Loading...
Searching...
No Matches
DicomBeam.hh
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. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26#ifndef DicomBeam__HH
27#define DicomBeam__HH
28
29#include "dcmtk/dcmdata/dcfilefo.h"
30#include "G4ThreeVector.hh"
31
32#include <vector>
33#include <iostream>
37class DicomBeamBlock;
38class DicomBeamWedge;
39
40class DicomBeam
41{
42public:
43 DicomBeam();
45
46public:
47 void SetDoseSpecificationPoint(G4ThreeVector point ){
49 }
50 void SetMeterset(Float64 dat){
51 theMeterset = dat;
52 }
53 void SetSourceAxisDistance(Float64 dat) {
55 }
56 void SetNumber(Sint32 dat){
57 theNumber = dat;
58 }
59 void SetRadiationType(OFString dat){
60 theRadiationType = dat;
61 }
63 theDevices.push_back(db);
64 }
66 theControlPoints.push_back(db);
67 }
69 theCompensators.push_back(db);
70 }
72 theBlocks.push_back(db);
73 }
75 theWedges.push_back(db);
76 }
77 size_t GetNControlPoints() const {
78 return theControlPoints.size();
79 }
81 return theControlPoints[ii];
82 }
83
85
86 void Print( std::ostream& out );
87
88 void DumpToFile();
89
90private:
92 Float64 theMeterset;
94 Sint32 theNumber;
96 std::vector<DicomVBeamDevice*> theDevices;
97 std::vector<DicomBeamControlPoint*> theControlPoints;
98 std::vector<DicomBeamCompensator*> theCompensators;
99 std::vector<DicomBeamBlock*> theBlocks;
100 std::vector<DicomBeamWedge*> theWedges;
101
102};
103
104#endif
void AddBlock(DicomBeamBlock *db)
Definition DicomBeam.hh:71
std::vector< DicomBeamCompensator * > theCompensators
Definition DicomBeam.hh:98
void SetRadiationType(OFString dat)
Definition DicomBeam.hh:59
void SetControlPointMetersets()
Definition DicomBeam.cc:44
void SetDoseSpecificationPoint(G4ThreeVector point)
Definition DicomBeam.hh:47
Float64 theSourceAxisDistance
Definition DicomBeam.hh:93
void AddWedge(DicomBeamWedge *db)
Definition DicomBeam.hh:74
std::vector< DicomBeamBlock * > theBlocks
Definition DicomBeam.hh:99
Sint32 theNumber
Definition DicomBeam.hh:94
Float64 theMeterset
Definition DicomBeam.hh:92
void Print(std::ostream &out)
Definition DicomBeam.cc:38
void AddControlPoint(DicomBeamControlPoint *db)
Definition DicomBeam.hh:65
size_t GetNControlPoints() const
Definition DicomBeam.hh:77
void AddDevice(DicomVBeamDevice *db)
Definition DicomBeam.hh:62
std::vector< DicomBeamWedge * > theWedges
Definition DicomBeam.hh:100
void DumpToFile()
Definition DicomBeam.cc:55
DicomBeamControlPoint * GetControlPoint(size_t ii)
Definition DicomBeam.hh:80
void SetNumber(Sint32 dat)
Definition DicomBeam.hh:56
std::vector< DicomVBeamDevice * > theDevices
Definition DicomBeam.hh:96
void SetSourceAxisDistance(Float64 dat)
Definition DicomBeam.hh:53
void AddCompensator(DicomBeamCompensator *db)
Definition DicomBeam.hh:68
void SetMeterset(Float64 dat)
Definition DicomBeam.hh:50
G4ThreeVector theDoseSpecificationPoint
Definition DicomBeam.hh:91
OFString theRadiationType
Definition DicomBeam.hh:95
std::vector< DicomBeamControlPoint * > theControlPoints
Definition DicomBeam.hh:97

Applications | User Support | Publications | Collaboration