58 CheckCopyNo( copyNo );
60 std::size_t nx, ny, nz;
61 ComputeVoxelIndices( copyNo, nx, ny, nz );
74 CheckCopyNo( copyNo );
85 CheckCopyNo( copyNo );
104GetMaterial( std::size_t nx, std::size_t ny, std::size_t nz)
const
119void G4PartialPhantomParameterisation::
120ComputeVoxelIndices(
const G4int copyNo, std::size_t& nx,
121 std::size_t& ny, std::size_t& nz )
const
123 CheckCopyNo( copyNo );
125 auto ite = fFilledIDs.lower_bound(copyNo);
126 G4long dist = std::distance( fFilledIDs.cbegin(), ite );
130 G4int ifmin = (*ite).second;
135 nvoxXprev = (*ite).first;
142 nx = ifmin+copyNo-nvoxXprev-1;
180 if( localDir.
x() < 0 )
197 if( localDir.
y() < 0 )
214 if( localDir.
z() < 0 )
265 std::ostringstream message;
266 message <<
"Corrected the copy number! It was negative or too big."
268 <<
" LocalPoint: " << localPoint <<
G4endl
269 <<
" LocalDir: " << localDir <<
G4endl
272 <<
" LocalPoint - wall: "
276 G4Exception(
"G4PartialPhantomParameterisation::GetReplicaNo()",
281 auto ite = fFilledIDs.cbegin();
291 auto iteant = ite; iteant--;
292 G4int copyNo = (*iteant).first + 1 + ( nx - (*ite).second );
307void G4PartialPhantomParameterisation::CheckCopyNo(
const G4long copyNo )
const
311 std::ostringstream message;
312 message <<
"Copy number is negative or too big!" <<
G4endl
313 <<
" Copy number: " << copyNo <<
G4endl
314 <<
" Total number of voxels: " <<
fNoVoxels;
315 G4Exception(
"G4PartialPhantomParameterisation::CheckCopyNo()",
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
CLHEP::Hep3Vector G4ThreeVector
G4TouchableHistory G4VTouchable
std::size_t GetMaterialIndex(std::size_t nx, std::size_t ny, std::size_t nz) const
void ComputeTransformation(const G4int, G4VPhysicalVolume *) const override
G4Material * GetMaterial(std::size_t nx, std::size_t ny, std::size_t nz) const
G4int GetReplicaNo(const G4ThreeVector &localPoint, const G4ThreeVector &localDir) override
G4Material * ComputeMaterial(const G4int repNo, G4VPhysicalVolume *currentVol, const G4VTouchable *parentTouch=nullptr) override
void BuildContainerWalls()
G4ThreeVector GetTranslation(const G4int copyNo) const
std::size_t * fMaterialIndices
std::vector< G4Material * > fMaterials
void SetTranslation(const G4ThreeVector &v)