ReFRACtor
FullPhysics::Aerosol Class Referenceabstract

This class maintains the aerosol portion of the state. More...

#include <aerosol.h>

+ Inheritance diagram for FullPhysics::Aerosol:
+ Collaboration diagram for FullPhysics::Aerosol:

Public Member Functions

virtual ~Aerosol ()
 
virtual void add_observer (Observer< Aerosol > &Obs)
 Add an observer. More...
 
void add_observer_and_keep_reference (boost::shared_ptr< Observer< Aerosol > > &Obs)
 Add an observer and keep a reference to it. More...
 
virtual boost::shared_ptr< Aerosolclone () const =0
 
virtual boost::shared_ptr< Aerosolclone (const boost::shared_ptr< Pressure > &Press, const boost::shared_ptr< RelativeHumidity > &Rh) const =0
 
virtual void mark_used (const StateVector &Sv, blitz::Array< bool, 1 > &Used) const
 Mark elements that we are actively using (i.e., that aren't ignored). More...
 
virtual void notify_add (StateVector &Observed_object)
 Called when an object is added to an Observable. More...
 
virtual void notify_add ()
 
virtual void notify_remove (StateVector &Observed_object)
 Called when an object is removed from an Observable. More...
 
virtual void notify_remove ()
 
virtual void notify_update (const StateVector &Observed_object)
 Called when the Observed object is updated. More...
 
virtual int number_particle () const =0
 Number of aerosol particles. More...
 
virtual ArrayAd< double, 2 > optical_depth_each_layer (double wn) const =0
 This gives the optical depth for each layer, for the given wave number. More...
 
virtual ArrayAd< double, 3 > pf_mom (double wn, const ArrayAd< double, 2 > &frac_aer, int nummom=-1, int numscat=-1) const =0
 This calculates the portion of the phase function moments that come from the aerosol. More...
 
virtual void print (std::ostream &Os) const
 
std::string print_to_string () const
 Print to string. More...
 
virtual void remove_observer (Observer< Aerosol > &Obs)
 Remove an observer. More...
 
virtual ArrayAd< double, 1 > ssa_each_layer (double wn, int particle_index, const ArrayAd< double, 1 > &Od) const =0
 This gives the single scatter albedo for each layer, for the given wave number, for the given particle. More...
 
virtual void state_vector_name (const StateVector &Sv, blitz::Array< std::string, 1 > &Sv_name) const
 Update any portion of the list of the state vector names that apply to this object. More...
 

Static Public Attributes

static AccumulatedTimer timer
 Timer for Aerosol. More...
 

Protected Member Functions

void add_observer_do (Observer< Aerosol > &Obs, Aerosol &t)
 Add an observer. More...
 
void add_observer_do (Observer< Aerosol > &Obs)
 
void clean_dead_ptr ()
 Remove any dead pointers. More...
 
void notify_update_do (const Aerosol &Self)
 Function to call to notify Observers of a state change. More...
 
void remove_observer_do (Observer< Aerosol > &Obs, Aerosol &t)
 Remove an observer. More...
 
void remove_observer_do (Observer< Aerosol > &Obs)
 

Protected Attributes

std::list< boost::weak_ptr< Observer< Aerosol > > > olist
 
std::vector< boost::shared_ptr< Observer< Aerosol > > > ref_list
 

Detailed Description

This class maintains the aerosol portion of the state.

Other objects may depend on the aerosol, and should be updated when the aerosol is updated. To facilitate that, this class in an Oberverable, and objects can add themselves as Observers to be notified when the aerosol is updated.

I'm not really sure what the interface for this class should be. Right now it is used only by AtmosphereOco, and there is only one instance AerosolOptical, so the functions are what AtmosphereOco needs. But we may perhaps want to modify this in the future to be more general.

Definition at line 24 of file aerosol.h.

Constructor & Destructor Documentation

◆ ~Aerosol()

virtual FullPhysics::Aerosol::~Aerosol ( )
inlinevirtual

Definition at line 26 of file aerosol.h.

Member Function Documentation

◆ add_observer()

virtual void FullPhysics::Aerosol::add_observer ( Observer< Aerosol > &  Obs)
inlinevirtual

Add an observer.

Implements FullPhysics::Observable< Aerosol >.

Definition at line 31 of file aerosol.h.

◆ add_observer_and_keep_reference()

void FullPhysics::Observable< Aerosol >::add_observer_and_keep_reference ( boost::shared_ptr< Observer< Aerosol > > &  Obs)
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.

◆ add_observer_do() [1/2]

void FullPhysics::Observable< Aerosol >::add_observer_do ( Observer< Aerosol > &  Obs,
Aerosol t 
)
inlineprotectedinherited

Add an observer.

Definition at line 148 of file observer.h.

◆ add_observer_do() [2/2]

void FullPhysics::Observable< Aerosol >::add_observer_do ( Observer< Aerosol > &  Obs)
inlineprotectedinherited

Definition at line 159 of file observer.h.

◆ clean_dead_ptr()

void FullPhysics::Observable< Aerosol >::clean_dead_ptr ( )
inlineprotectedinherited

Remove any dead pointers.

Definition at line 196 of file observer.h.

◆ clone() [1/2]

virtual boost::shared_ptr<Aerosol> FullPhysics::Aerosol::clone ( ) const
pure virtual

Implemented in FullPhysics::AerosolOptical.

◆ clone() [2/2]

virtual boost::shared_ptr<Aerosol> FullPhysics::Aerosol::clone ( const boost::shared_ptr< Pressure > &  Press,
const boost::shared_ptr< RelativeHumidity > &  Rh 
) const
pure virtual

Implemented in FullPhysics::AerosolOptical.

◆ mark_used()

virtual void FullPhysics::StateVectorObserver::mark_used ( const StateVector Sv,
blitz::Array< bool, 1 > &  Used 
) const
inlinevirtualinherited

Mark elements that we are actively using (i.e., that aren't ignored).

You only need to mark the ones that are used as true, everything is already initialized as false. Default is to do nothing.

Reimplemented in FullPhysics::SubStateVectorObserver.

Definition at line 26 of file state_vector_observer.h.

◆ notify_add() [1/2]

virtual void FullPhysics::Observer< StateVector >::notify_add ( StateVector Observed_object)
inlinevirtualinherited

Called when an object is added to an Observable.

Default is to do nothing.

Reimplemented in FullPhysics::AtmosphereOco, and FullPhysics::SubStateVectorObserver.

Definition at line 47 of file observer.h.

◆ notify_add() [2/2]

virtual void FullPhysics::Observer< StateVector >::notify_add ( )
inlinevirtualinherited

Definition at line 48 of file observer.h.

◆ notify_remove() [1/2]

virtual void FullPhysics::Observer< StateVector >::notify_remove ( StateVector Observed_object)
inlinevirtualinherited

Called when an object is removed from an Observable.

Default is to do nothing.

Reimplemented in FullPhysics::AtmosphereOco, and FullPhysics::SubStateVectorObserver.

Definition at line 55 of file observer.h.

◆ notify_remove() [2/2]

virtual void FullPhysics::Observer< StateVector >::notify_remove ( )
inlinevirtualinherited

Definition at line 56 of file observer.h.

◆ notify_update()

virtual void FullPhysics::Observer< StateVector >::notify_update ( const StateVector Observed_object)
inlinevirtualinherited

Called when the Observed object is updated.

Reimplemented in FullPhysics::AtmosphereOco, FullPhysics::RadianceScalingSvFit, FullPhysics::AbsorberAbsco, FullPhysics::AerosolOptical, and FullPhysics::SubStateVectorObserver.

Definition at line 40 of file observer.h.

◆ notify_update_do()

void FullPhysics::Observable< Aerosol >::notify_update_do ( const Aerosol Self)
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.

◆ number_particle()

virtual int FullPhysics::Aerosol::number_particle ( ) const
pure virtual

Number of aerosol particles.

Implemented in FullPhysics::AerosolOptical.

◆ optical_depth_each_layer()

virtual ArrayAd<double, 2> FullPhysics::Aerosol::optical_depth_each_layer ( double  wn) const
pure virtual

This gives the optical depth for each layer, for the given wave number.

Note this only includes the aerosol portion of this, Atmosphere class combines this with Absorbers and rayleigh scattering.

This calculates the derivatives with respect to the state vector.

This has size of number_active_layer() x number_particle().

Implemented in FullPhysics::AerosolOptical.

◆ pf_mom()

virtual ArrayAd<double, 3> FullPhysics::Aerosol::pf_mom ( double  wn,
const ArrayAd< double, 2 > &  frac_aer,
int  nummom = -1,
int  numscat = -1 
) const
pure virtual

This calculates the portion of the phase function moments that come from the aerosol.

Parameters
wnThe wave number.
frac_aerThis is number_active_layer() x number_particle()
nummomNumber of moments to fill in
numscatNumber of scatters to fill in

Implemented in FullPhysics::AerosolOptical.

◆ print()

virtual void FullPhysics::StateVectorObserver::print ( std::ostream &  Os) const
inlinevirtualinherited

Reimplemented in FullPhysics::AtmosphereOco, FullPhysics::EmpiricalOrthogonalFunction, FullPhysics::AbsorberAbsco, FullPhysics::SolarAbsorptionAndContinuum, FullPhysics::PressureFixedLevel, FullPhysics::Instrument, FullPhysics::DispersionPolynomial, FullPhysics::GroundBrdf, FullPhysics::AerosolOptical, FullPhysics::SubStateVectorObserver, FullPhysics::RadianceScaling, FullPhysics::IlsInstrument, FullPhysics::AerosolPropertyRhHdf, FullPhysics::IlsConvolution, FullPhysics::RadianceScalingSvFit, FullPhysics::AerosolShapeGaussian, FullPhysics::AerosolPropertyImpBase, FullPhysics::AerosolExtinctionLog, FullPhysics::PressureSigma, FullPhysics::RadianceScalingLinearFit, FullPhysics::AerosolExtinctionLinear, FullPhysics::AerosolExtinctionImpBase, FullPhysics::PressureImpBase, FullPhysics::StokesCoefficientImpBase, FullPhysics::GroundLambertian, FullPhysics::TemperatureImpBase, FullPhysics::AerosolPropertyHdf, FullPhysics::FluorescenceEffect, FullPhysics::AbsorberVmrImpBase, FullPhysics::SolarModel, FullPhysics::InstrumentDoppler, FullPhysics::GroundCoxmunk, FullPhysics::ApplyInstrumentUnits, FullPhysics::GroundCoxmunkPlusLambertian, FullPhysics::AbsorberVmrFixedLevel, FullPhysics::AbsorberVmrFixedLevelScaled, FullPhysics::AbsorberVmrMet, FullPhysics::SubStateVectorProxy, FullPhysics::AbsorberVmrLevel, FullPhysics::AbsorberVmrLevelScaled, FullPhysics::TemperatureFixedLevel, FullPhysics::AbsorberVmrScaled, FullPhysics::StokesCoefficientFraction, FullPhysics::TemperatureMet, FullPhysics::TemperatureLevelOffset, FullPhysics::TemperatureOffset, and FullPhysics::StokesCoefficientConstant.

Definition at line 37 of file state_vector_observer.h.

◆ print_to_string()

std::string FullPhysics::Printable< StateVectorObserver >::print_to_string ( ) const
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.

◆ remove_observer()

virtual void FullPhysics::Aerosol::remove_observer ( Observer< Aerosol > &  Obs)
inlinevirtual

Remove an observer.

Implements FullPhysics::Observable< Aerosol >.

Definition at line 33 of file aerosol.h.

◆ remove_observer_do() [1/2]

void FullPhysics::Observable< Aerosol >::remove_observer_do ( Observer< Aerosol > &  Obs,
Aerosol t 
)
inlineprotectedinherited

Remove an observer.

Definition at line 173 of file observer.h.

◆ remove_observer_do() [2/2]

void FullPhysics::Observable< Aerosol >::remove_observer_do ( Observer< Aerosol > &  Obs)
inlineprotectedinherited

Definition at line 181 of file observer.h.

◆ ssa_each_layer()

virtual ArrayAd<double, 1> FullPhysics::Aerosol::ssa_each_layer ( double  wn,
int  particle_index,
const ArrayAd< double, 1 > &  Od 
) const
pure virtual

This gives the single scatter albedo for each layer, for the given wave number, for the given particle.

Note this only includes the aerosol portion of this, Atmosphere class combines this with Rayleigh scattering.

We take in the optical depth of each layer. This is just what is returned by optical_depth_each_layer(), we take this in because we can change what the derivative of optical_depth_each_layer is respect to, e.g. in AtmosphereOco we use taua_i.

This calculates the derivative with respect to whatever variables Od is relative to.

This has size of number_active_layer()

Implemented in FullPhysics::AerosolOptical.

◆ state_vector_name()

virtual void FullPhysics::StateVectorObserver::state_vector_name ( const StateVector Sv,
blitz::Array< std::string, 1 > &  Sv_name 
) const
inlinevirtualinherited

Update any portion of the list of the state vector names that apply to this object.

Default is to do nothing.

Reimplemented in FullPhysics::SubStateVectorObserver.

Definition at line 34 of file state_vector_observer.h.

Member Data Documentation

◆ olist

std::list<boost::weak_ptr<Observer<Aerosol > > > FullPhysics::Observable< Aerosol >::olist
protectedinherited

Definition at line 200 of file observer.h.

◆ ref_list

std::vector<boost::shared_ptr<Observer<Aerosol > > > FullPhysics::Observable< Aerosol >::ref_list
protectedinherited

Definition at line 201 of file observer.h.

◆ timer

AccumulatedTimer Aerosol::timer
static

Timer for Aerosol.

Definition at line 29 of file aerosol.h.


The documentation for this class was generated from the following files:

Copyright © 2017, California Institute of Technology.
ALL RIGHTS RESERVED.
U.S. Government Sponsorship acknowledged.
Generated Fri Aug 24 2018 15:44:11