Subversion Repositories public iLand

Rev

Rev 179 | Rev 214 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1
 
90 Werner 2
#ifndef SPECIES_H
3
#define SPECIES_H
38 Werner 4
 
103 Werner 5
 
91 Werner 6
#include "expression.h"
7
 
103 Werner 8
#include "speciesset.h"
102 Werner 9
 
91 Werner 10
class StampContainer; // forwards
38 Werner 11
class Stamp;
91 Werner 12
 
103 Werner 13
 
90 Werner 14
class Species
38 Werner 15
{
16
public:
111 Werner 17
    Species(SpeciesSet *set) { mSet = set; mIndex=set->count(); }
91 Werner 18
    // properties
19
    /// @property id 4-character unique identification of the tree species
111 Werner 20
    const QString &id() const { return mId; }
91 Werner 21
    /// the full name (e.g. Picea Abies) of the species
111 Werner 22
    const QString &name() const { return mName; }
145 Werner 23
    int index() const { return mIndex; } ///< unique index of species within current set
179 werner 24
    bool active() const { return true; } ///< active??? todo!
136 Werner 25
 
91 Werner 26
    // calculations: allometries
145 Werner 27
    double biomassFoliage(const double dbh) const;
28
    double biomassWoody(const double dbh) const;
29
    double biomassRoot(const double dbh) const;
30
    double allometricRatio_wf() const { return mWoody_b / mFoliage_b; }
31
    double allometricFractionStem(const double dbh) const;
136 Werner 32
 
116 Werner 33
    // turnover rates
145 Werner 34
    double turnoverLeaf() const { return mTurnoverLeaf; }
35
    double turnoverRoot() const { return mTurnoverRoot; }
119 Werner 36
    // hd-values
37
    void hdRange(const double dbh, double &rMinHD, double &rMaxHD);
125 Werner 38
    // growth
145 Werner 39
    double volumeFactor() const { return mVolumeFactor; } ///< factor for volume calculation: V = factor * D^2*H (incorporates density and the form of the bole)
40
    double density() const { return mWoodDensity; } ///< density of stem wood [kg/m3]
41
    double specificLeafArea() const { return mSpecificLeafArea; }
159 werner 42
    // mortality
43
    double deathProb_intrinsic() const { return mDeathProb_intrinsic; }
44
    double deathProb_stress() const { return mDeathProb_stress; }
169 werner 45
    // aging
46
    double aging(const float height, const int age);
209 werner 47
    // environmental responses
48
    double vpdResponse(const double &vpd) const;
49
    double temperatureResponse(const double &delayed_temp) const;
50
    double nitrogenResponse(const double &availableNitrogen) const { return mSet->nitrogenResponse(availableNitrogen, mRespNitrogenClass); }
110 Werner 51
 
136 Werner 52
    const Stamp* stamp(const float dbh, const float height) const { return mLIPs.stamp(dbh, height);}
39 Werner 53
    // maintenance
91 Werner 54
    void setup();
38 Werner 55
private:
90 Werner 56
    Q_DISABLE_COPY(Species);
136 Werner 57
    // helpers during setup
58
    double doubleVar(const QString s) { return mSet->var(s).toDouble(); }///< during setup: get value of variable @p s as a double.
59
    double intVar(const QString s) { return mSet->var(s).toInt(); } ///< during setup: get value of variable @p s as an integer.
60
    QString stringVar(const QString s) { return mSet->var(s).toString(); } ///< during setup: get value of variable @p s as a string.
61
 
91 Werner 62
    SpeciesSet *mSet; ///< ptr. to the "parent" set
136 Werner 63
    StampContainer mLIPs; ///< ptr to the container of the LIP-pattern
91 Werner 64
    QString mId;
65
    QString mName;
111 Werner 66
    int mIndex; ///< internal index within the SpeciesSet
136 Werner 67
    // biomass allometries:
68
    double mFoliage_a, mFoliage_b;  ///< allometry (biomass = a * dbh^b) for foliage
69
    double mWoody_a, mWoody_b; ///< allometry (biomass = a * dbh^b) for woody compartments aboveground
70
    double mRoot_a, mRoot_b; ///< allometry (biomass = a * dbh^b) for roots (compound, fine and coarse roots as one pool)
71
    double mBranch_a, mBranch_b; ///< allometry (biomass = a * dbh^b) for branches
72
 
110 Werner 73
    double mSpecificLeafArea; ///< conversion factor from kg OTS to m2 LeafArea
116 Werner 74
    // turnover rates
75
    double mTurnoverLeaf; ///< yearly turnover rate leafs
76
    double mTurnoverRoot; ///< yearly turnover rate root
119 Werner 77
    // height-diameter-relationships
78
    Expression mHDlow; ///< minimum HD-relation as f(d) (open grown tree)
79
    Expression mHDhigh; ///< maximum HD-relation as f(d)
125 Werner 80
    // stem density and taper
81
    double mWoodDensity; ///< density of the wood [kg/m3]
82
    double mFormFactor; ///< taper form factor of the stem [-] used for volume / stem-mass calculation calculation
83
    double mVolumeFactor; ///< factor for volume calculation
159 werner 84
    // mortality
85
    double mDeathProb_intrinsic;  ///< prob. of intrinsic death per year [0..1]
86
    double mDeathProb_stress; ///< max. prob. of death per year when tree suffering maximum stress
169 werner 87
    // Aging
88
    double mMaximumAge; ///< maximum age of species (years)
89
    double mMaximumHeight; ///< maximum height of species (m) for aging
209 werner 90
    // environmental responses
91
    double mRespVpdExponent; ///< exponent in vpd response calculation (Mäkela 2008)
92
    double mRespTempMin; ///< temperature response calculation offset
93
    double mRespTempMax; ///< temperature response calculation: saturation point for temp. response
94
    double mRespNitrogenClass; ///< nitrogen response class (1..3). fractional values (e.g. 1.2) are interpolated.
169 werner 95
    Expression mAging;
38 Werner 96
};
97
 
40 Werner 98
 
119 Werner 99
// inlined functions...
100
inline void Species::hdRange(const double dbh, double &rLowHD, double &rHighHD)
101
{
102
    rLowHD = mHDlow.calculate(dbh);
103
    rHighHD = mHDhigh.calculate(dbh);
104
}
209 werner 105
/** vpdResponse calculates response on vpd.
106
    Input: vpd [kPa]*/
107
inline double Species::vpdResponse(const double &vpd) const
108
{
109
    return exp(mRespVpdExponent * vpd);
110
}
119 Werner 111
 
209 werner 112
/** temperatureResponse calculates response on delayed daily temperature.
113
    Input: average temperature [°C]
114
    Note: slightly different from Mäkela 2008: the maximum parameter (Sk) in iLand is interpreted as the absolute
115
          temperature yielding a response of 1; in Mäkela 2008, Sk is the width of the range (relative to the lower threhold)
116
*/
117
inline double Species::temperatureResponse(const double &delayed_temp) const
118
{
119
    double x = qMax(delayed_temp-mRespTempMin, 0.);
120
    x = qMin(x/(mRespTempMax-mRespTempMin), 1.);
121
    return x;
122
}
123
 
90 Werner 124
#endif // SPECIES_H