2017-09-05 22:36:21 +00:00
|
|
|
//============================================================================
|
|
|
|
// Copyright (c) Kitware, Inc.
|
|
|
|
// All rights reserved.
|
|
|
|
// See LICENSE.txt for details.
|
2019-04-15 23:24:21 +00:00
|
|
|
//
|
2017-09-05 22:36:21 +00:00
|
|
|
// 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/cont/ArrayHandleCast.h>
|
|
|
|
#include <vtkm/cont/DataSet.h>
|
2018-12-27 16:58:16 +00:00
|
|
|
#include <vtkm/cont/Initialize.h>
|
|
|
|
|
2020-04-30 12:12:04 +00:00
|
|
|
#include <vtkm/io/VTKDataSetReader.h>
|
|
|
|
#include <vtkm/io/VTKDataSetWriter.h>
|
2017-09-05 22:36:21 +00:00
|
|
|
|
|
|
|
#include <vtkm/worklet/CosmoTools.h>
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <stdexcept>
|
|
|
|
#include <string>
|
|
|
|
|
2018-12-06 18:33:31 +00:00
|
|
|
static const vtkm::cont::LogLevel CosmoLogLevel = vtkm::cont::LogLevel::UserFirst;
|
2017-09-05 22:36:21 +00:00
|
|
|
|
|
|
|
void TestCosmoCenterFinder(const char* fileName)
|
|
|
|
{
|
|
|
|
std::cout << std::endl
|
|
|
|
<< "Testing Cosmology MBP Center Finder Filter on one halo " << fileName << std::endl;
|
|
|
|
|
|
|
|
// Open the file for reading
|
|
|
|
std::ifstream inFile(fileName);
|
|
|
|
if (inFile.fail())
|
|
|
|
{
|
|
|
|
std::cout << "File does not exist " << fileName << std::endl;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Read in number of particles and locations
|
2020-05-12 13:16:54 +00:00
|
|
|
vtkm::Id nParticles;
|
2017-09-05 22:36:21 +00:00
|
|
|
inFile >> nParticles;
|
|
|
|
|
2020-05-12 13:16:54 +00:00
|
|
|
float* xLocation = new float[static_cast<std::size_t>(nParticles)];
|
|
|
|
float* yLocation = new float[static_cast<std::size_t>(nParticles)];
|
|
|
|
float* zLocation = new float[static_cast<std::size_t>(nParticles)];
|
2017-09-05 22:36:21 +00:00
|
|
|
std::cout << "Running MBP on " << nParticles << std::endl;
|
|
|
|
|
|
|
|
for (vtkm::Id p = 0; p < nParticles; p++)
|
|
|
|
{
|
|
|
|
inFile >> xLocation[p] >> yLocation[p] >> zLocation[p];
|
|
|
|
}
|
|
|
|
|
|
|
|
vtkm::cont::ArrayHandle<vtkm::Float32> xLocArray =
|
2020-07-16 16:32:32 +00:00
|
|
|
vtkm::cont::make_ArrayHandle<vtkm::Float32>(xLocation, nParticles, vtkm::CopyFlag::Off);
|
2017-09-05 22:36:21 +00:00
|
|
|
vtkm::cont::ArrayHandle<vtkm::Float32> yLocArray =
|
2020-07-16 16:32:32 +00:00
|
|
|
vtkm::cont::make_ArrayHandle<vtkm::Float32>(yLocation, nParticles, vtkm::CopyFlag::Off);
|
2017-09-05 22:36:21 +00:00
|
|
|
vtkm::cont::ArrayHandle<vtkm::Float32> zLocArray =
|
2020-07-16 16:32:32 +00:00
|
|
|
vtkm::cont::make_ArrayHandle<vtkm::Float32>(zLocation, nParticles, vtkm::CopyFlag::Off);
|
2017-09-05 22:36:21 +00:00
|
|
|
|
|
|
|
// Output MBP particleId pairs array
|
|
|
|
vtkm::Pair<vtkm::Id, vtkm::Float32> nxnResult;
|
|
|
|
vtkm::Pair<vtkm::Id, vtkm::Float32> mxnResult;
|
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
const vtkm::Float32 particleMass = 1.08413e+09f;
|
|
|
|
vtkm::worklet::CosmoTools cosmoTools;
|
2017-09-05 22:36:21 +00:00
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
{
|
|
|
|
VTKM_LOG_SCOPE(CosmoLogLevel, "Executing NxN");
|
2017-09-05 22:36:21 +00:00
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
cosmoTools.RunMBPCenterFinderNxN(
|
|
|
|
xLocArray, yLocArray, zLocArray, nParticles, particleMass, nxnResult);
|
2017-09-05 22:36:21 +00:00
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
VTKM_LOG_S(CosmoLogLevel,
|
|
|
|
"NxN MPB = " << nxnResult.first << " potential = " << nxnResult.second);
|
|
|
|
}
|
2017-09-05 22:36:21 +00:00
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
{
|
|
|
|
VTKM_LOG_SCOPE(CosmoLogLevel, "Executing MxN");
|
|
|
|
cosmoTools.RunMBPCenterFinderMxN(
|
|
|
|
xLocArray, yLocArray, zLocArray, nParticles, particleMass, mxnResult);
|
2017-09-05 22:36:21 +00:00
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
VTKM_LOG_S(CosmoLogLevel,
|
|
|
|
"MxN MPB = " << mxnResult.first << " potential = " << mxnResult.second);
|
|
|
|
}
|
2017-09-05 22:36:21 +00:00
|
|
|
|
|
|
|
if (nxnResult.first == mxnResult.first)
|
|
|
|
std::cout << "FOUND CORRECT PARTICLE " << mxnResult.first << " with potential "
|
|
|
|
<< nxnResult.second << std::endl;
|
|
|
|
else
|
|
|
|
std::cout << "ERROR DID NOT FIND SAME PARTICLE" << std::endl;
|
|
|
|
|
|
|
|
xLocArray.ReleaseResources();
|
|
|
|
yLocArray.ReleaseResources();
|
|
|
|
zLocArray.ReleaseResources();
|
|
|
|
|
|
|
|
delete[] xLocation;
|
|
|
|
delete[] yLocation;
|
|
|
|
delete[] zLocation;
|
|
|
|
}
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Form of the input file in ASCII
|
|
|
|
// Line 1: number of particles in the file
|
|
|
|
// Line 2+: (float) xLoc (float) yLoc (float) zLoc
|
|
|
|
//
|
|
|
|
// CosmoCenterFinder data.cosmotools
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
2018-11-27 17:56:00 +00:00
|
|
|
vtkm::cont::SetLogLevelName(CosmoLogLevel, "Cosmo");
|
|
|
|
vtkm::cont::SetStderrLogLevel(CosmoLogLevel);
|
2019-04-09 13:52:53 +00:00
|
|
|
|
|
|
|
auto opts = vtkm::cont::InitializeOptions::DefaultAnyDevice;
|
|
|
|
vtkm::cont::InitializeResult config = vtkm::cont::Initialize(argc, argv, opts);
|
2018-11-27 17:56:00 +00:00
|
|
|
|
2017-09-05 22:36:21 +00:00
|
|
|
if (argc < 2)
|
|
|
|
{
|
|
|
|
std::cout << "Usage: " << std::endl << "$ " << argv[0] << " <input_file>" << std::endl;
|
2019-04-09 13:52:53 +00:00
|
|
|
std::cout << config.Usage << std::endl;
|
2017-09-05 22:36:21 +00:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2018-11-27 17:56:00 +00:00
|
|
|
#ifndef VTKM_ENABLE_LOGGING
|
|
|
|
std::cout << "Warning: turn on VTKm_ENABLE_LOGGING CMake option to turn on timing." << std::endl;
|
|
|
|
#endif
|
|
|
|
|
2017-09-05 22:36:21 +00:00
|
|
|
TestCosmoCenterFinder(argv[1]);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|