File failed to load: https://isis.astrogeology.usgs.gov/6.0.0/Object/assets/jax/output/NativeMML/config.js
Isis Developer Reference
MinnaertEmpirical.h
Go to the documentation of this file.
1 #ifndef MinnaertEmpirical_h
2 #define MinnaertEmpirical_h
3 
8 /* SPDX-License-Identifier: CC0-1.0 */
9 
10 #include "NumericalApproximation.h"
11 #include "PhotoModel.h"
12 
13 namespace Isis {
14  class Pvl;
15 
43  class MinnaertEmpirical : public PhotoModel {
44  public:
45  MinnaertEmpirical(Pvl &pvl);
46  virtual ~MinnaertEmpirical();
47 
48  void SetPhotoPhaseList(QString phasestrlist);
49  void SetPhotoKList(QString kstrlist);
50  void SetPhotoPhaseCurveList(QString phasecurvestrlist);
51 
53 // inline std::vector<double> PhotoPhaseList() const {
54 // return p_photoPhaseList;
55 // };
57 // inline std::vector<double> PhotoKList() const {
58 // return p_photoKList;
59 // };
61 // inline std::vector<double> PhotoPhaseCurveList() const {
62 // return p_photoPhaseCurveList;
63 // };
64 
65  virtual double PhotoModelAlgorithm(double phase, double incidence,
66  double emission);
67 
68  private:
69 // int p_photoPhaseAngleCount;
70 // std::vector<double> p_photoPhaseList;
71 // std::vector<double> p_photoKList;
72 // std::vector<double> p_photoPhaseCurveList;
73 // NumericalApproximation p_photoKSpline;
74 // NumericalApproximation p_photoBSpline;
75  };
76 };
77 
78 #endif
Isis::NumericalApproximation::SetInterpType
void SetInterpType(NumericalApproximation::InterpType itype)
Sets interpolation type.
Definition: NumericalApproximation.cpp:2319
Isis::MinnaertEmpirical::SetPhotoPhaseCurveList
void SetPhotoPhaseCurveList(QString phasecurvestrlist)
Set the empirical Minnaert function phase curve list.
Definition: MinnaertEmpirical.cpp:127
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::MinnaertEmpirical::~MinnaertEmpirical
virtual ~MinnaertEmpirical()
Definition: MinnaertEmpirical.cpp:62
Isis::PhotoModel::p_photoKList
std::vector< double > p_photoKList
Definition: PhotoModel.h:222
Isis::PhotoModel
Definition: PhotoModel.h:41
Isis::PI
const double PI
The mathematical constant PI.
Definition: Constants.h:40
Isis::PhotoModel::p_photoBSpline
NumericalApproximation p_photoBSpline
Definition: PhotoModel.h:228
PhotoModel.h
Isis::PhotoModel::p_photoPhaseList
std::vector< double > p_photoPhaseList
Definition: PhotoModel.h:221
Isis::PvlContainer::hasKeyword
bool hasKeyword(const QString &name) const
Check to see if a keyword exists.
Definition: PvlContainer.cpp:159
Isis::Pvl
Container for cube-like labels.
Definition: Pvl.h:119
NumericalApproximation.h
Isis::MinnaertEmpirical::MinnaertEmpirical
MinnaertEmpirical(Pvl &pvl)
Definition: MinnaertEmpirical.cpp:12
Isis::PvlObject::Traverse
@ Traverse
Search child objects.
Definition: PvlObject.h:158
Isis::MinnaertEmpirical::PhotoModelAlgorithm
virtual double PhotoModelAlgorithm(double phase, double incidence, double emission)
Return photometric phase angle list.
Definition: MinnaertEmpirical.cpp:138
Isis::PvlGroup
Contains multiple PvlContainers.
Definition: PvlGroup.h:41
_FILEINFO_
#define _FILEINFO_
Macro for the filename and line number.
Definition: IException.h:24
Isis::MinnaertEmpirical
Empirical Minnaert photometric model Derive model albedo using phase dependent Minnaert equation and ...
Definition: MinnaertEmpirical.h:43
Isis::NumericalApproximation::CubicClamped
@ CubicClamped
Cubic Spline interpolation with clamped boundary conditions.
Definition: NumericalApproximation.h:735
Isis::PvlObject::findObject
PvlObjectIterator findObject(const QString &name, PvlObjectIterator beg, PvlObjectIterator end)
Find the index of object with a specified name, between two indexes.
Definition: PvlObject.h:274
Isis::IException
Isis exception class.
Definition: IException.h:91
Isis::MinnaertEmpirical::SetPhotoKList
void SetPhotoKList(QString kstrlist)
Set the empirical Minnaert function K exponent list.
Definition: MinnaertEmpirical.cpp:104
Isis::PhotoModel::p_photoKSpline
NumericalApproximation p_photoKSpline
Definition: PhotoModel.h:226
IException.h
Isis::NumericalApproximation::SetCubicClampedEndptDeriv
void SetCubicClampedEndptDeriv(const double yp1, const double ypn)
Sets the values for the first derivatives of the endpoints of the data set.
Definition: NumericalApproximation.cpp:565
Isis::PhotoModel::p_photoPhaseAngleCount
int p_photoPhaseAngleCount
Definition: PhotoModel.h:225
Isis::NumericalApproximation::AddData
void AddData(const double x, const double y)
Add a datapoint to the set.
Definition: NumericalApproximation.cpp:440
Isis::MinnaertEmpirical::SetPhotoPhaseList
void SetPhotoPhaseList(QString phasestrlist)
Set the empirical Minnaert function phase angle list.
Definition: MinnaertEmpirical.cpp:79
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::IString::Token
IString Token(const IString &separator)
Returns the first token in the IString.
Definition: IString.cpp:897
MinnaertEmpiricalPlugin
Isis::PhotoModel * MinnaertEmpiricalPlugin(Isis::Pvl &pvl)
Definition: MinnaertEmpirical.cpp:186
Isis::IString
Adds specific functionality to C++ strings.
Definition: IString.h:165
Isis::PhotoModel::p_photoPhaseCurveList
std::vector< double > p_photoPhaseCurveList
Definition: PhotoModel.h:224
Isis::NumericalApproximation::Reset
void Reset()
Resets the state of the object.
Definition: NumericalApproximation.cpp:2251
MinnaertEmpirical.h
Isis
This is free and unencumbered software released into the public domain.
Definition: Apollo.h:16
Isis::IException::User
@ User
A type of error that could only have occurred due to a mistake on the user's part (e....
Definition: IException.h:126

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: 03/21/2022 06:51:04