Files
uLib/src/HEP/Geant/Solid.h
2026-04-18 19:22:23 +00:00

243 lines
5.4 KiB
C++

/*//////////////////////////////////////////////////////////////////////////////
// CMT Cosmic Muon Tomography project //////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
Copyright (c) 2014, Universita' degli Studi di Padova, INFN sez. di Padova
All rights reserved
Authors: Andrea Rigoni Garola < andrea.rigoni@pd.infn.it >
------------------------------------------------------------------
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 3.0 of the License, or (at your option) any later version.
This library 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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library.
//////////////////////////////////////////////////////////////////////////////*/
#ifndef SOLID_H
#define SOLID_H
#include "Core/Object.h"
#include "Geant/Matter.h"
#include "Math/Transform.h"
#include <Geant4/G4LogicalVolume.hh>
#include "Math/ContainerBox.h"
#include "Math/Dense.h"
#include "Math/TriangleMesh.h"
class G4Material;
class G4LogicalVolume;
class G4TessellatedSolid;
class G4Box;
namespace uLib {
namespace Geant {
class Solid : public Object {
uLibTypeMacro(Solid, Object)
ULIB_SERIALIZE_ACCESS
ULIB_DECLARE_PROPERTIES(Solid)
public:
Solid();
Solid(const char *name);
virtual ~Solid();
virtual G4VSolid* GetG4Solid() const { return nullptr; }
inline const char *GetName() const {
return m_Name.c_str();
}
template < typename Ar >
void serialize(Ar &ar, const unsigned int version) {
ar & HRP("Name", m_Name);
}
public slots:
virtual void Update();
protected:
std::string m_Name;
};
class LogicalVolume : public Object {
uLibTypeMacro(LogicalVolume, Object)
ULIB_SERIALIZE_ACCESS
ULIB_DECLARE_PROPERTIES(LogicalVolume)
public:
LogicalVolume();
LogicalVolume(const char *name);
virtual ~LogicalVolume();
virtual G4VSolid* GetG4Solid() const { return m_Solid ? m_Solid->GetG4Solid() : nullptr; }
Solid* GetSolid() const { return m_Solid.Get(); }
inline const char *GetName() const {
return m_Logical ? m_Logical->GetName().c_str() : m_Name.c_str();
}
void SetSolid(SmartPointer<Solid> solid) { m_Solid = solid; }
void SetMaterial(SmartPointer<Material> material) { m_Material = material; }
G4LogicalVolume* GetG4LogicalVolume() const { return m_Logical; }
template < typename Ar >
void serialize(Ar &ar, const unsigned int version) {
ar & HRP("Name", m_Name);
ar & HRP("Material", m_Material);
ar & HRP("Solid", m_Solid);
}
public slots:
virtual void Update();
protected:
std::string m_Name;
SmartPointer<Material> m_Material;
SmartPointer<Solid> m_Solid;
G4LogicalVolume *m_Logical;
};
class PhysicalVolume : public TRS {
uLibTypeMacro(PhysicalVolume, TRS)
ULIB_SERIALIZE_ACCESS
public:
PhysicalVolume();
PhysicalVolume(LogicalVolume *logical);
PhysicalVolume(const char *name, LogicalVolume *logical);
virtual ~PhysicalVolume();
LogicalVolume* GetLogical() const { return m_Logical.Get(); }
virtual G4VPhysicalVolume* GetG4PhysicalVolume() {
if (!m_Physical) Update();
return m_Physical;
}
const char* GetName() const { return m_Name.c_str(); }
template <typename Ar>
void serialize(Ar &ar, const unsigned int version) {
ar & boost::serialization::base_object<TRS>(*this);
ar & HRP("Name", m_Name);
ar & HRP("Logical", m_Logical);
}
public slots:
void Update();
protected:
std::string m_Name;
SmartPointer<LogicalVolume> m_Logical;
G4VPhysicalVolume *m_Physical;
ULIB_DECLARE_PROPERTIES(PhysicalVolume)
};
class TessellatedSolid : public Solid {
uLibTypeMacro(TessellatedSolid, Solid)
ULIB_SERIALIZE_ACCESS
public:
TessellatedSolid();
TessellatedSolid(const char *name);
void SetMesh(const TriangleMesh *mesh);
uLibGetMacro(Solid, G4TessellatedSolid *)
virtual G4VSolid* GetG4Solid() const override { return (G4VSolid*)m_Solid; }
const TriangleMesh* GetMesh() const { return m_Mesh.get(); }
virtual void Update() override;
protected:
SmartPointer<TriangleMesh> m_Mesh;
G4TessellatedSolid *m_Solid;
//ULIB_DECLARE_PROPERTIES(TessellatedSolid)
};
////////////////////////////////////////////////////////////////////////////////
//// BOX SOLID /////////////////////////////////////////////////////////////////
class BoxSolid : public Solid {
uLibTypeMacro(BoxSolid, Solid)
ULIB_SERIALIZE_ACCESS
public:
BoxSolid();
BoxSolid(const char *name);
BoxSolid(const char *name, SmartPointer<ContainerBox> box);
virtual G4VSolid* GetG4Solid() const override { return (G4VSolid*)m_Solid; }
virtual void Update() override;
ContainerBox* GetObject() const { return m_ContainerBox; }
template < typename Ar >
void serialize(Ar &ar, const unsigned int version) {
ar & boost::serialization::base_object<Solid>(*this);
ar & HRP("Container", m_ContainerBox);
}
private:
SmartPointer<ContainerBox> m_ContainerBox;
G4Box *m_Solid;
ULIB_DECLARE_PROPERTIES(BoxSolid)
};
} // namespace Geant
} // namespace uLib
#endif // SOLID_H