Gyoto
GyotoComplexAstrobj.h
Go to the documentation of this file.
1 
8 /*
9  Copyright 2011 Thibaut Paumard, Frederic Vincent
10 
11  This file is part of Gyoto.
12 
13  Gyoto is free software: you can redistribute it and/or modify
14  it under the terms of the GNU General Public License as published by
15  the Free Software Foundation, either version 3 of the License, or
16  (at your option) any later version.
17 
18  Gyoto is distributed in the hope that it will be useful,
19  but WITHOUT ANY WARRANTY; without even the implied warranty of
20  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21  GNU General Public License for more details.
22 
23  You should have received a copy of the GNU General Public License
24  along with Gyoto. If not, see <http://www.gnu.org/licenses/>.
25  */
26 
27 
28 #ifndef __GyotoComplexAstrobj_H_
29 #define __GyotoComplexAstrobj_H_
30 
31 #include <GyotoAstrobj.h>
32 
33 namespace Gyoto{
34  namespace Astrobj {
35  class Complex;
36  }
37 }
38 
74  friend class Gyoto::SmartPointer<Gyoto::Astrobj::Complex>;
75 
76  // Data :
77  // -----
78  protected:
79 
84 
88  Gyoto::SmartPointer<Gyoto::Astrobj::Generic> * elements_;
89 
93  double step_max_;
94 
95  public:
96  Complex();
97  Complex(const Complex& ) ;
98  virtual Complex* clone() const;
99 
100  virtual double deltaMax(double coord[8]);
101 
105  virtual ~Complex() ;
106 
107  // Mutators
108  // --------
109  public:
118  void append(Gyoto::SmartPointer<Gyoto::Astrobj::Generic> element);
120  void remove(size_t i);
122  size_t getCardinal() const;
124  using Generic::metric;
125  void metric(SmartPointer<Metric::Generic> gg);
127 
128  public:
129 #ifdef GYOTO_USE_XERCES
130  virtual void fillElement(FactoryMessenger *fmp) const ;
131  virtual void setParameters(FactoryMessenger *fmp);
132 #endif
133 
134  // Outputs
135  // -------
136  public:
137 
154  virtual int Impact(Gyoto::Photon* ph, size_t index,
155  Astrobj::Properties *data=NULL) ;
157 
158 
169  Gyoto::SmartPointer<Gyoto::Astrobj::Generic>& operator[](size_t i) ;
171  Gyoto::SmartPointer<Gyoto::Astrobj::Generic> const&operator[](size_t i) const;
173 
174 };
175 
176 #endif
void append(Gyoto::SmartPointer< Gyoto::Astrobj::Generic > element)
Add element at the end of the array.
virtual double deltaMax(double coord[8])
Get max step constraint for adaptive integration.
virtual Complex * clone() const
"Virtual" copy constructor
Astronomical objects (light emitters)
void remove(size_t i)
Remove i-th element from the array.
#define size_t
If not defined in .
Definition: GyotoConfig.h:357
virtual void setParameters(FactoryMessenger *fmp)
Main loop in Subcontractor_t function.
size_t getCardinal() const
Get the number of elements in the array.
Namespace for the Gyoto library.
Definition: GyotoAstrobj.h:43
Pointers performing reference counting.
Definition: GyotoProperty.h:41
double step_max_
Maximum δ step inside the Astrobj.
Definition: GyotoComplexAstrobj.h:93
size_t cardinal_
Number of objects.
Definition: GyotoComplexAstrobj.h:83
Base class for astronomical object.
Definition: GyotoAstrobj.h:188
virtual SmartPointer< Metric::Generic > metric() const
Get the Metric gg_.
Complex astronomical object.
Definition: GyotoComplexAstrobj.h:73
Gyoto::SmartPointer< Gyoto::Astrobj::Generic > * elements_
Array of Astrobj::Generic.
Definition: GyotoComplexAstrobj.h:88
virtual int Impact(Gyoto::Photon *ph, size_t index, Astrobj::Properties *data=NULL)
Call Impact() for each of the elements.