1
0
Fork 0

Rewrite icing parameters computation

Remove unnecessary properties I/O.
This commit is contained in:
Colin Geniet 2020-03-12 12:48:28 +01:00
parent f6e8bed92b
commit 197ce0c664
2 changed files with 62 additions and 71 deletions

View file

@ -3,6 +3,8 @@
# Copyright (c) 2019 Joshua Davidson (Octal450) # Copyright (c) 2019 Joshua Davidson (Octal450)
### Ice sensitive components definition.
var Iceable = { var Iceable = {
new: func(node) { new: func(node) {
var m = { parents: [Iceable] }; var m = { parents: [Iceable] };
@ -32,17 +34,64 @@ var Iceable = {
}; };
var dewpoint = 0; ### Icing parameters computation.
var temperature = 0; # Environmental parameters of the icing model.
var speed = 0; var environment = {
var visibility = 0; dewpoint: props.globals.getNode("environment/dewpoint-degc"),
var visibLclWx = 0; temperature: props.globals.getNode("environment/temperature-degc"),
var severity = 0; visibility: props.globals.getNode("environment/effective-visibility-m"),
var factor = 0; visibLclWx: props.globals.getNode("environment/visibility-m"),
};
# Icing factor computation.
var maxSpread = 0; var maxSpread = 0;
var icingCond = 0;
var severity_factor_table = [
-0.00000166,
0.00000277,
0.00000277,
0.00000554,
0.00001108,
0.00002216,
];
var melt_factor = -0.00005;
var icing_factor = func() {
var temperature = environment.temperature.getValue();
var dewpoint = environment.dewpoint.getValue();
var visibility = environment.visibility.getValue();
var visibLclWx = environment.visibLclWx.getValue();
# Do we create ice?
var spread = temperature - dewpoint;
# freezing fog or low temp and below dp or in advanced wx cloud
var icingCond = ((spread < maxSpread or visibility < 1000 or visibLclWx < 5000)
and temperature < 0);
# todo: turn this into a table or something
var severity = 0;
if (icingCond) {
if (temperature >= -2) {
severity = 1;
} else if (temperature >= -12) {
severity = 3;
} else if (temperature >= -30) {
severity = 5;
} else if (temperature >= -40) {
severity = 3;
} else if (temperature >= -99) {
severity = 1;
}
}
return severity_factor_table[severity];
}
var speed = 0;
var pause = 0; var pause = 0;
var melt = 0;
var windowprobe = 0; var windowprobe = 0;
var wingBtn = 0; var wingBtn = 0;
var wingFault = 0; var wingFault = 0;
@ -60,7 +109,6 @@ var lengAnti = 0;
var rengAnti = 0; var rengAnti = 0;
var WingHasBeenTurnedOff = 0; var WingHasBeenTurnedOff = 0;
var GroundModeFinished = 0; var GroundModeFinished = 0;
var spread = 0;
var windowprb = 0; var windowprb = 0;
var stateL = 0; var stateL = 0;
var stateR = 0; var stateR = 0;
@ -68,11 +116,6 @@ var stateR = 0;
var iceables = []; var iceables = [];
var icingInit = func { var icingInit = func {
setprop("systems/icing/severity", "0"); # maximum severity: we will make it random
setprop("systems/icing/factor", 0.0); # the factor is how many inches we add per second
setprop("systems/icing/max-spread-degc", 0.0);
setprop("systems/icing/melt-w-heat-factor", -0.00005000);
setprop("systems/icing/icingcond", 0);
setprop("controls/switches/windowprobeheat", 0); setprop("controls/switches/windowprobeheat", 0);
setprop("controls/switches/wing", 0); setprop("controls/switches/wing", 0);
setprop("controls/switches/wingfault", 0); setprop("controls/switches/wingfault", 0);
@ -99,17 +142,8 @@ var icingInit = func {
} }
var icingModel = func { var icingModel = func {
dewpoint = getprop("environment/dewpoint-degc");
temperature = getprop("environment/temperature-degc");
speed = getprop("velocities/airspeed-kt"); speed = getprop("velocities/airspeed-kt");
visibility = getprop("environment/effective-visibility-m");
visibLclWx = getprop("environment/visibility-m");
severity = getprop("systems/icing/severity");
factor = getprop("systems/icing/factor");
maxSpread = getprop("systems/icing/max-spread-degc");
icingCond = getprop("systems/icing/icingcond");
pause = getprop("sim/freeze/master"); pause = getprop("sim/freeze/master");
melt = getprop("systems/icing/melt-w-heat-factor");
windowprobe = getprop("controls/deice/windowprobeheat"); windowprobe = getprop("controls/deice/windowprobeheat");
wingBtn = getprop("controls/switches/wing"); wingBtn = getprop("controls/switches/wing");
wingFault = getprop("controls/switches/wingfault"); wingFault = getprop("controls/switches/wingfault");
@ -127,39 +161,17 @@ var icingModel = func {
rengAnti = getprop("controls/deice/rengine"); rengAnti = getprop("controls/deice/rengine");
WingHasBeenTurnedOff = getprop("controls/deice/WingHasBeenTurnedOff"); WingHasBeenTurnedOff = getprop("controls/deice/WingHasBeenTurnedOff");
GroundModeFinished = getprop("controls/deice/GroundModeFinished"); GroundModeFinished = getprop("controls/deice/GroundModeFinished");
if (temperature >= 0 or !icingCond) {
setprop("systems/icing/severity", "0");
} else if (temperature < 0 and temperature >= -2 and icingCond) {
setprop("systems/icing/severity", "1");
} else if (temperature < -2 and temperature >= -12 and icingCond) {
setprop("systems/icing/severity", "3");
} else if (temperature < -12 and temperature >= -30 and icingCond) {
setprop("systems/icing/severity", "5");
} else if (temperature < -30 and temperature >= -40 and icingCond) {
setprop("systems/icing/severity", "3");
} else if (temperature < -40 and temperature >= -99 and icingCond) {
setprop("systems/icing/severity", "1");
}
var factor = icing_factor();
foreach(iceable; iceables) { foreach(iceable; iceables) {
iceable.update(factor, melt); iceable.update(factor, melt_factor);
}
# Do we create ice?
spread = temperature - dewpoint;
# freezing fog or low temp and below dp or in advanced wx cloud
if ((spread < maxSpread and temperature < 0) or (temperature < 0 and visibility < 1000) or (visibLclWx < 5000 and temperature < 0)) {
setprop("systems/icing/icingcond", 1);
} else {
setprop("systems/icing/icingcond", 0);
} }
if (WingHasBeenTurnedOff and !wowl and !wowr and GroundModeFinished) { if (WingHasBeenTurnedOff and !wowl and !wowr and GroundModeFinished) {
setprop("controls/deice/wing", 1); setprop("controls/deice/wing", 1);
setprop("controls/switches/WingHasBeenTurnedOff", 0); setprop("controls/switches/WingHasBeenTurnedOff", 0);
} }
# If we have low pressure we have a fault # If we have low pressure we have a fault
if (PSI < 10) { if (PSI < 10) {
setprop("controls/switches/wingfault", 1); setprop("controls/switches/wingfault", 1);
@ -182,7 +194,7 @@ var icingModel = func {
setprop("systems/pitot/failed", 0); setprop("systems/pitot/failed", 0);
} }
} }
# if ((getprop("systems/electrical/bus/dc-1") == 0 or getprop("systems/electrical/bus/dc-2") == 0) and getprop("fdm/jsbsim/position/wow") == 0) { # if ((getprop("systems/electrical/bus/dc-1") == 0 or getprop("systems/electrical/bus/dc-2") == 0) and getprop("fdm/jsbsim/position/wow") == 0) {
# setprop("controls/switches/leng", 1); # setprop("controls/switches/leng", 1);
# setprop("controls/switches/reng", 1); # setprop("controls/switches/reng", 1);

View file

@ -608,27 +608,6 @@
<output>/systems/pressurization/targetvs</output> <output>/systems/pressurization/targetvs</output>
</filter> </filter>
<filter>
<name>Icing Severity</name>
<type>gain</type>
<gain>1.0</gain>
<update-interval-secs type="double">0.1</update-interval-secs>
<input>
<expression>
<table>
<property>/systems/icing/severity</property>
<entry><ind>0</ind><dep>-0.00000166</dep></entry>
<entry><ind>1</ind><dep> 0.00000277</dep></entry>
<entry><ind>2</ind><dep> 0.00000277</dep></entry>
<entry><ind>3</ind><dep> 0.00000554</dep></entry>
<entry><ind>4</ind><dep> 0.00001108</dep></entry>
<entry><ind>5</ind><dep> 0.00002216</dep></entry>
</table>
</expression>
</input>
<output>/systems/icing/factor</output>
</filter>
<filter> <filter>
<name>TAS</name> <name>TAS</name>
<type>gain</type> <type>gain</type>