SORTIE Core C++ Documentation
|
GLI Points File Creator - Version 1.0. More...
#include <GLIPoints.h>
Classes | |
struct | stcCoords |
Structure for holding GLI points. More... | |
Public Member Functions | |
clGLIPoints (clSimManager *p_oSimManager) | |
Constructor. More... | |
~clGLIPoints () | |
Destructor. More... | |
void | GetData (xercesc::DOMDocument *p_oDoc) |
Does setup for this object. More... | |
void | Action () |
Calculates the GLI values. More... | |
float | CalcLightValue (clTree *p_oTree, clTreePopulation *p_oPop) |
Required overridden function - doesn't do anything. More... | |
Public Member Functions inherited from clGLIBase | |
clGLIBase (clSimManager *p_oSimManager) | |
Constructor. More... | |
virtual | ~clGLIBase () |
Destructor. More... | |
float | GetSinMinSunAng () |
Gets the sine of the minimum sun angle. More... | |
float | GetAziChunkConverter () |
Gets the reciprocal of the size of a single azimuth sky grid division, in degrees. More... | |
float | GetRcpTanMinAng () |
Gets the reciprocal of the tangent of the minimum sun angle. More... | |
Public Member Functions inherited from clLightBase | |
clLightBase (clSimManager *p_oSimManager) | |
Constructor. More... | |
virtual | ~clLightBase () |
Destructor. More... | |
void | Action () |
Performs all light calculations. More... | |
void | RegisterTreeDataMembers () |
Performs data member registrations for "Light". More... | |
clLightOrg * | GetLightOrg () |
Gets the light org object. More... | |
float | GetMinSunAngle () |
Gets the altitude angle below which the sky is assumed to be dark. More... | |
float | GetNumAziAng () |
Gets the number of azimuth angles into which the sky hemisphere is divided. More... | |
float | GetNumAltAng () |
Gets the number of altitude angles into which the sky hemisphere is divided. More... | |
float | GetMinAngRow () |
Gets the row in the brightness array corresponding to the minimum solar angle. More... | |
float | GetBrightness (int alt, int azi) |
Public Member Functions inherited from clBehaviorBase | |
virtual float | GetBehaviorVersion () |
Gets the behavior version number. More... | |
clBehaviorBase (clSimManager *p_oSimManager) | |
Constructor. More... | |
virtual | ~clBehaviorBase () |
Destructor. More... | |
virtual short int | ValidateVersionNumber (float fTestVersion) |
Makes sure that the version number of a file passed is between the minimum and current version numbers. More... | |
virtual void | SetSpeciesTypeCombos (short int iNumCombos, stcSpeciesTypeCombo *p_whatCombos) |
Sets the species/type combos for a behavior. More... | |
virtual void | SetNameData (std::string sNameString) |
Sets the string for the parameter file behavior. More... | |
virtual short int | GetNewTreeInts () |
Gets the number of new tree integer data members this behavior wants to register. More... | |
virtual short int | GetNewTreeFloats () |
Gets the number of new tree float data members this behavior wants to register. More... | |
virtual short int | GetNewTreeChars () |
Gets the number of new tree character data members this behavior wants to register. More... | |
virtual short int | GetNewTreeBools () |
Gets the number of new tree bool data members this behavior wants to register. More... | |
virtual short int | GetNumSpeciesTypeCombos () |
Gets the number of species/type combos to which this behavior applies. More... | |
virtual short int | GetNumBehaviorSpecies () |
Gets the number of unique tree species to which this behavior applies. More... | |
struct stcSpeciesTypeCombo | GetSpeciesTypeCombo (short int iIndex) |
Gets one of this behavior's type/species combos. More... | |
virtual short int | GetBehaviorSpecies (short int iIndex) |
Gets one of the behavior's species. More... | |
short int | GetBehaviorListNumber () |
Gets the behavior list number for this behavior, which differentiates between multiple copies of the behavior in the behavior list. More... | |
void | SetBehaviorListNumber (short int iNumber) |
Sets the behavior list number for this behavior, which differentiates between multiple copies of the behavior in the behavior list. More... | |
std::string | FormatSpeciesTypeQueryString () |
Formats the string for species/types query. More... | |
virtual DOMElement * | GetParentParametersElement (xercesc::DOMDocument *p_oDoc) |
This will get the correct set of parameters for this behavior based on the behavior list position number. More... | |
Public Member Functions inherited from clWorkerBase | |
clWorkerBase (clSimManager *p_oSimManager) | |
Constructor. More... | |
virtual | ~clWorkerBase () |
Destructor. More... | |
std::string | GetName () |
Gets the object's namestring. More... | |
clSimManager * | GetSimManager () |
void | DoObjectSetup (xercesc::DOMDocument *p_oDoc, fileType iFileType) |
Triggers the setup process. More... | |
virtual void | TimestepCleanup () |
Performs any necessary cleanup operations at the end of a timestep. More... | |
virtual void | EndOfRunCleanup () |
Performs any necessary cleanup operations at the end of a run. More... | |
Protected Member Functions | |
void | ReadParameterFileData (xercesc::DOMDocument *p_oDoc) |
Reads in needed parameter file data. More... | |
void | SetUpBrightnessArray () |
Sets up the light brightness array. More... | |
void | DoSetupCalculations () |
Performs setup calculations. More... | |
Protected Member Functions inherited from clGLIBase | |
void | AddTreeToGliFishEye (const float &fTargetX, const float &fTargetY, const float &fTargetHeight, clTree *p_oNeighbor, clPlot *p_oPlot, clTreePopulation *p_oPop, clAllometry *p_oAllom) |
Adds one shading neighbor to the fisheye photo array for a GLI calculation. More... | |
void | GLIFisheyeNoCanopyIntersect (const float &fTargetX, const float &fTargetY, const float &fNeighX, const float &fNeighY, const float &fNeighCanrad, const float &fNeighHeight, const short int &iNeighSpecies, const float &fTargetHeight, const float &fDistToNearEdge, clTree *p_oNeighbor, clPlot *p_oPlot, clAllometry *p_oAllom) |
Adds one shading neighbor to the fisheye photo array for a GLI calculation when the canopies of the two trees do not overlap. More... | |
void | GLIFisheyeCanopyIntersect (const float &fTargetX, const float &fTargetY, const float &fNeighX, const float &fNeighY, const float &fNeighCanrad, const float &fNeighHeight, const short int &iNeighSpecies, const float &fTargetHeight, clTree *p_oNeighbor, clPlot *p_oPlot, clAllometry *p_oAllom) |
Adds one shading neighbor to the fisheye photo array for a GLI calculation when the canopies of the two trees overlap. More... | |
Protected Member Functions inherited from clLightBase | |
void | GetData (xercesc::DOMDocument *p_oDoc) |
Triggers all light setup. More... | |
virtual void | DoShellSetup (xercesc::DOMDocument *p_oDoc) |
If a descendent class has specific setup needs, it can overload this function. More... | |
void | PopulateGLIBrightnessArray () |
Populates the GLI brightness array. More... | |
void | PopulateSailLightBrightnessArray () |
Populates the sail brightness array. More... | |
float | GetDayAngle (int iJulianDay) |
Computes day angle. More... | |
float | GetDeclination (float &fDayAngle) |
Computes solar declination. More... | |
float | GetEccentricity (float &fDayAngle) |
Computes solar eccentricity. More... | |
float | GetSunrise (float &fLatInRadians, float &fDeclination) |
Computes sunrise. More... | |
float | GetCosineOfZenithAngle (float &fDeclination, float &fLatInRadians, float &fTimeNow) |
Computes cosine of the zenith angle of the sun at a given time. More... | |
float | GetAltitudeAngle (float &fCosZenAng) |
Computes altitude angle of the sun at a given time in radians. More... | |
float | GetAzimuthAngle (float &fDeclination, float &fLatInRadians, float &fAltInRad, float &fTimeNow) |
Computes azimuth angle of the sun at a given time in radians in SORTIE azimuth coordinates. More... | |
float | GetAirmassEffect (float &fAltInDeg, float &fCosZenAng) |
Computes the airmass effect for a given altitude angle. More... | |
float | GetBeamRadiation (float &fClearSkyTransCoeff, float &fAirmass, float &fEccentricity, float &fCosZenAng) |
Computes beam radiation strength. More... | |
virtual float | GetLightExtinctionCoefficient (clTree *p_oTree) |
Gets the light extinction coefficent. More... | |
Protected Member Functions inherited from clWorkerBase | |
void | AssembleFileCode (int iFileType, int iFileVersion, char *cCode) |
Creates the proper identifying filecode for an XML file. More... | |
Protected Attributes | |
struct clGLIPoints::stcCoords * | mp_pointsList |
List of points for which to calculate GLI. More... | |
int | m_iNumPoints |
How many points are in mp_pointsList. More... | |
std::string | m_sFileName |
Points output file file name. More... | |
Protected Attributes inherited from clGLIBase | |
float | m_fSinMinSunAng |
Sin of the min sun angle. More... | |
float | m_fAziChunkConverter |
Reciprocal of the size of a single azimuth sky grid division, in degrees. More... | |
float | m_fRcpTanMinAng |
1/tan (m_fMinSunAngle). More... | |
float * | mp_fAziSlope |
For each azimuth chunk of sky, this holds the slope of the line to the middle of the chunk. More... | |
Protected Attributes inherited from clLightBase | |
bool | m_bHooked |
Whether or not this shell object is hooked to clLightOrg. More... | |
bool | m_bNeedsCommonParameters |
Whether or not this shell object requires the common light parameters held in clLightOrg such as clLightOrg::m_iLastJulDay. More... | |
float ** | mp_fBrightness |
Sky brightness array. More... | |
float ** | mp_fPhoto |
Simulated fisheye photo array. More... | |
double | m_fMinSunAngle |
The altitude angle below which the sky is assumed to be dark. More... | |
double | m_fAzimuthOfNorth |
The azimuth angle of north. More... | |
int | m_iNumAziAng |
Number of azimuth angles into which the sky hemisphere is divided. More... | |
int | m_iNumAltAng |
Number of altitude angles into which the sky hemisphere is divided. More... | |
int | m_iMinAngRow |
Row in the brightness array corresponding to the minimum solar angle. More... | |
Protected Attributes inherited from clBehaviorBase | |
short int | m_iNumSpeciesTypeCombos |
How many type/species combos a behavior will act on. More... | |
short int | m_iNumBehaviorSpecies |
How many distinct species are in the combo list - important for filling species-specific values from parameter file. More... | |
short int * | mp_iWhatSpecies |
List of distinct species - for filling species-specific values from parameter file. More... | |
stcSpeciesTypeCombo * | mp_whatSpeciesTypeCombos |
Array of species/type combos that the behavior will act on. More... | |
short int | m_iNewTreeInts |
The number of new tree integer data members this behavior wants to add. More... | |
short int | m_iNewTreeFloats |
The number of new tree float data members this behavior wants to add. More... | |
short int | m_iNewTreeChars |
The number of new tree character data members this behavior wants to add. More... | |
short int | m_iNewTreeBools |
The number of new tree boolean data members this behavior wants to add. More... | |
short int | m_iBehaviorListNumber |
The number of this behavior in the behavior list, to differentiate between possible multiple copies of this behavior. More... | |
float | m_fVersionNumber |
Version number - this will be rounded to 2 digits after the decimal place. More... | |
std::string | m_sXMLRoot |
XML root that encloses the parameters for this behavior. More... | |
float | m_fMinimumVersionNumber |
Minimum version number - this behavior will run parameter data for a file marked between this number and the current version number, inclusive. More... | |
Protected Attributes inherited from clWorkerBase | |
std::string | m_sNameString |
If a behavior has registered a command line command with the sim manager, this allows it to be called. More... | |
clSimManager * | mp_oSimManager |
Pointer to the simulation manager object. More... | |
int * | mp_iAllowedFileTypes |
List of the input file types this object can handle. More... | |
int | m_iNumAllowedTypes |
Number of input file types this object can handle. More... | |
Additional Inherited Members | |
Static Protected Attributes inherited from clLightBase | |
static clLightOrg * | mp_oLightOrg |
clLightOrg object - this pointer is held in common by all shells More... | |
GLI Points File Creator - Version 1.0.
This behavior creates a GLI value for each of a list of user-defined points. The user includes in the parameter file a points file with a set of X and Y coordinates and a height. For each timestep, this will calculate the GLI for each of those points and then write the results to a tab-delimited text file. This behavior does not need to be applied to any trees. Nothing else is done with the GLI values. This is an analysis behavior that prepares some calculations; the user can use the values however they see fit.
The namestring and parameter file call string for this behavior is "GLIPointCreator". This class is descended from clGLIBase so it can use its light calculation methods, but since the string "lightshell" is ommitted from this class's namestring, it should not be treated as a light behavior.
The sky brightness array used by this behavior is potentially identical to that for other GLI light behaviors. Before committing to the calculation of a brightness array, this behavior will ask those behaviors if their settings are identical. If they are, and that class has already calculated the brightness array, this behavior can just copy.
Copyright 2011 Charles D. Canham.
Edit history:
--------------—
October 20, 2011 - Wiped the slate clean for SORTIE 7.0 (LEM)
clGLIPoints::clGLIPoints | ( | clSimManager * | p_oSimManager | ) |
Constructor.
Sets the namestring.
p_oSimManager | Sim Manager object. |
clGLIPoints::~clGLIPoints | ( | ) |
Destructor.
Frees memory.
|
virtual |
Calculates the GLI values.
For each point, this calculates its GLI and then writes the result to the output file.
Reimplemented from clBehaviorBase.
|
inlinevirtual |
Required overridden function - doesn't do anything.
p_oTree | Ignored. |
p_oPop | Ignored. |
Implements clLightBase.
|
protected |
Performs setup calculations.
This calculates the values for m_fAziChunkConverter, m_fRcpTanMinAng, and mp_fAziSlope.
|
virtual |
Does setup for this object.
Calls the following functions:
p_oDoc | DOM tree of parsed input file. |
Implements clWorkerBase.
|
protected |
Reads in needed parameter file data.
First this looks for the "gliPoints" tag and tries to read in all its data from that (in case the user has provided different sky grid settings to different light objects). If there's no sky grid data in the "gliPoints" tag, then this will get what it needs from the first tag it finds with these values. (The "gliPoints" tag, no matter what, must have the GLI points list and the filename of the output file.)
p_oDoc | DOM tree of parsed input file. |
modelErr | if:
|
|
protected |
Sets up the light brightness array.
This will check to see if it can share the brightness array with clGliLight or clQuadratGliLight, and if not, it creates the sky brightness array.
|
protected |
How many points are in mp_pointsList.
|
protected |
Points output file file name.
If it already exists, the file is overwritten
|
protected |
List of points for which to calculate GLI.