作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试将数据从统一网格写入 vtk XML 文件,以便我可以使用 Paraview 呈现它。我希望我的输出文件包含两个变量:一个 3 分量 vector 和一个标量值在每一点。我设法写了一个 .vti 文件,只包含 vector ,如下所示:
#include <vtkVersion.h>
#include <vtkSmartPointer.h>
#include <vtkXMLImageDataWriter.h>
#include <vtkImageData.h>
int main()
{
int nx = 10, ny = 10, nz = 10;
vtkSmartPointer<vtkImageData> imageData =
vtkSmartPointer<vtkImageData>::New();
imageData->SetDimensions(nx, ny, nz);
#if VTK_MAJOR_VERSION <= 5
imageData->SetNumberOfScalarComponents(3);
imageData->SetScalarTypeToDouble();
#else
imageData->AllocateScalars(VTK_DOUBLE, 3);
#endif
for (int k = 0; k < nz; ++k) {
for (int j = 0; j < ny; ++j) {
for (int i = 0; i < nx; ++i) {
double * voxel = static_cast<double*>(imageData->GetScalarPointer(i,j,k));
int coord = i + j * nx + k * nx * ny;
double t = 0.0;
double p = 1.0;
voxel[0] = sin(t) * cos(p);
voxel[1] = sin(t) * sin(p);
voxel[2] = cos(t);
}
}
}
vtkSmartPointer<vtkXMLImageDataWriter> writer =
vtkSmartPointer<vtkXMLImageDataWriter>::New();
writer->SetFileName("test.vti");
#if VTK_MAJOR_VERSION <= 5
writer->SetInputConnection(imageData->GetProducerPort());
#else
writer->SetInputData(imageData);
#endif
writer->Write();
return EXIT_SUCCESS;
}
如何为网格上的每个点添加一个额外的标量值?
最佳答案
根据这个答案中的 python 代码,我自己想出了如何做到这一点:
https://stackoverflow.com/a/7667417/2088135
如果有人对如何做同样的事情感兴趣,这里是“翻译”代码。
#include <vtkVersion.h>
#include <vtkSmartPointer.h>
#include <vtkXMLImageDataWriter.h>
#include <vtkImageData.h>
#include <vtkPointData.h>
#include <vtkDoubleArray.h>
int main()
{
int nx = 10, ny = 10, nz = 10;
vtkSmartPointer<vtkImageData> imageData =
vtkSmartPointer<vtkImageData>::New();
imageData->SetDimensions(nx, ny, nz);
vtkSmartPointer<vtkDoubleArray> director =
vtkSmartPointer<vtkDoubleArray>::New();
director->SetNumberOfComponents(3);
director->SetNumberOfTuples(nx * ny * nz);
vtkSmartPointer<vtkDoubleArray> energy =
vtkSmartPointer<vtkDoubleArray>::New();
energy->SetNumberOfComponents(1);
energy->SetNumberOfTuples(nx * ny * nz);
for (int i = 0; i < director->GetNumberOfTuples(); ++i) {
double t = 1.0;
double p = 0.0;
double e = 5.0;
double x = sin(t) * cos(p),
y = sin(t) * sin(p),
z = cos(t);
director->SetTuple3(i, x, y, z);
energy->SetValue(i, e);
}
imageData->GetPointData()->AddArray(director);
director->SetName("Director");
imageData->GetPointData()->AddArray(energy);
energy->SetName("Energy");
vtkSmartPointer<vtkXMLImageDataWriter> writer =
vtkSmartPointer<vtkXMLImageDataWriter>::New();
writer->SetFileName("test.vti");
#if VTK_MAJOR_VERSION <= 5
writer->SetInputConnection(imageData->GetProducerPort());
#else
writer->SetInputData(imageData);
#endif
writer->Write();
return EXIT_SUCCESS;
}
关于c++ vtk xml writer (vtkImageData) - 同一个vti文件中的多个变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14964312/
我用 express.js 创建了一个 Electron 应用程序,用 Electron 开发一个快速应用程序的原因是打包一个在没有安装 Node 的情况下运行的可执行文件。 我成功地将应用程序打包到
我有一个要求,在 Juniper 路由器外壳中运行的 python 脚本需要在 FPC 的 vty 控制台中执行一些命令。我不能使用 vty c,因为它可能无法在所有平台上正常工作。但是,我可以使用
我有代码可以在“line vty”上查找“access-class”的名称 之后我能够找到 ACL,但随后我想检查 ACL 的每一行以验证“拒绝”和“允许”语句是否具有“log”关键字。如果条目上没有
我是一名优秀的程序员,十分优秀!