1 #ifndef AEROSOL_EXTINCTION_LOG_H 2 #define AEROSOL_EXTINCTION_LOG_H 6 #include <boost/lexical_cast.hpp> 31 const blitz::Array<bool, 1>& Flag,
32 const blitz::Array<double, 1>& Aext,
33 const std::string& Aerosol_name)
42 {
return "Aerosol " +
aerosol_name() +
" Log(extinction) for Press Lvl " +
43 boost::lexical_cast<std::string>(i + 1); }
45 virtual void print(std::ostream& Os)
const;
virtual std::string model_short_name() const
A short name representing the type of extinction model being implemented.
virtual boost::shared_ptr< AerosolExtinction > clone() const
Clone a AerosolExtinction object.
virtual std::string sub_state_identifier() const
Return a string to identify this part of the state, this name should be all lower case and seperate p...
This class maps the state vector to the aerosol extinction on each level.
virtual void print(std::ostream &Os) const
Print to stream.
virtual void calc_aerosol_extinction() const
Derived classes should provide a function to fill in vmr when this is called.
virtual std::string aerosol_name() const
Name of aerosol.
Contains classes to abstract away details in various Spurr Radiative Transfer software.
boost::shared_ptr< Pressure > press
Pressure.
As a design principle, we have each base class with the absolutely minimum interface needed for use f...
virtual ~AerosolExtinctionLog()
AerosolExtinctionLog(const boost::shared_ptr< Pressure > &Press, const blitz::Array< bool, 1 > &Flag, const blitz::Array< double, 1 > &Aext, const std::string &Aerosol_name)
Constructor.
virtual std::string state_vector_name_i(int i) const
Return state vector name for ith entry in coeff.