Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions | Protected Member Functions | Protected Attributes
G4PrimaryTransformer Class Reference

#include <G4PrimaryTransformer.hh>

Public Member Functions

 G4PrimaryTransformer ()
 
virtual ~G4PrimaryTransformer ()
 
G4TrackVectorGimmePrimaries (G4Event *anEvent, G4int trackIDCounter=0)
 
void CheckUnknown ()
 
void SetVerboseLevel (G4int vl)
 
void SetUnknnownParticleDefined (G4bool vl)
 
G4bool GetUnknownParticleDefined () const
 

Protected Member Functions

void GenerateTracks (G4PrimaryVertex *primaryVertex)
 
void GenerateSingleTrack (G4PrimaryParticle *primaryParticle, G4double x0, G4double y0, G4double z0, G4double t0, G4double wv)
 
void SetDecayProducts (G4PrimaryParticle *mother, G4DynamicParticle *motherDP)
 
G4bool CheckDynamicParticle (G4DynamicParticle *DP)
 
virtual G4ParticleDefinitionGetDefinition (G4PrimaryParticle *pp)
 
virtual G4bool IsGoodForTrack (G4ParticleDefinition *pd)
 

Protected Attributes

G4TrackVector TV
 
G4ParticleTableparticleTable
 
G4int verboseLevel
 
G4int trackID
 
G4ParticleDefinitionunknown
 
G4bool unknownParticleDefined
 
G4ParticleDefinitionopticalphoton
 
G4bool opticalphotonDefined
 
G4int nWarn
 

Detailed Description

Definition at line 47 of file G4PrimaryTransformer.hh.

Constructor & Destructor Documentation

G4PrimaryTransformer::G4PrimaryTransformer ( )
G4PrimaryTransformer::~G4PrimaryTransformer ( )
virtual

Definition at line 53 of file G4PrimaryTransformer.cc.

54 {;}

Member Function Documentation

G4bool G4PrimaryTransformer::CheckDynamicParticle ( G4DynamicParticle DP)
protected

Definition at line 305 of file G4PrimaryTransformer.cc.

References G4DecayProducts::entries(), G4cerr, G4endl, G4Exception(), G4DynamicParticle::GetDefinition(), G4DynamicParticle::GetPreAssignedDecayProducts(), IsGoodForTrack(), and JustWarning.

306 {
307  if(IsGoodForTrack(DP->GetDefinition())) return true;
309  if(decayProducts && decayProducts->entries()>0) return true;
310  G4cerr << G4endl
311  << "G4PrimaryTransformer: a shortlived primary particle is found" << G4endl
312  << " without any valid decay table nor pre-assigned decay mode." << G4endl;
313  G4Exception("G4PrimaryTransformer","InvalidPrimary",JustWarning,
314  "This primary particle will be ignored.");
315  return false;
316 }
const G4DecayProducts * GetPreAssignedDecayProducts() const
G4ParticleDefinition * GetDefinition() const
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
Definition: G4Exception.cc:41
virtual G4bool IsGoodForTrack(G4ParticleDefinition *pd)
#define G4endl
Definition: G4ios.hh:61
G4int entries() const
G4GLOB_DLL std::ostream G4cerr
void G4PrimaryTransformer::CheckUnknown ( )

Definition at line 56 of file G4PrimaryTransformer.cc.

References G4ParticleTable::FindParticle(), opticalphoton, opticalphotonDefined, particleTable, unknown, and unknownParticleDefined.

Referenced by G4PrimaryTransformer(), and G4RunManagerKernel::RunInitialization().

57 {
58  unknown = particleTable->FindParticle("unknown");
59  if(unknown)
60  { unknownParticleDefined = true; }
61  else
62  { unknownParticleDefined = false; }
63  opticalphoton = particleTable->FindParticle("opticalphoton");
64  if(opticalphoton)
65  { opticalphotonDefined = true; }
66  else
67  { opticalphotonDefined = false; }
68 }
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
G4ParticleDefinition * opticalphoton
G4ParticleTable * particleTable
G4ParticleDefinition * unknown
void G4PrimaryTransformer::GenerateSingleTrack ( G4PrimaryParticle primaryParticle,
G4double  x0,
G4double  y0,
G4double  z0,
G4double  t0,
G4double  wv 
)
protected

Definition at line 116 of file G4PrimaryTransformer.cc.

References G4DynamicParticle::AddElectron(), CLHEP::Hep3Vector::cross(), DBL_MAX, python.hepunit::deg, python.hepunit::eplus, G4cerr, G4cout, G4endl, G4Exception(), G4UniformRand, G4ParticleDefinition::GetAtomicNumber(), G4PrimaryParticle::GetCharge(), G4PrimaryParticle::GetDaughter(), G4PrimaryParticle::GetKineticEnergy(), G4PrimaryParticle::GetMass(), G4PrimaryParticle::GetMomentum(), G4DynamicParticle::GetMomentumDirection(), G4PrimaryParticle::GetMomentumDirection(), G4PrimaryParticle::GetNext(), G4ParticleDefinition::GetParticleName(), G4PrimaryParticle::GetPDGcode(), G4ParticleDefinition::GetPDGEncoding(), G4PrimaryParticle::GetPolarization(), G4PrimaryParticle::GetPolX(), G4PrimaryParticle::GetPolY(), G4PrimaryParticle::GetPolZ(), G4PrimaryParticle::GetProperTime(), G4PrimaryParticle::GetWeight(), iz, JustWarning, CLHEP::Hep3Vector::mag2(), G4DynamicParticle::SetCharge(), G4DynamicParticle::SetMass(), G4Track::SetParentID(), G4DynamicParticle::SetPDGcode(), G4DynamicParticle::SetPolarization(), G4DynamicParticle::SetPreAssignedDecayProperTime(), G4DynamicParticle::SetPrimaryParticle(), G4Track::SetTrackID(), G4PrimaryParticle::SetTrackID(), G4Track::SetWeight(), CLHEP::Hep3Vector::x(), CLHEP::Hep3Vector::y(), and CLHEP::Hep3Vector::z().

Referenced by GenerateTracks().

118 {
119  G4ParticleDefinition* partDef = GetDefinition(primaryParticle);
120  if(!IsGoodForTrack(partDef))
121  // The particle cannot be converted to G4Track, check daughters
122  {
123 #ifdef G4VERBOSE
124  if(verboseLevel>2)
125  {
126  G4cout << "Primary particle (PDGcode " << primaryParticle->GetPDGcode()
127  << ") --- Ignored" << G4endl;
128  }
129 #endif
130  G4PrimaryParticle* daughter = primaryParticle->GetDaughter();
131  while(daughter)
132  {
133  GenerateSingleTrack(daughter,x0,y0,z0,t0,wv);
134  daughter = daughter->GetNext();
135  }
136  }
137 
138  // The particle is defined in GEANT4
139  else
140  {
141  // Create G4DynamicParticle object
142 #ifdef G4VERBOSE
143  if(verboseLevel>1)
144  {
145  G4cout << "Primary particle (" << partDef->GetParticleName()
146  << ") --- Transfered with momentum " << primaryParticle->GetMomentum()
147  << G4endl;
148  }
149 #endif
150  G4DynamicParticle* DP =
151  new G4DynamicParticle(partDef,
152  primaryParticle->GetMomentumDirection(),
153  primaryParticle->GetKineticEnergy());
154  if(opticalphotonDefined && partDef==opticalphoton && primaryParticle->GetPolarization().mag2()==0.)
155  {
156  if(nWarn<10)
157  {
158  G4Exception("G4PrimaryTransformer::GenerateSingleTrack","ZeroPolarization",JustWarning,
159  "Polarization of the optical photon is null. Random polarization is assumed.");
160  G4cerr << "This warning message is issued up to 10 times." << G4endl;
161  nWarn++;
162  }
163 
164  G4double angle = G4UniformRand() * 360.0*deg;
165  G4ThreeVector normal (1., 0., 0.);
166  G4ThreeVector kphoton = DP->GetMomentumDirection();
167  G4ThreeVector product = normal.cross(kphoton);
168  G4double modul2 = product*product;
169 
170  G4ThreeVector e_perpend (0., 0., 1.);
171  if (modul2 > 0.) e_perpend = (1./std::sqrt(modul2))*product;
172  G4ThreeVector e_paralle = e_perpend.cross(kphoton);
173 
174  G4ThreeVector polar = std::cos(angle)*e_paralle + std::sin(angle)*e_perpend;
175  DP->SetPolarization(polar.x(),polar.y(),polar.z());
176  }
177  else
178  {
179  DP->SetPolarization(primaryParticle->GetPolX(),
180  primaryParticle->GetPolY(),
181  primaryParticle->GetPolZ());
182  }
183  if(primaryParticle->GetProperTime()>0.0)
184  { DP->SetPreAssignedDecayProperTime(primaryParticle->GetProperTime()); }
185 
186  // Set Mass if it is specified
187  G4double pmas = primaryParticle->GetMass();
188  if(pmas>=0.)
189  { DP->SetMass(pmas); }
190 
191  // Set Charge if it is specified
192  if (primaryParticle->GetCharge()<DBL_MAX) {
193  if (partDef->GetAtomicNumber() <0) {
194  DP->SetCharge(primaryParticle->GetCharge());
195  } else {
196  // ions
197  G4int iz = partDef->GetAtomicNumber();
198  G4int iq = static_cast<int>(primaryParticle->GetCharge()/eplus);
199  G4int n_e = iz - iq;
200  if (n_e>0) DP->AddElectron(0,n_e);
201  }
202  }
203  // Set decay products to the DynamicParticle
204  SetDecayProducts( primaryParticle, DP );
205  // Set primary particle
206  DP->SetPrimaryParticle(primaryParticle);
207  // Set PDG code if it is different from G4ParticleDefinition
208  if(partDef->GetPDGEncoding()==0 && primaryParticle->GetPDGcode()!=0)
209  {
210  DP->SetPDGcode(primaryParticle->GetPDGcode());
211  }
212  // Check the particle is properly constructed
213  if(!CheckDynamicParticle(DP))
214  {
215  delete DP;
216  return;
217  }
218  // Create G4Track object
219  G4Track* track = new G4Track(DP,t0,G4ThreeVector(x0,y0,z0));
220  // Set trackID and let primary particle know it
221  trackID++;
222  track->SetTrackID(trackID);
223  primaryParticle->SetTrackID(trackID);
224  // Set parentID to 0 as a primary particle
225  track->SetParentID(0);
226  // Set weight ( vertex weight * particle weight )
227  track->SetWeight(wv*(primaryParticle->GetWeight()));
228  // Store it to G4TrackVector
229  TV.push_back( track );
230 
231  }
232 }
G4double GetPolX() const
G4ThreeVector GetMomentum() const
void SetPreAssignedDecayProperTime(G4double)
CLHEP::Hep3Vector G4ThreeVector
double x() const
G4double GetKineticEnergy() const
G4ThreeVector GetPolarization() const
G4double GetPolZ() const
G4bool CheckDynamicParticle(G4DynamicParticle *DP)
G4double GetPolY() const
int G4int
Definition: G4Types.hh:78
const G4ThreeVector & GetMomentumDirection() const
G4ParticleDefinition * opticalphoton
const G4String & GetParticleName() const
double z() const
G4int GetAtomicNumber() const
void SetWeight(G4double aValue)
#define G4UniformRand()
Definition: Randomize.hh:87
G4GLOB_DLL std::ostream G4cout
G4double GetMass() const
const G4ThreeVector & GetMomentumDirection() const
G4double iz
Definition: TRTMaterials.hh:39
G4PrimaryParticle * GetDaughter() const
void SetTrackID(G4int id)
void SetPrimaryParticle(G4PrimaryParticle *p)
void SetPolarization(G4double polX, G4double polY, G4double polZ)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
Definition: G4Exception.cc:41
G4double GetProperTime() const
virtual G4bool IsGoodForTrack(G4ParticleDefinition *pd)
G4int GetPDGcode() const
G4double GetWeight() const
void AddElectron(G4int orbit, G4int number=1)
G4PrimaryParticle * GetNext() const
void GenerateSingleTrack(G4PrimaryParticle *primaryParticle, G4double x0, G4double y0, G4double z0, G4double t0, G4double wv)
void SetParentID(const G4int aValue)
double y() const
G4double GetCharge() const
double mag2() const
#define G4endl
Definition: G4ios.hh:61
virtual G4ParticleDefinition * GetDefinition(G4PrimaryParticle *pp)
Hep3Vector cross(const Hep3Vector &) const
void SetPDGcode(G4int c)
double G4double
Definition: G4Types.hh:76
void SetCharge(G4double charge)
#define DBL_MAX
Definition: templates.hh:83
void SetMass(G4double mass)
void SetTrackID(const G4int aValue)
G4GLOB_DLL std::ostream G4cerr
void SetDecayProducts(G4PrimaryParticle *mother, G4DynamicParticle *motherDP)
void G4PrimaryTransformer::GenerateTracks ( G4PrimaryVertex primaryVertex)
protected

Definition at line 87 of file G4PrimaryTransformer.cc.

References G4cout, G4endl, GenerateSingleTrack(), G4PrimaryParticle::GetNext(), G4PrimaryVertex::GetPrimary(), G4PrimaryVertex::GetT0(), G4PrimaryVertex::GetWeight(), G4PrimaryVertex::GetX0(), G4PrimaryVertex::GetY0(), G4PrimaryVertex::GetZ0(), python.hepunit::mm, python.hepunit::nanosecond, G4PrimaryVertex::Print(), and verboseLevel.

Referenced by GimmePrimaries().

88 {
89  G4double X0 = primaryVertex->GetX0();
90  G4double Y0 = primaryVertex->GetY0();
91  G4double Z0 = primaryVertex->GetZ0();
92  G4double T0 = primaryVertex->GetT0();
93  G4double WV = primaryVertex->GetWeight();
94 
95 #ifdef G4VERBOSE
96  if(verboseLevel>2) {
97  primaryVertex->Print();
98  } else if (verboseLevel==1) {
99  G4cout << "G4PrimaryTransformer::PrimaryVertex ("
100  << X0 / mm << "(mm),"
101  << Y0 / mm << "(mm),"
102  << Z0 / mm << "(mm),"
103  << T0 / nanosecond << "(nsec))" << G4endl;
104  }
105 #endif
106 
107  G4PrimaryParticle* primaryParticle = primaryVertex->GetPrimary();
108  while( primaryParticle != 0 )
109  {
110  GenerateSingleTrack( primaryParticle, X0, Y0, Z0, T0, WV );
111  primaryParticle = primaryParticle->GetNext();
112  }
113 }
G4double GetX0() const
void Print() const
G4double GetT0() const
G4double GetWeight() const
G4PrimaryParticle * GetPrimary(G4int i=0) const
G4GLOB_DLL std::ostream G4cout
G4double GetZ0() const
int nanosecond
Definition: hepunit.py:82
G4PrimaryParticle * GetNext() const
void GenerateSingleTrack(G4PrimaryParticle *primaryParticle, G4double x0, G4double y0, G4double z0, G4double t0, G4double wv)
G4double GetY0() const
#define G4endl
Definition: G4ios.hh:61
double G4double
Definition: G4Types.hh:76
G4ParticleDefinition * G4PrimaryTransformer::GetDefinition ( G4PrimaryParticle pp)
protectedvirtual

Definition at line 318 of file G4PrimaryTransformer.cc.

References G4ParticleTable::FindParticle(), G4PrimaryParticle::GetG4code(), G4PrimaryParticle::GetPDGcode(), G4ParticleDefinition::IsShortLived(), particleTable, unknown, and unknownParticleDefined.

319 {
320  G4ParticleDefinition* partDef = pp->GetG4code();
321  if(!partDef) partDef = particleTable->FindParticle(pp->GetPDGcode());
322  if(unknownParticleDefined && ((!partDef)||partDef->IsShortLived())) partDef = unknown;
323  return partDef;
324 }
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
G4ParticleDefinition * GetG4code() const
G4int GetPDGcode() const
G4ParticleTable * particleTable
G4ParticleDefinition * unknown
G4bool G4PrimaryTransformer::GetUnknownParticleDefined ( ) const
inline

Definition at line 78 of file G4PrimaryTransformer.hh.

References unknownParticleDefined.

G4TrackVector * G4PrimaryTransformer::GimmePrimaries ( G4Event anEvent,
G4int  trackIDCounter = 0 
)

Definition at line 70 of file G4PrimaryTransformer.cc.

References GenerateTracks(), G4PrimaryVertex::GetNext(), G4Event::GetPrimaryVertex(), trackID, and TV.

71 {
72  trackID = trackIDCounter;
73 
74  //TV.clearAndDestroy();
75  for( size_t ii=0; ii<TV.size();ii++)
76  { delete TV[ii]; }
77  TV.clear();
78  G4PrimaryVertex* nextVertex = anEvent->GetPrimaryVertex();
79  while(nextVertex)
80  {
81  GenerateTracks(nextVertex);
82  nextVertex = nextVertex->GetNext();
83  }
84  return &TV;
85 }
G4PrimaryVertex * GetPrimaryVertex(G4int i=0) const
Definition: G4Event.hh:156
G4PrimaryVertex * GetNext() const
void GenerateTracks(G4PrimaryVertex *primaryVertex)
G4bool G4PrimaryTransformer::IsGoodForTrack ( G4ParticleDefinition pd)
protectedvirtual

Definition at line 326 of file G4PrimaryTransformer.cc.

References G4ParticleDefinition::GetDecayTable(), and G4ParticleDefinition::IsShortLived().

Referenced by CheckDynamicParticle().

327 {
328  if(!pd)
329  { return false; }
330  else if(!(pd->IsShortLived()))
331  { return true; }
332 // Following two lines should be removed if the user does not want to make shortlived
333 // primary particle with proper decay table to be converted into a track.
334  else if(pd->GetDecayTable())
335  { return true; }
336  return false;
337 }
G4DecayTable * GetDecayTable() const
void G4PrimaryTransformer::SetDecayProducts ( G4PrimaryParticle mother,
G4DynamicParticle motherDP 
)
protected

Definition at line 235 of file G4PrimaryTransformer.cc.

References DBL_MAX, G4cout, G4endl, G4PrimaryParticle::GetCharge(), G4PrimaryParticle::GetDaughter(), G4PrimaryParticle::GetMass(), G4PrimaryParticle::GetMomentum(), G4PrimaryParticle::GetNext(), G4ParticleDefinition::GetParticleName(), G4PrimaryParticle::GetPDGcode(), G4DynamicParticle::GetPreAssignedDecayProducts(), G4PrimaryParticle::GetProperTime(), G4DecayProducts::PushProducts(), G4DynamicParticle::SetCharge(), G4DynamicParticle::SetMass(), G4DynamicParticle::SetPreAssignedDecayProducts(), G4DynamicParticle::SetPreAssignedDecayProperTime(), and G4DynamicParticle::SetPrimaryParticle().

236 {
237  G4PrimaryParticle* daughter = mother->GetDaughter();
238  if(!daughter) return;
239  G4DecayProducts* decayProducts = (G4DecayProducts*)(motherDP->GetPreAssignedDecayProducts() );
240  if(!decayProducts)
241  {
242  decayProducts = new G4DecayProducts(*motherDP);
243  motherDP->SetPreAssignedDecayProducts(decayProducts);
244  }
245  while(daughter)
246  {
247  G4ParticleDefinition* partDef = GetDefinition(daughter);
248  if(!IsGoodForTrack(partDef))
249  {
250 #ifdef G4VERBOSE
251  if(verboseLevel>2)
252  {
253  G4cout << " >> Decay product (PDGcode " << daughter->GetPDGcode()
254  << ") --- Ignored" << G4endl;
255  }
256 #endif
257  SetDecayProducts(daughter,motherDP);
258  }
259  else
260  {
261 #ifdef G4VERBOSE
262  if(verboseLevel>1)
263  {
264  G4cout << " >> Decay product (" << partDef->GetParticleName()
265  << ") --- Attached with momentum " << daughter->GetMomentum()
266  << G4endl;
267  }
268 #endif
270  = new G4DynamicParticle(partDef,daughter->GetMomentum());
271  DP->SetPrimaryParticle(daughter);
272  // Decay proper time for daughter
273  if(daughter->GetProperTime()>0.0)
274  { DP->SetPreAssignedDecayProperTime(daughter->GetProperTime()); }
275  // Set Charge is specified
276  if (daughter->GetCharge()<DBL_MAX) {
277  DP->SetCharge(daughter->GetCharge());
278  }
279  G4double pmas = daughter->GetMass();
280  if(pmas>=0.)
281  { DP->SetMass(pmas); }
282  decayProducts->PushProducts(DP);
283  SetDecayProducts(daughter,DP);
284  // Check the particle is properly constructed
285  if(!CheckDynamicParticle(DP))
286  {
287  delete DP;
288  return;
289  }
290  }
291  daughter = daughter->GetNext();
292  }
293 }
G4ThreeVector GetMomentum() const
void SetPreAssignedDecayProperTime(G4double)
G4int PushProducts(G4DynamicParticle *aParticle)
const G4DecayProducts * GetPreAssignedDecayProducts() const
G4bool CheckDynamicParticle(G4DynamicParticle *DP)
const G4String & GetParticleName() const
G4GLOB_DLL std::ostream G4cout
G4double GetMass() const
G4PrimaryParticle * GetDaughter() const
void SetPrimaryParticle(G4PrimaryParticle *p)
G4double GetProperTime() const
virtual G4bool IsGoodForTrack(G4ParticleDefinition *pd)
G4int GetPDGcode() const
G4PrimaryParticle * GetNext() const
G4double GetCharge() const
#define G4endl
Definition: G4ios.hh:61
virtual G4ParticleDefinition * GetDefinition(G4PrimaryParticle *pp)
double G4double
Definition: G4Types.hh:76
void SetPreAssignedDecayProducts(G4DecayProducts *aDecayProducts)
void SetCharge(G4double charge)
#define DBL_MAX
Definition: templates.hh:83
void SetMass(G4double mass)
void SetDecayProducts(G4PrimaryParticle *mother, G4DynamicParticle *motherDP)
void G4PrimaryTransformer::SetUnknnownParticleDefined ( G4bool  vl)

Definition at line 295 of file G4PrimaryTransformer.cc.

References G4cerr, G4endl, unknown, and unknownParticleDefined.

296 {
299  { G4cerr << "unknownParticleDefined cannot be set true because G4UnknownParticle is not defined in the physics list."
300  << G4endl << "Command ignored." << G4endl;
301  unknownParticleDefined = false;
302  }
303 }
G4ParticleDefinition * unknown
#define G4endl
Definition: G4ios.hh:61
G4GLOB_DLL std::ostream G4cerr
void G4PrimaryTransformer::SetVerboseLevel ( G4int  vl)
inline

Definition at line 70 of file G4PrimaryTransformer.hh.

References verboseLevel.

Referenced by G4EventManager::SetVerboseLevel().

71  { verboseLevel = vl; };

Field Documentation

G4int G4PrimaryTransformer::nWarn
protected

Definition at line 67 of file G4PrimaryTransformer.hh.

G4ParticleDefinition* G4PrimaryTransformer::opticalphoton
protected

Definition at line 64 of file G4PrimaryTransformer.hh.

Referenced by CheckUnknown().

G4bool G4PrimaryTransformer::opticalphotonDefined
protected

Definition at line 65 of file G4PrimaryTransformer.hh.

Referenced by CheckUnknown().

G4ParticleTable* G4PrimaryTransformer::particleTable
protected

Definition at line 58 of file G4PrimaryTransformer.hh.

Referenced by CheckUnknown(), G4PrimaryTransformer(), and GetDefinition().

G4int G4PrimaryTransformer::trackID
protected

Definition at line 60 of file G4PrimaryTransformer.hh.

Referenced by GimmePrimaries().

G4TrackVector G4PrimaryTransformer::TV
protected

Definition at line 57 of file G4PrimaryTransformer.hh.

Referenced by GimmePrimaries().

G4ParticleDefinition* G4PrimaryTransformer::unknown
protected

Definition at line 62 of file G4PrimaryTransformer.hh.

Referenced by CheckUnknown(), GetDefinition(), and SetUnknnownParticleDefined().

G4bool G4PrimaryTransformer::unknownParticleDefined
protected
G4int G4PrimaryTransformer::verboseLevel
protected

Definition at line 59 of file G4PrimaryTransformer.hh.

Referenced by GenerateTracks(), and SetVerboseLevel().


The documentation for this class was generated from the following files: