304 virtual void
metric(SmartPointer<Metric::Generic>) ;
326 virtual double
rMax(std::string const &unit);
327 virtual double
rMax(std::string const &unit) const;
351 virtual void
rMax(double val, std::string const &unit);
368 void showshadow(bool flag);
369 bool showshadow() const ;
371 void redshift(bool flag);
372 bool redshift() const ;
386#ifdef GYOTO_USE_XERCES
450 virtual int
Impact(Gyoto::Photon* ph, size_t index,
451 Astrobj::Properties *data=NULL) = 0 ;
467 double const * coord_obj_hit, double dt,
468 Astrobj::Properties* data) const;
470 double* coord_obj_hit, double dt,
471 Astrobj::Properties* data) const = delete ;
522 virtual double
emission(double nu_em, double dsem, state_t const &coord_ph,
523 double const coord_obj[8]=NULL)
525 virtual double
emission(double nu_em, double dsem, double coord_ph[8],
526 double coord_obj[8]=NULL)
551 virtual void
emission(double Inu[], double const nu_em[], size_t nbnu,
552 double dsem, state_t const &coord_ph,
553 double const coord_obj[8]=NULL) const ;
554 virtual void
emission(double Inu[], double nu_em[], size_t nbnu,
555 double dsem, double coord_ph[8],
556 double coord_obj[8]=NULL) const = delete ;
562 double const nu_em[], size_t nbnu,
563 double dsem, state_t const &coord_ph,
564 double const coord_obj[8]=NULL) const ;
565 virtual void
radiativeQ(double Inu[], double Taunu[],
566 double nu_em[], size_t nbnu,
567 double dsem, double coord_ph[8],
568 double coord_obj[8]=NULL) const = delete ;
602 virtual void
radiativeQ(double *Inu, double *Qnu, double *Unu, double *Vnu,
603 Eigen::Matrix4d *Onu, double const *nuem , size_t nbnu, double dsem,
604 state_t const &cph, double const *co) const ;
618 state_t const &c_ph, double const c_obj[8]=NULL) const;
621 double c_ph[8], double c_obj[8]=NULL) const=delete;
629 size_t const * chaninds, size_t nbnu,
630 double dsem, state_t const &cph, double const *co) const;
633 size_t const * chaninds, size_t nbnu,
634 double dsem, double *cph, double *co) const = delete;
646 virtual double
transmission(double nuem, double dsem, state_t const &coord_ph, double const coord_obj[8]) const ;
648 virtual double
transmission(double nuem, double dsem, state_t const &coord) const = delete;
649 virtual double
transmission(double nuem, double dsem, double coord[8]) const = delete;
663 Eigen::Matrix4d
Omatrix(double alphanu[4], double rnu[3], double Chi, double dsem) const;
664 Eigen::Matrix4d
Omatrix(double alphaInu, double alphaQnu, double alphaUnu, double alphaVnu,
665 double rQnu, double rUnu, double rVnu, double Chi, double dsem) const;
666 Eigen::Matrix4d
Omatrix(double alphanu[4], double rnu[3], double sin2Chi, double cos2Chi, double dsem) const;
667 Eigen::Matrix4d
Omatrix(double alphaInu, double alphaQnu, double alphaUnu, double alphaVnu,
668 double rQnu, double rUnu, double rVnu, double sin2Chi, double cos2Chi, double dsem) const;
670 Eigen::Matrix4d Pmatrix(double alphaInu, double alphaQnu, double alphaUnu, double alphaVnu,
671 double rQnu, double rUnu, double rVnu, double sin2Chi, double cos2Chi, double dsem) const;
677 Eigen::Vector4d
rotateJs(double jInu, double jQnu, double jUnu, double jVnu, double sin2Chi, double cos2Chi) const;
678 Eigen::Vector4d
rotateJs(double jInu, double jQnu, double jUnu, double jVnu, double Chi) const;
689 double
getChi(double const fourvect[4], state_t const &cph, double const vel[4], bool elec=false) const;
699 void
getSinCos2Chi(double const fourvect[4], state_t const &cph, double const vel[4], double* sin2Chi, double* cos2Chi, bool elec=false) const;
708 void
computeB4vect(double B4vect[4], std::string const magneticConfig, double const co[8], state_t const &cph) const;
710 void computeB4vect_ipole(double B4vect[4], std::string const magneticConfig, double const co[8], state_t const &cph, double spin) const;
721 double
interpolate(int const N, double* const array, double* const Xq, double** const X, int* const X_params, std::string const *cond_limits) const;
731 double
interpolate(int const N, double* const array, double* const Xq, double** const X_params, std::string const *cond_limits) const;
741 double
interp1d(double const x, double const y0, double const y1) const;
751 double
interpNd(int const N, double* const Xq, double** const X, double* const Y, std::string const *cond_limit) const;
760 int
getIndice(double &xq, std::string const cond_limit, double const X_params[3], double* const X=NULL) const;