28 #ifndef __GyotoAstrobj_H_ 29 #define __GyotoAstrobj_H_ 38 #include <Eigen/Dense> 39 #include <unsupported/Eigen/MatrixFunctions> 81 ao -> plugins(plugin) ;
82 #ifdef GYOTO_USE_XERCES 83 if (fmp) ao -> setParameters(fmp);
112 std::vector<std::string> &plugin,
256 std::string magneticConfig_;
313 virtual void
metric(SmartPointer<Metric::Generic>) ;
326 virtual double
rMax();
327 virtual double
rMax() const;
335 virtual double
rMax(std::string const &unit);
336 virtual double
rMax(std::string const &unit) const;
343 virtual double
deltaMax(double coord[8]);
351 virtual void
rMax(double val);
360 virtual void
rMax(double val, std::string const &unit);
377 void showshadow(bool flag);
378 bool showshadow() const ;
380 void redshift(bool flag);
381 bool redshift() const ;
395 #ifdef GYOTO_USE_XERCES 459 virtual int
Impact(Gyoto::Photon* ph, size_t index,
460 Astrobj::Properties *data=NULL) = 0 ;
476 double const * coord_obj_hit, double dt,
477 Astrobj::Properties* data) const;
479 double* coord_obj_hit, double dt,
480 Astrobj::Properties* data) const = delete ;
531 virtual double
emission(double nu_em, double dsem, state_t const &coord_ph,
532 double const coord_obj[8]=NULL)
534 virtual double
emission(double nu_em, double dsem, double coord_ph[8],
535 double coord_obj[8]=NULL)
560 virtual void
emission(double Inu[], double const nu_em[], size_t nbnu,
561 double dsem, state_t const &coord_ph,
562 double const coord_obj[8]=NULL) const ;
563 virtual void
emission(double Inu[], double nu_em[], size_t nbnu,
564 double dsem, double coord_ph[8],
565 double coord_obj[8]=NULL) const = delete ;
570 virtual void
radiativeQ(double Inu[], double Taunu[],
571 double const nu_em[], size_t nbnu,
572 double dsem, state_t const &coord_ph,
573 double const coord_obj[8]=NULL) const ;
574 virtual void
radiativeQ(double Inu[], double Taunu[],
575 double nu_em[], size_t nbnu,
576 double dsem, double coord_ph[8],
577 double coord_obj[8]=NULL) const = delete ;
611 virtual void
radiativeQ(double *Inu, double *Qnu, double *Unu, double *Vnu,
612 Eigen::Matrix4d *Onu, double const *nuem , size_t nbnu, double dsem,
613 state_t const &cph, double const *co) const ;
627 state_t const &c_ph, double const c_obj[8]=NULL) const;
630 double c_ph[8], double c_obj[8]=NULL) const=delete;
638 size_t const * chaninds, size_t nbnu,
639 double dsem, state_t const &cph, double const *co) const;
642 size_t const * chaninds, size_t nbnu,
643 double dsem, double *cph, double *co) const = delete;
655 virtual double
transmission(double nuem, double dsem, state_t const &coord_ph, double const coord_obj[8]) const ;
657 virtual double
transmission(double nuem, double dsem, state_t const &coord) const = delete;
658 virtual double
transmission(double nuem, double dsem, double coord[8]) const = delete;
672 Eigen::Matrix4d
Omatrix(double alphanu[4], double rnu[3], double Chi, double dsem) const;
673 Eigen::Matrix4d
Omatrix(double alphaInu, double alphaQnu, double alphaUnu, double alphaVnu,
674 double rQnu, double rUnu, double rVnu, double Chi, double dsem) const;
675 Eigen::Matrix4d
Omatrix(double alphanu[4], double rnu[3], double sin2Chi, double cos2Chi, double dsem) const;
676 Eigen::Matrix4d
Omatrix(double alphaInu, double alphaQnu, double alphaUnu, double alphaVnu,
677 double rQnu, double rUnu, double rVnu, double sin2Chi, double cos2Chi, double dsem) const;
679 Eigen::Matrix4d Pmatrix(double alphaInu, double alphaQnu, double alphaUnu, double alphaVnu,
680 double rQnu, double rUnu, double rVnu, double sin2Chi, double cos2Chi, double dsem) const;
686 Eigen::Vector4d
rotateJs(double jInu, double jQnu, double jUnu, double jVnu, double sin2Chi, double cos2Chi) const;
687 Eigen::Vector4d
rotateJs(double jInu, double jQnu, double jUnu, double jVnu, double Chi) const;
698 double
getChi(double const fourvect[4], state_t const &cph, double const vel[4], bool elec=false) const;
707 double
get_theta_mag(double const fourvect[4], state_t const &coord_ph, double const vel[4]) const;
717 void
getSinCos2Chi(double const fourvect[4], state_t const &cph, double const vel[4], double* sin2Chi, double* cos2Chi, bool elec=false) const;
727 void
computeB4vect(double B4vect[4], std::string const magneticConfig, double const co[8], state_t const &cph, double const par=0.75) const;
729 void computeB4vect_ipole(double B4vect[4], std::string const magneticConfig, double const co[8], state_t const &cph, double spin) const;
740 double
interpolate(int const N, double* const array, double* const Xq, double** const X, int* const X_params, std::string const *cond_limits) const;
750 double
interpolate(int const N, double* const array, double* const Xq, double** const X_params, std::string const *cond_limits) const;
772 double
interp1d(double const x, double const y0, double const y1) const;
782 double
interpNd(int const N, double* const Xq, double** const X, double* const Y, std::string const *cond_limit) const;
791 int
getIndice(double &xq, std::string const cond_limit, double const X_params[3], double* const X=NULL) const;
846 int first_dmin_found;
857 double *nbcrosseqplane;
884 double * impactcoords;
948 void
init(size_t nbnuobs=0);
969 void intensityConverter(Gyoto::SmartPointer<Gyoto::Units::Converter>);
971 void intensityConverter(std::string);
973 void spectrumConverter(Gyoto::SmartPointer<Gyoto::Units::Converter>);
975 void spectrumConverter(std::string);
977 void binSpectrumConverter(Gyoto::SmartPointer<Gyoto::Units::Converter>);
979 void binSpectrumConverter(std::string);
int noredshift_
1 to impose redshift factor g = 1
Definition: GyotoAstrobj.h:254
std::string magneticConfiguration() const
#define GYOTO_OBJECT
Declare class::properties and class::getProperties()
Definition: GyotoObject.h:84
virtual Gyoto::Quantity_t getDefaultQuantities()
Which quantities to compute if know was requested.
void getSinCos2Chi(double const fourvect[4], state_t const &cph, double const vel[4], double *sin2Chi, double *cos2Chi, bool elec=false) const
virtual void radiativeQ(double Inu[], double Taunu[], double const nu_em[], size_t nbnu, double dsem, state_t const &coord_ph, double const coord_obj[8]=NULL) const
emission and transmission together
virtual double deltaMax(double coord[8])
Get max step constraint for adaptive integration.
void computeB4vect(double B4vect[4], std::string const magneticConfig, double const co[8], state_t const &cph, double const par=0.75) const
virtual double transmission(double nuem, double dsem, state_t const &coord_ph, double const coord_obj[8]) const
Transmission: exp( αν * dsem )
Eigen::Matrix4d Omatrix(double alphanu[4], double rnu[3], double Chi, double dsem) const
A null geodesic transporting light.
Definition: GyotoPhoton.h:54
Base class for metrics.
Definition: GyotoMetric.h:163
Reference-counting pointers.
double interp1d(double const x, double const y0, double const y1) const
void Register(std::string name, Gyoto::Astrobj::Subcontractor_t *scp)
Make an Astrobj kind known to the Factory.
virtual double integrateEmission(double nu1, double nu2, double dsem, state_t const &c_ph, double const c_obj[8]=NULL) const
∫ν1ν2 Iν dν (or jν)
SmartPointer< Gyoto::Metric::Generic > gg_
The Metric in this end of the Universe.
Definition: GyotoAstrobj.h:229
Factory / SmartPointee::Subcontractor_t interface.
Definition: GyotoFactoryMessenger.h:92
int getIndice(double &xq, std::string const cond_limit, double const X_params[3], double *const X=NULL) const
double interpolate(int const N, double *const array, double *const Xq, double **const X, int *const X_params, std::string const *cond_limits) const
void init(char const *pluglist=NULL)
Initialise the various registers.
virtual double rMax()
Get maximal distance from center of coordinate system.
double rmax_
Maximum distance to the center of the coordinate system [geometrical units].
Definition: GyotoAstrobj.h:241
Gyoto ubiquitous macros and typedefs.
Compile-time configuration.
Gyoto::Register::Entry * Register_
The Astrobj register.
int shadow_
1 to highlight the shadow region in the image
Definition: GyotoAstrobj.h:253
void initRegister()
Empty the Astrobj register Astrobj::Register_.
SmartPointer< Gyoto::Astrobj::Generic > Subcontractor_t(Gyoto::FactoryMessenger *, std::vector< std::string > const &)
A function to build instances of a specific Astrobj::Generic sub-class.
Definition: GyotoAstrobj.h:65
Namespace for the Gyoto library.
Definition: GyotoAstrobj.h:46
virtual void setParameters(FactoryMessenger *fmp)
Main loop in Subcontractor_t function.
unsigned int Quantity_t
Type for observabke quantities.
Definition: GyotoDefs.h:76
virtual void processHitQuantities(Photon *ph, state_t const &coord_ph_hit, double const *coord_obj_hit, double dt, Astrobj::Properties *data) const
Fills Astrobj::Properties.
double deltamaxinsidermax_
Maximum Photon integration step inside rmax_ [geometrical units].
Definition: GyotoAstrobj.h:249
Gyoto::Astrobj::Subcontractor_t * getSubcontractor(std::string name, std::vector< std::string > &plugin, int errmode=0)
Query the Astrobj register Astrobj::Register_.
double interpNd(int const N, double *const Xq, double **const X, double *const Y, std::string const *cond_limit) const
Can be pointed to by a SmartPointer.
Definition: GyotoSmartPointer.h:80
virtual int Impact(Gyoto::Photon *ph, size_t index, Astrobj::Properties *data=NULL)=0
Does a photon at these coordinates impact the object?
virtual SmartPointer< Metric::Generic > metric() const
Get the Metric gg_.
bool flag_radtransf_
1 if radiative transfer inside Astrobj, else 0
Definition: GyotoAstrobj.h:251
Eigen::Vector4d rotateJs(double jInu, double jQnu, double jUnu, double jVnu, double sin2Chi, double cos2Chi) const
virtual Generic * clone() const =0
Cloner.
Base class for astronomical object.
Definition: GyotoAstrobj.h:204
Object with properties.
Definition: GyotoObject.h:151
bool opticallyThin() const
Query whether object is optically thin.
int __defaultfeatures
Whether some virtual methods are implemented.
Definition: GyotoAstrobj.h:222
SmartPointer< Astrobj::Generic > Subcontractor(FactoryMessenger *fmp, std::vector< std::string > const &plugin)
A template for Subcontractor_t functions.
Definition: GyotoAstrobj.h:79
double getChi(double const fourvect[4], state_t const &cph, double const vel[4], bool elec=false) const
#define GYOTO_OBJECT_ACCESSORS_UNIT(method)
Declare a quadruplet of accessors to double member that supports unit.
Definition: GyotoObject.h:70
virtual double emission(double nu_em, double dsem, state_t const &coord_ph, double const coord_obj[8]=NULL) const
Specific intensity Iν
double get_theta_mag(double const fourvect[4], state_t const &coord_ph, double const vel[4]) const
Observable properties of an Astronomical object.
Definition: GyotoAstrobj.h:823
Entry in a register (or a full register)
Definition: GyotoRegister.h:132