mirror of
https://gitlab.kitware.com/vtk/vtk-m
synced 2024-10-05 09:59:12 +00:00
5aba6e1bea
Some of the test data sets are derived from data sets that are commonly distributed to test visualization algorithms and are featured in numerous papers. However, I am unable to track down the original source let alone identify what license, if any, they were released under. To avoid any complications with data ownership, remove these data sets and replace them with in house data sets that we explicitly own.
92 lines
3.1 KiB
C++
92 lines
3.1 KiB
C++
//============================================================================
|
|
// Copyright (c) Kitware, Inc.
|
|
// All rights reserved.
|
|
// See LICENSE.txt for details.
|
|
//
|
|
// This software is distributed WITHOUT ANY WARRANTY; without even
|
|
// the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
// PURPOSE. See the above copyright notice for more information.
|
|
//============================================================================
|
|
|
|
#include <vtkm/Particle.h>
|
|
#include <vtkm/cont/DataSet.h>
|
|
#include <vtkm/cont/Initialize.h>
|
|
#include <vtkm/filter/flow/Streamline.h>
|
|
#include <vtkm/io/VTKDataSetReader.h>
|
|
#include <vtkm/io/VTKDataSetWriter.h>
|
|
|
|
// Example computing streamlines.
|
|
// An example vector field is available in the vtk-m data directory: rotate-vectors.vtk
|
|
// Example usage:
|
|
// this will advect 200 particles 50 steps using a step size of 0.05
|
|
//
|
|
// Particle_Advection <path-to-data-dir>/rotate-vectors.vtk rotate 200 50 0.05 output.vtk
|
|
//
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
auto opts = vtkm::cont::InitializeOptions::DefaultAnyDevice;
|
|
auto config = vtkm::cont::Initialize(argc, argv, opts);
|
|
|
|
if (argc < 7)
|
|
{
|
|
std::cerr << "Usage: " << argv[0]
|
|
<< " dataFile varName numSeeds numSteps stepSize outputFile [options]" << std::endl;
|
|
std::cerr << "where options are: " << std::endl << config.Usage << std::endl;
|
|
return -1;
|
|
}
|
|
|
|
std::string dataFile = argv[1];
|
|
std::string varName = argv[2];
|
|
vtkm::Id numSeeds = std::stoi(argv[3]);
|
|
vtkm::Id numSteps = std::stoi(argv[4]);
|
|
vtkm::FloatDefault stepSize = std::stof(argv[5]);
|
|
std::string outputFile = argv[6];
|
|
|
|
vtkm::cont::DataSet ds;
|
|
|
|
if (dataFile.find(".vtk") != std::string::npos)
|
|
{
|
|
vtkm::io::VTKDataSetReader rdr(dataFile);
|
|
ds = rdr.ReadDataSet();
|
|
}
|
|
else
|
|
{
|
|
std::cerr << "Unsupported data file: " << dataFile << std::endl;
|
|
return -1;
|
|
}
|
|
|
|
//create seeds randomly placed withing the bounding box of the data.
|
|
vtkm::Bounds bounds = ds.GetCoordinateSystem().GetBounds();
|
|
std::vector<vtkm::Particle> seeds;
|
|
|
|
for (vtkm::Id i = 0; i < numSeeds; i++)
|
|
{
|
|
vtkm::Particle p;
|
|
vtkm::FloatDefault rx = (vtkm::FloatDefault)rand() / (vtkm::FloatDefault)RAND_MAX;
|
|
vtkm::FloatDefault ry = (vtkm::FloatDefault)rand() / (vtkm::FloatDefault)RAND_MAX;
|
|
vtkm::FloatDefault rz = (vtkm::FloatDefault)rand() / (vtkm::FloatDefault)RAND_MAX;
|
|
p.SetPosition({ static_cast<vtkm::FloatDefault>(bounds.X.Min + rx * bounds.X.Length()),
|
|
static_cast<vtkm::FloatDefault>(bounds.Y.Min + ry * bounds.Y.Length()),
|
|
static_cast<vtkm::FloatDefault>(bounds.Z.Min + rz * bounds.Z.Length()) });
|
|
p.SetID(i);
|
|
seeds.push_back(p);
|
|
}
|
|
auto seedArray = vtkm::cont::make_ArrayHandle(seeds, vtkm::CopyFlag::Off);
|
|
|
|
//compute streamlines
|
|
vtkm::filter::flow::Streamline streamline;
|
|
|
|
streamline.SetStepSize(stepSize);
|
|
streamline.SetNumberOfSteps(numSteps);
|
|
streamline.SetSeeds(seedArray);
|
|
|
|
streamline.SetActiveField(varName);
|
|
auto output = streamline.Execute(ds);
|
|
|
|
vtkm::io::VTKDataSetWriter wrt(outputFile);
|
|
wrt.WriteDataSet(output);
|
|
|
|
return 0;
|
|
}
|