Skip to content

Commit

Permalink
Merge pull request #42 from firelab/rj-fix-surface-crown-user-provide…
Browse files Browse the repository at this point in the history
…d-waf

[BHP1-1049] Respect User-Provided WAF when running Surface & Crown
  • Loading branch information
rjsheperd authored Jan 11, 2025
2 parents 931a022 + 5be5252 commit be8f62e
Showing 1 changed file with 11 additions and 7 deletions.
18 changes: 11 additions & 7 deletions src/behave/crown.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -112,14 +112,14 @@ void Crown::doCrownRunRothermel()
double canopyHeight = surfaceFuel_.getCanopyHeight(LengthUnits::Feet);
double canopyBaseHeight = crownInputs_.getCanopyBaseHeight(LengthUnits::Feet);
double crownRatio = 0;
if(canopyHeight > 0)
{
if (canopyHeight > 0) {
crownRatio = (canopyHeight - canopyBaseHeight) / canopyHeight;
}

surfaceFuel_.setCrownRatio(crownRatio, FractionUnits::Fraction);

// Step 1: Do surface run and store values needed for further calculations
if (surfaceFuel_.getWindAdjustmentFactorCalculationMethod() == WindAdjustmentFactorCalculationMethod::UseCrownRatio) {
surfaceFuel_.setCrownRatio(crownRatio, FractionUnits::Fraction);
}
surfaceFuel_.doSurfaceRunInDirectionOfMaxSpread(); // Crown ROS output given in direction of max spread
surfaceFireHeatPerUnitArea_ = surfaceFuel_.getHeatPerUnitArea(HeatPerUnitAreaUnits::BtusPerSquareFoot);
surfaceFirelineIntensity_ = surfaceFuel_.getFirelineIntensity(FirelineIntensityUnits::BtusPerFootPerSecond);
Expand Down Expand Up @@ -171,11 +171,15 @@ void Crown::doCrownRunScottAndReinhardt()
// Scott and Reinhardt (2001) linked models method for crown fire
double canopyHeight = surfaceFuel_.getCanopyHeight(LengthUnits::Feet);
double canopyBaseHeight = crownInputs_.getCanopyBaseHeight(LengthUnits::Feet);
double crownRatio = (canopyHeight - canopyBaseHeight) / canopyHeight;

surfaceFuel_.setCrownRatio(crownRatio, FractionUnits::Fraction);
double crownRatio = 0;
if (canopyHeight > 0) {
crownRatio = (canopyHeight - canopyBaseHeight) / canopyHeight;
}

// Step 1: Do surface run and store values needed for further calculations
if (surfaceFuel_.getWindAdjustmentFactorCalculationMethod() == WindAdjustmentFactorCalculationMethod::UseCrownRatio) {
surfaceFuel_.setCrownRatio(crownRatio, FractionUnits::Fraction);
}
const double windSpeed = surfaceFuel_.getWindSpeed(SpeedUnits::FeetPerMinute, WindHeightInputMode::TwentyFoot);
surfaceFuel_.setWindSpeed(windSpeed, SpeedUnits::FeetPerMinute, WindHeightInputMode::TwentyFoot);
surfaceFuel_.doSurfaceRunInDirectionOfMaxSpread();
Expand Down

0 comments on commit be8f62e

Please sign in to comment.