File failed to load: https://isis.astrogeology.usgs.gov/6.0.0/Object/assets/jax/output/NativeMML/config.js
Isis Developer Reference
HapkeAtm2.h
Go to the documentation of this file.
1 #if !defined(HapkeAtm2_h)
2 #define HapkeAtm2_h
3 
8 /* SPDX-License-Identifier: CC0-1.0 */
9 
10 #include "AtmosModel.h"
11 
12 namespace Isis {
13  class Pvl;
14 
40  class HapkeAtm2 : public AtmosModel {
41  public:
42  HapkeAtm2(Pvl &pvl, PhotoModel &pmodel);
43  virtual ~HapkeAtm2() {};
44 
45  protected:
46 
47  virtual void AtmosModelAlgorithm(double phase, double incidence,
48  double emission);
49 
50  private:
51  double p_e1, p_e1_2, p_e2, p_e3, p_e4, p_e5;
52  double p_em;
53  double p_e;
54  double p_g11p, p_g12p, p_g13p, p_g14p;
55  double p_x0, p_y0;
56  double p_wha2;
57  double p_g12, p_g13, p_g14;
58  double p_f1, p_f2, p_f3, p_f4;
59  double p_f1m, p_f2m, p_f3m, p_f4m;
60  double p_delta;
61  double p_fixcon;
62  double p_alpha0, p_alpha1, p_alpha2;
63  double p_beta0, p_beta1, p_beta2;
64  double p_gammax, p_gammay;
65  };
66 };
67 
68 #endif
Isis::NumericalAtmosApprox::IntegFunc
IntegFunc
This enum defines function to be integrated by Romberg's method.
Definition: NumericalAtmosApprox.h:43
Isis::AtmosModel::p_atmosHga
double p_atmosHga
Definition: AtmosModel.h:263
Isis::NumericalApproximation::Extrapolate
@ Extrapolate
Evaluate() attempts to extrapolate if a is outside of the domain. This is only valid for NumericalApp...
Definition: NumericalApproximation.h:814
Isis::AtmosModel::AtmosWha
double AtmosWha() const
Return atmospheric Wha value.
Definition: AtmosModel.h:123
Isis::AtmosModel::TauOrWhaChanged
bool TauOrWhaChanged() const
Checks whether tau or wha have changed.
Definition: AtmosModel.cpp:954
Isis::PhotoModel
Definition: PhotoModel.h:41
Isis::PI
const double PI
The mathematical constant PI.
Definition: Constants.h:40
Isis::AtmosModel::p_pstd
double p_pstd
Pure atmospheric-scattering term.
Definition: AtmosModel.h:258
AtmosModel.h
Isis::AtmosModel::En
static double En(unsigned int n, double x)
This routine evaluates the generalized exponential integral, En(x).
Definition: AtmosModel.cpp:370
Isis::IException::Unknown
@ Unknown
A type of error that cannot be classified as any of the other error types.
Definition: IException.h:118
PvlGroup.h
Isis::NumericalAtmosApprox
This class extends Isis::NumericalApproximation.
Definition: NumericalAtmosApprox.h:32
Isis::AtmosModel::Eulgam
double Eulgam() const
Definition: AtmosModel.h:244
Isis::AtmosModel
Isotropic atmos scattering model.
Definition: AtmosModel.h:60
Isis::Pvl
Container for cube-like labels.
Definition: Pvl.h:119
Isis::AtmosModel::p_atmosAtmSwitch
int p_atmosAtmSwitch
Definition: AtmosModel.h:248
Isis::HapkeAtm2::HapkeAtm2
HapkeAtm2(Pvl &pvl, PhotoModel &pmodel)
Definition: HapkeAtm2.cpp:20
Isis::AtmosModel::p_atmosMunot
double p_atmosMunot
Definition: AtmosModel.h:277
NumericalApproximation.h
Isis::HapkeAtm2
Definition: HapkeAtm2.h:40
Isis::AtmosModel::p_atmosInc
double p_atmosInc
Definition: AtmosModel.h:275
Isis::HapkeAtm2::~HapkeAtm2
virtual ~HapkeAtm2()
Definition: HapkeAtm2.h:43
IString.h
Isis::AtmosModel::p_trans
double p_trans
Transmission of surface reflected light through the atmosphere overall.
Definition: AtmosModel.h:259
Isis::AtmosModel::p_atmosEstTau
bool p_atmosEstTau
Estimate optical depth tau using shadows.
Definition: AtmosModel.h:269
Isis::AtmosModel::p_atmosSini
double p_atmosSini
Definition: AtmosModel.h:278
Isis::AtmosModel::p_atmosHahgsb
double p_atmosHahgsb
Definition: AtmosModel.h:272
Pvl.h
_FILEINFO_
#define _FILEINFO_
Macro for the filename and line number.
Definition: IException.h:24
HapkeAtm2Plugin
Isis::AtmosModel * HapkeAtm2Plugin(Isis::Pvl &pvl, Isis::PhotoModel &pmodel)
Definition: HapkeAtm2.cpp:335
Isis::AtmosModel::GenerateHahgTables
void GenerateHahgTables()
This method computes the values of the atmospheric Hahg and Hahg0 tables and sets the properties of t...
Definition: AtmosModel.cpp:637
Isis::AtmosModel::p_transs
double p_transs
Transmission of light that must be subtracted from the flat surface model to get the shadow model.
Definition: AtmosModel.h:261
Isis::AtmosModel::p_atmosHahgtSpline
NumericalApproximation p_atmosHahgtSpline
Spline object for the atmospheric Hahg Table. Properties are set in GenerateHahgTables().
Definition: AtmosModel.h:285
Isis::IException
Isis exception class.
Definition: IException.h:91
Isis::AtmosModel::p_atmosTau
double p_atmosTau
Definition: AtmosModel.h:264
Isis::AtmosModel::p_atmosHnorm
double p_atmosHnorm
Atmospheric shell thickness normalized to planet radius.
Definition: AtmosModel.h:267
IException.h
Isis::AtmosModel::p_atmosHahgt0Spline
NumericalApproximation p_atmosHahgt0Spline
Spline object for the atmospheric Hahg0 Table. Properties are set in GenerateHahgTables().
Definition: AtmosModel.h:287
Isis::AtmosModel::GenerateHahgTablesShadow
void GenerateHahgTablesShadow()
This method is a modified version of the GenerateHahgTables method and is used solely for shadow mode...
Definition: AtmosModel.cpp:726
Isis::AtmosModel::SetOldTau
void SetOldTau(double tau)
Definition: AtmosModel.h:230
Isis::AtmosModel::SetOldWha
void SetOldWha(double wha)
Definition: AtmosModel.h:233
Isis::AtmosModel::Ei
static double Ei(double x)
This routine computes the exponential integral, Ei(x).
Definition: AtmosModel.cpp:229
Isis::NumericalApproximation::Evaluate
double Evaluate(const double a, const ExtrapType &etype=ThrowError)
Calculates interpolated or extrapolated value of tabulated data set for given domain value.
Definition: NumericalApproximation.cpp:836
Isis::AtmosModel::G11Prime
static double G11Prime(double tau)
Perform Chandra and Van de Hulst's series approximation for the g'11 function needed in second order ...
Definition: AtmosModel.cpp:153
Isis::AtmosModel::p_sbar
double p_sbar
Illumination of the ground by the sky.
Definition: AtmosModel.h:262
Constants.h
Isis::HapkeAtm2::AtmosModelAlgorithm
virtual void AtmosModelAlgorithm(double phase, double incidence, double emission)
Henyey-Greenstein atmos scattering in the 1st approximation.
Definition: HapkeAtm2.cpp:62
Isis::AtmosModel::p_atmosWha
double p_atmosWha
Definition: AtmosModel.h:265
Isis::AtmosModel::p_trans0
double p_trans0
Transmission of surface reflected light through the atmosphere with no scatterings in the atmosphere.
Definition: AtmosModel.h:260
Isis::NumericalAtmosApprox::RombergsMethod
double RombergsMethod(AtmosModel *am, IntegFunc sub, double a, double b)
This variation on the NumericalApproximation method integrates a specified AtmosModel function rather...
Definition: NumericalAtmosApprox.cpp:52
Isis::NumericalApproximation::Reset
void Reset()
Resets the state of the object.
Definition: NumericalApproximation.cpp:2251
Isis::NumericalAtmosApprox::OuterFunction
@ OuterFunction
Indicates that Romberg's method will integrate the function OutrFunc2Bint()
Definition: NumericalAtmosApprox.h:43
Isis
This is free and unencumbered software released into the public domain.
Definition: Apollo.h:16
HapkeAtm2.h

U.S. Department of the Interior | U.S. Geological Survey
ISIS | Privacy & Disclaimers | Astrogeology Research Program
To contact us, please post comments and questions on the USGS Astrogeology Discussion Board
To report a bug, or suggest a feature go to: ISIS Github
File Modified: 07/13/2023 15:11:13