ReFRACtor
|
This is a RadiativeTransfer that supplies an interface that can be called for a single wavenumber. More...
#include <radiative_transfer_single_wn.h>
Public Member Functions | |
virtual | ~RadiativeTransferSingleWn () |
virtual void | add_observer (Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > &Obs) |
Required observable functions. More... | |
void | add_observer_and_keep_reference (boost::shared_ptr< Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > > &Obs) |
Add an observer and keep a reference to it. More... | |
const boost::shared_ptr< RtAtmosphere > & | atmosphere () const |
boost::shared_ptr< RtAtmosphere > | atmosphere_ptr () const |
virtual int | number_spectrometer () const |
Number of spectrometer we have. More... | |
virtual int | number_stokes () const =0 |
Number of stokes parameters we will return in stokes and stokes_and_jacobian. More... | |
virtual int | number_stream () const =0 |
Number of streams to use in processing. More... | |
virtual void | print (std::ostream &Os, bool Short_form=false) const |
Print to stream. More... | |
std::string | print_to_string () const |
Print to string. More... | |
virtual Spectrum | reflectance (const SpectralDomain &Spec_domain, int Spec_index, bool Skip_jacobian=false) const |
Calculate reflectance for the given set of wavenumbers/wavelengths. More... | |
virtual void | remove_observer (Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > &Obs) |
Remove an observer. More... | |
virtual blitz::Array< double, 2 > | stokes (const SpectralDomain &Spec_domain, int Spec_index) const |
Calculate stokes vector for the given set of wavenumbers/wavelengths. More... | |
virtual ArrayAd< double, 2 > | stokes_and_jacobian (const SpectralDomain &Spec_domain, int Spec_index) const |
Calculate stokes vector for the given set of wavenumbers/wavelengths. More... | |
virtual ArrayAd< double, 1 > | stokes_and_jacobian_single_wn (double Wn, int Spec_index, const ArrayAd< double, 2 > &Iv=ArrayAd< double, 2 >()) const =0 |
Calculate stokes vector and Jacobian for the given wavenumber. More... | |
const boost::shared_ptr< StokesCoefficient > & | stokes_coefficient () const |
Stokes coefficients used to go from Stokes vector to scalar reflectance. More... | |
virtual blitz::Array< double, 1 > | stokes_single_wn (double Wn, int Spec_index, const ArrayAd< double, 2 > &Iv=ArrayAd< double, 2 >()) const =0 |
Calculate stokes vector for the given wavenumber. More... | |
Protected Member Functions | |
RadiativeTransferSingleWn (const boost::shared_ptr< StokesCoefficient > &Stokes_coef, const boost::shared_ptr< RtAtmosphere > &Atm) | |
Constructor. More... | |
RadiativeTransferSingleWn () | |
Default constructor. Derived classes should fill in atm and stokes_coef. More... | |
void | add_observer_do (Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > &Obs, std::vector< boost::shared_ptr< NamedSpectrum > > &t) |
Add an observer. More... | |
void | add_observer_do (Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > &Obs) |
void | clean_dead_ptr () |
Remove any dead pointers. More... | |
void | notify_update_do (const std::vector< boost::shared_ptr< NamedSpectrum > > &Self) |
Function to call to notify Observers of a state change. More... | |
boost::shared_ptr< boost::progress_display > | progress_display (const blitz::Array< double, 1 > &wn) const |
Helper routine, creates a progress meter. More... | |
void | remove_observer_do (Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > &Obs, std::vector< boost::shared_ptr< NamedSpectrum > > &t) |
Remove an observer. More... | |
void | remove_observer_do (Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > &Obs) |
Protected Attributes | |
boost::shared_ptr< RtAtmosphere > | atm |
std::list< boost::weak_ptr< Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > > > | olist |
std::vector< boost::shared_ptr< Observer< std::vector< boost::shared_ptr< NamedSpectrum > > > > > | ref_list |
boost::shared_ptr< StokesCoefficient > | stokes_coef |
Object to go from stokes vector to reflectance. More... | |
Static Protected Attributes | |
static AccumulatedTimer | timer |
This is a RadiativeTransfer that supplies an interface that can be called for a single wavenumber.
This class mixes in some of the common functionality needed by LRadRt and LidortDriver. We may want to pull some of this out into separate classes. But right now we only have a few examples of a RadiativeTransfer and it isn't at all clear what a useful hierarchy would be. Rather than try to predict what we might need in the future, we really just have two categories: "The LSI" and "LRad and LIDORT". This class is really the later, and I guess we could have called it StuffThatIsInCommonWithLRadAndLidort.
Definition at line 21 of file radiative_transfer_single_wn.h.
|
inlinevirtual |
Definition at line 25 of file radiative_transfer_single_wn.h.
|
inlineprotected |
Constructor.
Stokes_coef | The stokes coefficients to go from vector stokes parameters to reflectance. This should be number_spectrometer() x 4. |
Atm | The RtAtmosphere to use. |
Definition at line 88 of file radiative_transfer_single_wn.h.
|
inlineprotected |
Default constructor. Derived classes should fill in atm and stokes_coef.
Definition at line 96 of file radiative_transfer_single_wn.h.
|
inlinevirtualinherited |
Required observable functions.
Implements FullPhysics::Observable< std::vector< boost::shared_ptr< NamedSpectrum > > >.
Definition at line 42 of file radiative_transfer_fixed_stokes_coefficient.h.
|
inlineinherited |
Add an observer and keep a reference to it.
See the discussion in the Observer class description for details.
Definition at line 107 of file observer.h.
|
inlineprotectedinherited |
Add an observer.
Definition at line 148 of file observer.h.
|
inlineprotectedinherited |
Definition at line 159 of file observer.h.
|
inline |
Definition at line 77 of file radiative_transfer_single_wn.h.
|
inline |
Definition at line 26 of file radiative_transfer_single_wn.h.
|
inlineprotectedinherited |
Remove any dead pointers.
Definition at line 196 of file observer.h.
|
inlineprotectedinherited |
Function to call to notify Observers of a state change.
The object should pass itself to this function, so it can be passed to the Observers.
Definition at line 121 of file observer.h.
|
inlinevirtualinherited |
Number of spectrometer we have.
Implements FullPhysics::RadiativeTransfer.
Definition at line 31 of file radiative_transfer_fixed_stokes_coefficient.h.
|
pure virtualinherited |
Number of stokes parameters we will return in stokes and stokes_and_jacobian.
Implemented in FullPhysics::LRadRt, FullPhysics::SpurrRt, FullPhysics::ChapmanBoaRT, FullPhysics::LsiRt, and FullPhysics::HresWrapper.
|
pure virtual |
Number of streams to use in processing.
Note that Lidort 3.0 used a less common "full streams" that was twice the more commonly used "half streams". This function returns the later. This is the same as what is used in Lidort 3.5 and LRad. The "full streams" used in Lidort 3.0 would be twice this.
Implemented in FullPhysics::LRadRt, FullPhysics::SpurrRt, FullPhysics::RadiantDriver, FullPhysics::LidortRt, FullPhysics::HresWrapper, and FullPhysics::TwostreamRt.
|
virtual |
Print to stream.
Reimplemented from FullPhysics::RadiativeTransferFixedStokesCoefficient.
Reimplemented in FullPhysics::LRadRt, FullPhysics::SpurrRt, FullPhysics::LidortRt, and FullPhysics::TwostreamRt.
Definition at line 41 of file radiative_transfer_single_wn.cc.
|
inlineinherited |
Print to string.
This is primarily useful for SWIG wrappers to this class, e.g. a to_s method in ruby.
Definition at line 31 of file printable.h.
|
protectedinherited |
Helper routine, creates a progress meter.
This will return 0 if we aren't logging, or if we don't have enough points to bother with.
Definition at line 19 of file radiative_transfer.cc.
|
virtualinherited |
Calculate reflectance for the given set of wavenumbers/wavelengths.
Spec_domain | List of wavenumber/wavelength to calculate for. |
Spec_index | The Spectral index |
Skip_jacobian | If true, don't do the Jacobian calculation. Often this is significantly faster to calculate. |
Implements FullPhysics::RadiativeTransfer.
Definition at line 12 of file radiative_transfer_fixed_stokes_coefficient.cc.
|
inlinevirtualinherited |
Remove an observer.
Implements FullPhysics::Observable< std::vector< boost::shared_ptr< NamedSpectrum > > >.
Definition at line 44 of file radiative_transfer_fixed_stokes_coefficient.h.
|
inlineprotectedinherited |
Remove an observer.
Definition at line 173 of file observer.h.
|
inlineprotectedinherited |
Definition at line 181 of file observer.h.
|
virtual |
Calculate stokes vector for the given set of wavenumbers/wavelengths.
Spec_domain | List of wavenumber/wavelength to calculate for. |
Spec_index | The Spectral index |
Implements FullPhysics::RadiativeTransfer.
Definition at line 7 of file radiative_transfer_single_wn.cc.
|
virtual |
Calculate stokes vector for the given set of wavenumbers/wavelengths.
This also calculates the Jacobian of the stokes with respect to the state vector elements.
Spec_domain | List of wavenumber/wavelength to calculate for. |
Spec_index | The Spectral index |
Implements FullPhysics::RadiativeTransfer.
Definition at line 22 of file radiative_transfer_single_wn.cc.
|
pure virtual |
Calculate stokes vector and Jacobian for the given wavenumber.
You can optionally supply a set of intermediate atmosphere variables (e.g., taug, taur, taua_i) to use instead of with atmosphere_ptr() to calculate this.
Wn | Wavenumber to calculate for. This should be in cm^-1 |
Spec_index | The Spectral index |
Iv | Optional intermediate variables to use, rather than calculating. |
Implemented in FullPhysics::LRadRt, FullPhysics::SpurrRt, FullPhysics::RadiantDriver, and FullPhysics::HresWrapper.
|
inlineinherited |
Stokes coefficients used to go from Stokes vector to scalar reflectance.
Definition at line 24 of file radiative_transfer_fixed_stokes_coefficient.h.
|
pure virtual |
Calculate stokes vector for the given wavenumber.
You can optionally supply a set of intermediate atmosphere variables (e.g., taug, taur, taua_i) to use instead of with atmosphere_ptr() to calculate this.
Wn | Wavenumber to calculate for. This should be in cm^-1 |
Spec_index | The Spectral index |
Iv | Optional intermediate variables to use, rather than calculating. |
Implemented in FullPhysics::LRadRt, FullPhysics::SpurrRt, FullPhysics::RadiantDriver, and FullPhysics::HresWrapper.
|
protected |
Definition at line 98 of file radiative_transfer_single_wn.h.
|
protectedinherited |
Definition at line 200 of file observer.h.
|
protectedinherited |
Definition at line 201 of file observer.h.
|
protectedinherited |
Object to go from stokes vector to reflectance.
Definition at line 65 of file radiative_transfer_fixed_stokes_coefficient.h.
|
staticprotectedinherited |
Definition at line 92 of file radiative_transfer.h.