Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4PolyhedronArbitrary.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration and of QinetiQ Ltd, *
20// * subject to DEFCON 705 IPR conditions. *
21// * By using, copying, modifying or distributing the software (or *
22// * any work based on the software) you agree to acknowledge its *
23// * use in resulting scientific publications, and indicate your *
24// * acceptance of all terms of the Geant4 Software license. *
25// ********************************************************************
26//
27//
28// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
29//
30// MODULE: G4PolyhedronArbitrary.cc
31//
32// Date: 15/06/2005
33// Author: P R Truscott
34// Organisation: QinetiQ Ltd, UK
35// Customer: UK Ministry of Defence : RAO CRP TD Electronic Systems
36// Contract: C/MAT/N03517
37//
38// This software is the intellectual property of QinetiQ Ltd, subject
39// DEFCON 705 IPR conditions.
40//
41// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
42//
43// CHANGE HISTORY
44// --------------
45//
46// 31 October 2004, P R Truscott, QinetiQ Ltd, UK
47// Created.
48//
49// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
50//
51// DESCRIPTION
52// -----------
53//
54//
55//
56///////////////////////////////////////////////////////////////////////////////
57//
58//
60///////////////////////////////////////////////////////////////////////////////
61//
63 const G4int nFacets)
64{
65 AllocateMemory(nVertices, nFacets);
66 nVertexCount = 0;
67 nFacetCount = 0;
68}
69///////////////////////////////////////////////////////////////////////////////
70//
73///////////////////////////////////////////////////////////////////////////////
74//
76{
77 if (nVertexCount == nvert + 1)
78 {
79 G4cerr <<G4endl;
80 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddVertex" <<G4endl;
81 G4cerr <<"ATTEMPT TO EXCEED MAXIMUM NUMBER OF VERTICES : " << nVertexCount
82 <<G4endl;
83 G4cerr <<G4endl;
84 }
85 else
86 {
88 pV[nVertexCount] = v;
89 }
90}
91///////////////////////////////////////////////////////////////////////////////
92//
93void G4PolyhedronArbitrary::AddFacet (const G4int iv1, const G4int iv2,
94 const G4int iv3, const G4int iv4)
95{
96 if (nFacetCount == nface)
97 {
98 G4cerr <<G4endl;
99 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddFacet" <<G4endl;
100 G4cerr <<"ATTEMPT TO EXCEED MAXIMUM NUMBER OF FACETS : " << nFacetCount
101 <<G4endl;
102 G4cerr <<G4endl;
103 }
104 else if (iv1 < 1 || iv1 > nvert || iv2 < 1 || iv2 > nvert ||
105 iv3 < 1 || iv3 > nvert || iv4 > nvert)
106 {
107 G4cerr <<G4endl;
108 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddFacet" <<G4endl;
109 G4cerr <<"ATTEMPT TO INDEX VERTEX NUMBER WHICH IS OUT-OF-RANGE : " <<G4endl;
110 G4cerr <<G4endl;
111 }
112 else if (iv1 > nVertexCount || iv2 > nVertexCount || iv3 > nVertexCount ||
113 iv4 > nVertexCount)
114 {
115 G4cerr <<G4endl;
116 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddFacet" <<G4endl;
117 G4cerr <<"VERTEX NEEDS TO BE DEFINED FIRST : " <<G4endl;
118 G4cerr <<G4endl;
119 }
120 else
121 {
122 nFacetCount++;
123 pF[nFacetCount] = G4Facet(iv1, 0, iv2, 0, iv3, 0, iv4, 0);
124 }
125}
126///////////////////////////////////////////////////////////////////////////////
127//
int G4int
Definition G4Types.hh:85
G4GLOB_DLL std::ostream G4cerr
#define G4endl
Definition G4ios.hh:67
G4PolyhedronArbitrary(const G4int nVertices, const G4int nFacets)
void AddFacet(const G4int iv1, const G4int iv2, const G4int iv3, const G4int iv4=0)
void AddVertex(const G4ThreeVector &v)
G4Point3D * pV
void AllocateMemory(G4int Nvert, G4int Nface)