|
| 1 | +//----------------------------------------------------------------------------- |
| 2 | +/// |
| 3 | +/// file: t_vtk-h_dataset.cpp |
| 4 | +/// |
| 5 | +//----------------------------------------------------------------------------- |
| 6 | + |
| 7 | +#include "gtest/gtest.h" |
| 8 | + |
| 9 | +#include <vtkh/vtkh.hpp> |
| 10 | +#include <vtkh/DataSet.hpp> |
| 11 | +#include <vtkh/filters/MeshQuality.hpp> |
| 12 | +#include <vtkh/rendering/RayTracer.hpp> |
| 13 | +#include <vtkh/rendering/Scene.hpp> |
| 14 | +#include <vtkm/cont/testing/MakeTestDataSet.h> |
| 15 | + |
| 16 | + |
| 17 | +#include <iostream> |
| 18 | + |
| 19 | + |
| 20 | + |
| 21 | +//---------------------------------------------------------------------------- |
| 22 | +TEST(vtkh_mesh_quality, vtkh_volume) |
| 23 | +{ |
| 24 | + vtkh::DataSet data_set; |
| 25 | + |
| 26 | + const int base_size = 32; |
| 27 | + const int num_blocks = 2; |
| 28 | + |
| 29 | + vtkm::cont::testing::MakeTestDataSet maker; |
| 30 | + data_set.AddDomain(maker.Make3DExplicitDataSet5(),0); |
| 31 | + |
| 32 | + vtkh::MeshQuality quali; |
| 33 | + quali.SetInput(&data_set); |
| 34 | + quali.AddMapField("point_data_Float64"); |
| 35 | + quali.AddMapField("cell_data_Float64"); |
| 36 | + quali.Update(); |
| 37 | + |
| 38 | + vtkh::DataSet *q_output = quali.GetOutput(); |
| 39 | + |
| 40 | + vtkm::Bounds bounds = q_output->GetGlobalBounds(); |
| 41 | + float bg_color[4] = { 0.f, 0.f, 0.f, 1.f}; |
| 42 | + vtkm::rendering::Camera camera; |
| 43 | + camera.ResetToBounds(bounds); |
| 44 | + vtkh::Render render = vtkh::MakeRender(512, |
| 45 | + 512, |
| 46 | + camera, |
| 47 | + *q_output, |
| 48 | + "mesh_volume", |
| 49 | + bg_color); |
| 50 | + vtkh::RayTracer tracer; |
| 51 | + tracer.SetInput(q_output); |
| 52 | + tracer.SetField("volume"); |
| 53 | + |
| 54 | + vtkh::Scene scene; |
| 55 | + scene.AddRenderer(&tracer); |
| 56 | + scene.AddRender(render); |
| 57 | + scene.Render(); |
| 58 | + |
| 59 | + delete q_output; |
| 60 | +} |
| 61 | + |
| 62 | +//---------------------------------------------------------------------------- |
| 63 | +TEST(vtkh_mesh_quality, vtkh_not_supported) |
| 64 | +{ |
| 65 | + vtkh::DataSet data_set; |
| 66 | + |
| 67 | + const int base_size = 32; |
| 68 | + const int num_blocks = 2; |
| 69 | + |
| 70 | + vtkm::cont::testing::MakeTestDataSet maker; |
| 71 | + data_set.AddDomain(maker.Make3DExplicitDataSet5(),0); |
| 72 | + data_set.AddDomain(maker.Make3DUniformDataSet0(),1); |
| 73 | + |
| 74 | + vtkh::MeshQuality quali; |
| 75 | + quali.SetInput(&data_set); |
| 76 | + quali.AddMapField("point_data_Float64"); |
| 77 | + quali.AddMapField("cell_data_Float64"); |
| 78 | + bool threw = false; |
| 79 | + try |
| 80 | + { |
| 81 | + quali.Update(); |
| 82 | + } |
| 83 | + catch(...) |
| 84 | + { |
| 85 | + threw = true; |
| 86 | + } |
| 87 | + EXPECT_TRUE(threw); |
| 88 | +} |
0 commit comments