/* This file is part of MAUS: http://micewww.pp.rl.ac.uk/projects/maus
*
* MAUS is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* MAUS is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with MAUS. If not, see .
*
*/
#include "gtest/gtest.h"
#include "src/legacy/Config/MiceModule.hh"
#include "src/common_cpp/Globals/GlobalsManager.hh"
#include "src/common_cpp/Simulation/GeometryNavigator.hh"
namespace MAUS {
class GeometryNavigatorTest : public ::testing::Test {
protected:
GeometryNavigatorTest() {
std::string mod_path = getenv("MAUS_ROOT_DIR");
mod_path += "/tests/cpp_unit/Simulation/TestGeometries/";
MiceModule* materials = new MiceModule(mod_path+"GeometryNavigatorTest.dat");
GlobalsManager::SetMonteCarloMiceModules(materials);
auto nist_t = {60., 70., 80., 90., 100., 120., 140., 170., 200.};
_nist_energy = std::vector(nist_t);
}
virtual ~GeometryNavigatorTest() {}
virtual void SetUp() {}
virtual void TearDown() {}
double _mass = 105.658;
std::vector _nist_energy;
};
TEST_F(GeometryNavigatorTest, TestGetMaterial) {
ThreeVector pos(0., 0., 100.);
GeometryNavigator* navigator = Globals::GetMCGeometryNavigator();
navigator->ComputeStep(pos, ThreeVector(0., 0., 1.), 1e9);
EXPECT_EQ(navigator->GetMaterialName(), std::string("G4_POLYSTYRENE"));
EXPECT_EQ(navigator->GetMaterial()->GetName(), std::string("G4_POLYSTYRENE"));
EXPECT_TRUE(navigator->IsMixture());
EXPECT_EQ(navigator->GetNumberOfElements(), 2);
// just check the API gives a number; assume values are correct.
for (int i = 0; i < navigator->GetNumberOfElements(); ++i) {
std::cerr << " A " << navigator->GetA(i);
std::cerr << " Z " << navigator->GetZ(i);
std::cerr << " fr " << navigator->GetFraction(i) << std::endl;
}
std::cerr << " N " << navigator->GetNuclearInteractionLength();
std::cerr << " X " << navigator->GetRadiationLength();
std::cerr << " rho " << navigator->GetDensity() << std::endl;
}
TEST_F(GeometryNavigatorTest, TestComputeStepCylinder) {
// This test describes a bug, the step computation yields the distance to
// the nearest boundary irrespective of the actual direction
GeometryNavigator* navigator = Globals::GetMCGeometryNavigator();
double step = 0.;
ThreeVector pos(0., 0., 0.);
pos = ThreeVector(0., 0., 100.);
step = navigator->ComputeStep(pos, ThreeVector(100., 0., 0.), 1e9);
EXPECT_NEAR(step, 25., 1e-3);
step = navigator->ComputeStep(pos, ThreeVector(100., 0., 0.), 1e9);
EXPECT_NEAR(step, 25., 1e-3);
step = navigator->ComputeStep(pos, ThreeVector(0., 100., 0.), 1e9);
EXPECT_NEAR(step, 25., 1e-3);
step = navigator->ComputeStep(pos, ThreeVector(0., 0., 100.), 1e9);
EXPECT_NEAR(step, 25., 1e-3);
}
TEST_F(GeometryNavigatorTest, TestComputeStepBox) {
GeometryNavigator* navigator = Globals::GetMCGeometryNavigator();
double step = 0.;
ThreeVector pos(0., 0., 0.);
step = navigator->ComputeStep(pos, ThreeVector(0., 0., 100.), 1.);
EXPECT_NEAR(step, 2.5, 1e-3);
step = navigator->ComputeStep(pos, ThreeVector(100., 0., 100.), 1.);
EXPECT_NEAR(step, 2.5, 1e-3);
step = navigator->ComputeStep(pos, ThreeVector(100., 100., 100.), 1.);
EXPECT_NEAR(step, 2.5, 1e-3);
}
TEST_F(GeometryNavigatorTest, TestComputeStepNestedCylinder) {
GeometryNavigator* navigator = Globals::GetMCGeometryNavigator();
double step = 0.;
ThreeVector pos(0., 0., 300.);
step = navigator->ComputeStep(pos, ThreeVector(0., 0., 100.), 1.);
EXPECT_NEAR(step, 15., 1e-3);
step = navigator->ComputeStep(pos, ThreeVector(0., 0., -100.), 1.);
EXPECT_NEAR(step, 15., 1e-3);
}
} // namespace MAUS