-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathimgui_vtk_demo.h
118 lines (103 loc) · 3.38 KB
/
imgui_vtk_demo.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#pragma once
#include <vtkActor.h>
#include <vtkSmartPointer.h>
#include <vtkContourFilter.h>
#include <vtkMath.h>
#include <vtkNamedColors.h>
#include <vtkPointData.h>
#include <vtkPolyDataMapper.h>
#include <vtkProperty.h>
#include <vtkShortArray.h>
#include <vtkStructuredPoints.h>
static vtkSmartPointer<vtkActor> SetupDemoPipeline()
{
double Pr = 10.0; // The Lorenz parameters
double b = 2.667;
double r = 28.0;
double x, y, z; // starting (and current) x, y, z
double h = 0.01; // integration step size
int resolution = 200; // slice resolution
int iter = 10000000; // number of iterations
double xmin = -30.0; // x, y, z range for voxels
double xmax = 30.0;
double ymin = -30.0;
double ymax = 30.0;
double zmin = -10.0;
double zmax = 60.0;
// take a stab at an integration step size
auto xIncr = resolution / (xmax - xmin);
auto yIncr = resolution / (ymax - ymin);
auto zIncr = resolution / (zmax - zmin);
printf("The Lorenz Attractor\n");
printf(" Pr = %f\n", Pr);
printf(" b = %f\n", b);
printf(" r = %f\n", r);
printf(" integration step size = %f\n", h);
printf(" slice resolution = %d\n", resolution);
printf(" # of iterations = %d\n", iter);
printf(" specified range:\n");
printf(" x: %f, %f\n", xmin, xmax);
printf(" y: %f, %f\n", ymin, ymax);
printf(" z: %f, %f\n", zmin, zmax);
x = vtkMath::Random(xmin, xmax);
y = vtkMath::Random(ymin, ymax);
z = vtkMath::Random(zmin, zmax);
printf(" starting at %f, %f, %f\n", x, y, z);
// allocate memory for the slices
auto sliceSize = resolution * resolution;
auto numPts = sliceSize * resolution;
auto scalars =
vtkSmartPointer<vtkShortArray>::New();
auto s = scalars->WritePointer(0, numPts);
for (auto i = 0; i < numPts; i++)
{
s[i] = 0;
}
for (auto j = 0; j < iter; j++)
{
// integrate to next time step
auto xx = x + h * Pr * (y - x);
auto yy = y + h * (x * (r - z) - y);
auto zz = z + h * (x * y - (b * z));
x = xx;
y = yy;
z = zz;
// calculate voxel index
if (x < xmax && x > xmin && y < ymax && y > ymin && z < zmax && z > zmin)
{
auto xxx = static_cast<short>(static_cast<double>(xx - xmin) * xIncr);
auto yyy = static_cast<short>(static_cast<double>(yy - ymin) * yIncr);
auto zzz = static_cast<short>(static_cast<double>(zz - zmin) * zIncr);
auto index = xxx + yyy * resolution + zzz * sliceSize;
s[index] += 1;
}
}
auto colors =
vtkSmartPointer<vtkNamedColors>::New();
auto volume =
vtkSmartPointer<vtkStructuredPoints>::New();
volume->GetPointData()->SetScalars(scalars);
volume->SetDimensions(resolution, resolution, resolution);
volume->SetOrigin(xmin, ymin, zmin);
volume->SetSpacing((xmax - xmin) / resolution, (ymax - ymin) / resolution,
(zmax - zmin) / resolution);
printf(" contouring...\n");
// create iso-surface
auto contour =
vtkSmartPointer<vtkContourFilter>::New();
contour->SetInputData(volume);
contour->SetValue(0, 50);
// create mapper
auto mapper =
vtkSmartPointer<vtkPolyDataMapper>::New();
mapper->SetInputConnection(contour->GetOutputPort());
mapper->ScalarVisibilityOff();
// create actor
auto actor =
vtkSmartPointer<vtkActor>::New();
actor->SetMapper(mapper);
#if VTK_MAJOR_VERSION >= 9
actor->GetProperty()->SetColor(colors->GetColor3d("PaleTurquoise").GetData());
#endif
return actor;
}