Simulation.Model.GradeModels represents a
collection of tree grade classification models. A grade model in OSM predicts
the proportion of stems in a tree record that should be assigned to each grade
class; including class changes (transitions) during simulation. The tree grade
classification system depends on the grade model. OSM can accommodate tree
grade classes ranging from 1 to 255. Depending on the classification used,
grade class could indicate tree form class (e.g., forked top, straight bole) or tree quality class (e.g., amount of rot, defects,
and/or damage) or some combination of form and quality.
Collecting
tree grades in the field and predicting tree grades in OSM can be useful for
simulating short-term and long-term value of alternative stand improvement
prescriptions. When simulating harvest prescriptions in OSM, tree selection can
be directed toward maintenance or improvement of high value trees through Priority and Retention commands.
A
user grade model (specified in a text file with a .grade extension) can specify grade predictions and transitions by
species and DBH class. Alternate models (files) can be built for different
stand or site conditions; each model can be loaded using a single command (LOAD). Variant model developers are free to build more
complex models that predict tree grades using a number of site, stand, and/or
tree properties. Both user and Variant grade models are loaded to the same
collection (GradeModels) so users can easily switch
models with a single command (CURRENT) between stand
simulations.
Variant
grade models:
1)
are
less onerous for users (no grade calibration file needs to be loaded);
2)
ought
to run faster during simulation;
3)
ought to be well tested.
User
grade models can be useful for:
1)
adapting
to a different grade classification system;
2)
testing
alternate grade models;
3)
providing grade predictions in cases where the Variant does not.
Tree grades collected in the field can be specified in the Tree List using the Grade column. Grades ≤ 0 or
null in the Grade column will be predicted using the CURRENT
grade model if ENABLED. Only species that are
represented in the grade model will get grade predictions. Grade predictions
occur when the tree list is loaded and before the first simulation cycle
begins. Grade predictions for recruits and grade transitions for existing trees
occur at the end of a simulation cycle after all tree list changes have been
accepted; therefore, no grade transitions will be apparent in reports until
Cycle 1.
When grade predictions or transitions do occur, they cause
the tree record to be partitioned into new tree record objects; one for each
new class predicted. Number of original tree record stems are also
proportionally distributed to the partitioned records by class according to the
grade model. After partitioning occurs, all tree record properties, other than
number of stems and grade class, stay exactly the same; even Tree ID. This
permits grade transitions to be tracked by tree ID in results if desired.
Unfortunately,
partitioning trees into new grade classes can result in near-exponential growth
of tree records from cycle to cycle and can severely reduce model performance
to the point of memory failure. An elegant solution to this problem is to make
transitions random if the number of tree records exceed a user defined
threshold; see command RandomLimit
for detailed discussion of the value and cost of this feature.
GradeModels
Enabled TRUE or
FALSE {DEFAULT =
False}
Load {model name} {local file path
*.grade}
Current {model name}
If a
Variant defines a grade model, you will need to enable it to get OSM to use it.
By default, grade models are not
enabled because they reduce simulation performance.
SIMULATION.MODEL.GradeModels.Enabled
TRUE
Current
grade model used by OSM. To switch grade models, use:
SIMULATION.MODEL.GradeModels.Current
Name
Name: model ID (name) in the
collection of GradeModels. Double quotes are required
around the name if it contains spaces.
This
command is provided to permit users to switch back to the Variant grade model
after loading a user grade model during the same session. Also, the Variant may
declare multiple grade model versions for users. This property allows a user to
switch to a different model between stand simulations. Consult Variant
documentation for declared grade models, if any. This functionality is also
exposed in the API.
To
load a user-defined grade model use:
SIMULATION.MODEL.GradeModels.Load
Name “C:\...\TextFile.grade”
Required
arguments:
1)
Name: used to ID the model in the
collection of GradeModels. Double quotes are required
around the name if it contains spaces.
2)
File: local absolute or relative
file path to the user-defined grade model; relative to command file. Double
quotes are required around the path if it contains spaces.
When
LOAD is called:
1)
OSM
attempts to read and build the user-defined grade model.
2)
OSM
stores the model in memory in GradeModels for the
remainder of the session.
3)
ENABLED
is switched to TRUE, if not already true.
4)
CURRENT
is set to the user-defined model name, which instructs OSM to use the
user-defined grade model.
Important:
·
If
you load a new grade model with the same name as an existing grade model
(Variant or User), the existing grade model will be replaced with the loaded
version. It is therefore wise to consult Variant documentation on grade model
names to avoid using.
Adjusts
the number of tree records required before grade transitions become random
events; e.g.,
SIMULATION.MODEL.GradeModels.RandomLimit
1000
Required
arguments:
1.
Limit: number of tree records required
before grade transitions operate as random events.
·
Default
= 1000
·
Minimum
= 0; transitions always occur as random events.
·
Maximum
= 2,147,483,647; transitions never occur as random events.
As
discussed earlier, partitioning tree records into new grade classes each cycle
can exponentially reduce simulation performance to the point of failure.
Assuming only 10 initial tree records and 10 new ingrowth records per cycle, a
grade model with 3, 4, and 5 grade classes could potentially cause the number
of tree records to balloon to 52 million, 192 billion, and 69 trillion records
after only 20 cycles.
A
partial solution to this problem is to make class transitions operate as random
events, where probability of transitioning to one or more classes is equal to
the annual or periodic transfer proportion of the class. If that probability is
greater than a random number between 0 and 1, the entire tree is transitioned
to other classes in proportion to the respective transfer ratios provided for
those destinations. However, if initial tree records are few, random
transitions can lead to very erratic grade transitions over time. A final
solution to this problem is to only enable random transitions if the number of
tree records is greater than some limit.
By
default this random transition limit is set to 1000 records. Again, assuming
only 10 initial tree records, 10 new ingrowth records per cycle, and assuming a
transfer probability of 5% per 5-year cycle, a grade model with 3, 4, and 5
grade classes with a random limit = 1000 would cause the number of tree records
to expand to approximately 7, 39, and 47 thousand records after 20 cycles.
Reducing the random limit to 100 would reduce these estimates by more than
half. Despite this solution, given the negative impact of increasing the number
of grade classes on simulation performance, the grading system should use as
few classes as possible (2-3 preferred; >5 strongly discouraged).
Example
effects of Random Limit on simulation results is presented below for six
initial yellow birch tree records in a mixedwood stand in New Brunswick. In
this example, three grades (poor, acceptable, and good) are predicted at cycle
0 and then transitioned for twenty 5-year cycles (100 years) using:
·
Good
ŕ Acceptable @ 0.5% per year
·
Good
ŕ Poor @ 0.25% per year
·
Acceptable
ŕ Poor @ 0.5% per year
The
stacked area fill in the background of the figure below shows the proportion of
grades over time resulting with random limit set to one million, which
effectively turns random transitions off, compared to ten scenarios (stacked
lines) with random limit set to 1000 (default). Note results for all eleven
simulations are identical up to cycle four. In cycle five, number of tree
records exceed 1000, which causes random transitions to occur at the end of
cycle five. For all yellow birch trees, the average proportion of poor and
acceptable grades for the ten stochastic simulations was within 1% point of the
deterministic simulation at 100 years. The deterministic simulation resulted in
20 times more records by year 100 and was 7-8 times slower to execute compared
to the average stochastic run.
Ability
to make grade transitions deterministic or stochastic can be useful for
simulating the probability of achieving certain prescription targets over the
long-term. It may be that a harvest prescription appears attractive under a
deterministic simulation, but 4 times out of 10 stochastic simulations the
treatment fails to deliver an adequate supply of high value trees for
subsequent entries.
A
custom grade model is defined in a text file (*.grade) and loaded (LOAD) to OSM before stands are simulated. This model
specifies Predictions and Transitions of grades by Variant Species and by 1 cm DBH classes.
General
arrangement of keywords (bold) and arguments in the text file is shown in the
example below; general descriptions (gray) are omitted in text file.
Species SM RM YB BE RO |
Species Filter |
|||||
|
|
|
Grades |
Total Check |
||
|
Predictions 1 2 3 |
DBH* |
1 (Poor) |
2 (Acceptable) |
3 (Good) |
|
|
|
5 |
14.48 |
9.86 |
75.66 |
100.0 |
|
|
10 |
14.07 |
12.45 |
73.48 |
100.0 |
|
|
20 |
14.23 |
16.17 |
69.60 |
100.0 |
|
|
30 |
15.69 |
17.97 |
66.34 |
100.0 |
|
|
40 |
18.46 |
17.84 |
63.69 |
100.0 |
|
|
50 |
22.54 |
20.46 |
57.00 |
100.0 |
|
|
70 |
34.61 |
22.39 |
43.00 |
100.0 |
|
|
|
|
|
|
|
|
Transitions 1 |
|
Annual proportion of class 1 -> 1 2 3 |
|
||
|
|
0 |
100.00 |
0.00 |
0.00 |
100.0 |
|
|
5 |
99.25 |
0.50 |
0.25 |
100.0 |
|
|
|
|
|
|
|
|
Transitions 2 |
|
Annual proportion of class 2 -> 1 2 3 |
|
||
|
|
0 |
0.00 |
100.00 |
0.00 |
100.0 |
|
|
5 |
0.00 |
99.50 |
0.50 |
100.0 |
|
|
|
|
|
|
|
|
Transitions 3 |
|
Annual proportion of class 3 -> 1 2 3 |
|
||
|
|
0 |
100.00 |
0.00 |
0.00 |
100.0 |
*DBH in 1 centimeter classes only; inches not supported. |
Actual
text in the file for the above model is shown below (comments in green).
#Example Tree Grade Classification Predictions & Transitions
# 1 = Poor; 2 = Acceptable; 3 = Good
# Limited to shade-tolerant hardwood
Species SM RM YB BE RO
Predictions 1 2 3
5 14.48 9.86 75.66
10 14.07 12.45 73.48
20 14.23 16.17 69.60
30 15.69 17.97 66.34
40 18.46 17.84 63.69
50 22.54 20.46
57.00
70 34.61 22.39
43.00
Transitions 1
0 100.00 0.00 0.00
Transitions 2
0 0.00 100.00 0.00
5 0.50 99.50 0.00
Transitions 3
0 0.00 0.00 100.00
5 0.25 0.50 99.25
Different
grade models for different species or species groups can be defined in the same
text file; one after another. The keyword Species
declares a new grade model for a species or species group. Predictions must be declared and Transitions can be optionally declared below each Species keyword.
Species A B C
Predictions…
Transitions…
Species D E F G
Predictions…
Transitions…
Variant
keys, USDA plant or genus codes, and species
groups previously declared can be used to assign predictions and
transitions to specific species. If no species codes are listed after Species, then the grade model is
assigned to all species. Subsequent Species
models will overwrite previous Species
models where individual species overlap.
Predictions declare the grade classes in
the model (e.g., 1 – Poor, 2 – Acceptable, 3 - Good) immediately following the
Predictions statement. Classes can be any whole number between 1 and 255. Below
the Predictions statement, grade
proportions (respective of the order classes declared in Predictions) are
listed in rows by DBH class (1 cm). DBH class can be any whole number between 0
and 100. Linear interpolation is used to calculate proportions for any DBH
class not provided. If DBH classes provided do not include 0 or 100, then the
closest DBH class proportions will be used (i.e., no extrapolation). To
maximize simulation performance, OSM pre-calculates predicted grade proportions
by 1 cm DBH class from 0 to 100 cm; therefore, a tree with DBH of 5.6 cm would
use proportions calculated for a 6 cm tree.
The
following predictions:
Predictions 1 2 3
5 14.48 9.86 75.66
10 14.07 12.45 73.48
20 14.23 16.17 69.60
30 15.69 17.97 66.34
40 18.46 17.84 63.69
50 22.54 20.46
57.00
70 34.61 22.39
43.00
, would
result in the following proportions of grades assigned to all trees by 1 cm DBH
class.
These
predictions will occur for all tree records where Grade is null or 0, which
include initial tree records in cycle 0 and ingrowth in cycles
≥1.
Transitions
declare the annual proportion(s) of one class that is predicted to
transfer to another class(s). If no transitions are specified, no transitions
occur. Transitions do not need to be declared for every grade class; but when
declared for a class, the class must have Predictions
(i.e., the class must be listed after Predictions).
The
single class stated immediately after Transitions defines the transfer source, while
the proportions listed following the DBH class (much the same as Predictions)
under Transitions tell OSM how much of the source class to transfer to the
destination classes annually. As with Predictions, linear interpolation is used
to calculate proportions for missing DBH classes, no extrapolation occurs, and
transition proportions by 1 cm DBH class from 0 to 100 cm are pre-calculated by
OSM.
The
following transition model (from above):
Transitions 1
0 100.00 0.00 0.00
Transitions
2
0 0.00 100.00 0.00
5 0.50 99.50 0.00
Transitions 3
0 0.00 0.00 100.00
5 0.25 0.50 99.25
,
would yield the following behaviour:
·
Class
1 (poor) would transition to itself.
·
Class
2 (acceptable) would
o For DBH = 0 cm, transition
back to itself.
o For DBH ≥ 5 cm,
transition at a rate of 0.5% / year to class 1 (poor).
o For DBH > 0 and < 5 cm,
transition at a linearly interpolated annual proportion to class 1.
·
Class
2 (good) would behave much the same as Class 2 except that a maximum of 0.25%
and 0.5% will be annually transferred to class 1 (poor) and 2 (acceptable),
respectively.
Because
class 1 in the example above always transitions back to itself at 100% the
transition declaration for class 1 should be left out of the text file to
improve performance; OSM will not need to query the transition for class 1 at
all if it does not exist.
When
years per simulation cycle are > 1, the annual transition proportion of the
source class is converted by OSM to a periodic proportion using the compound
interest formula. The relative proportion transferred to other classes is
multiplied against the periodic proportion to yield final periodic transfer
proportions. For example:
Class 3 -> |
1 |
2 |
3 |
Annual |
0.250% |
0.500% |
99.250% |
Periodic (5 year) |
1.231% |
2.463% |
96.306% |
Note
that annual and periodic simulations will not yield exactly the same results
because under annual cycles, transitions in year one may cause different
transitions to occur in year two; e.g., a tree can transition from class 1
-> 2 -> 3 within a 5-year period using annual cycles; whereas, under
periodic cycles a tree can only undergo a single source -> destination
transition. At the end of a 50-year simulation using a random test stand, the
transition model example above resulted in <0.4% difference in absolute
class proportions using annual cycles compared to 5-year cycles. Some of this
difference could be attributed to slight differences in tree growth and
mortality under annual vs. periodic simulations, due again to more integrated
model behaviour under annual cycles. Despite minor difference in model results
between annual and periodic cycles, as a general rule, it is recommended that
years per simulation cycle closely match years per measurement in permanent
sample plots used to calibrate models.