From ec0e9291e83658c922b18c5a7a80e52247125a15 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Tue, 9 Apr 2013 09:07:36 +0300 Subject: [PATCH 01/17] Madagascar regional texture definitions --- Materials/regions/madagascar.xml | 33 ++++++ Materials/regions/materials.xml | 180 +++++++++++++++++++++++++++++++ 2 files changed, 213 insertions(+) create mode 100644 Materials/regions/madagascar.xml diff --git a/Materials/regions/madagascar.xml b/Materials/regions/madagascar.xml new file mode 100644 index 000000000..10b3d4f1d --- /dev/null +++ b/Materials/regions/madagascar.xml @@ -0,0 +1,33 @@ + + + + + + + + sim/startup/season + summer + + + + position/longitude-deg + 40.0 + + + position/longitude-deg + 50.0 + + + position/latitude-deg + -35.0 + + + position/latitude-deg + -10.0 + + + + + + + diff --git a/Materials/regions/materials.xml b/Materials/regions/materials.xml index d400e7c39..f5fe5cb21 100644 --- a/Materials/regions/materials.xml +++ b/Materials/regions/materials.xml @@ -2627,6 +2627,186 @@ + + + + + + EvergreenBroadCover + EvergreenForest + Effects/forest + + Terrain/rainforest-hawaii.png + Terrain/rainforest-hawaii.png + Terrain/shrub-hawaii.png + + 2000 + 2000 + 10000000.0 + 4000.0 + Trees/tropical-summer.png + 8 + + 35.0 + 30.0 + 1 + 1 + + + + GrassCover + BareTundraCover + MixedTundraCover + Cemetery + Effects/landmass-nowood + + Terrain/tundra-hawaii.png + Terrain/rainforest-hawaii.png + Terrain/shrub-hawaii.png + Terrain/airport_grass2.png + + + 0.0 + + 2000 + 2000 + 4000000.0 + + 0.93 + 0.95 + 0.93 + 1.0 + + + 0.1 + 0.12 + 0.1 + 1.0 + + 1.2 + 1 + 0.7 + 0.1 + 0.15 + 1e30 + + + + MixedCropPastureCover + MixedCrop + ComplexCrop + + Terrain/cropgrass-madagascar.png + Terrain/shrub-hawaii.png + + + 0.5 + + 2000 + 2000 + 2000000.0 + 1 + 0.9 + 0.1 + 0.7 + 1e30 + + + + Effects/crop + DryCropPastureCover + DryCrop + + Terrain/tundra-hawaii.png + Terrain/rainforest-hawaii.png + Terrain/shrub-hawaii.png + + 2000 + 2000 + 1 + 0.9 + 0.1 + 0.6 + 1e30 + 2000000.0 + 50000.0 + Trees/tropical-summer.png + 8 + + 20.0 + 12.0 + + + + + BuiltUpCover + Urban + Terrain/town-madagascar.png + Terrain/town-europe.mask.png + 1024 + 1024 + 100000.0 + + 0.05 + 0.05 + 0.02 + 1.0 + + + 500.0 + 0.9 + 0.1 + 0.0 + 4 + 1000.0 + Trees/tropical-alt-summer.png + 8 + + 15.0 + 10.0 + + + + DeciduousBroadCover + DeciduousForest + Bog + Heath + + Terrain/rainforest-hawaii.png + Terrain/marsh2a.png + + + 0.4 + + 2000 + 2000 + 10000000.0 + 4000.0 + Trees/tropical-summer.png + 8 + + 25.0 + 15.0 + 1 + 0.85 + + + + Sand + + Terrain/sand-hawaii4.png + Terrain/sand-hawaii4.png + + 2000 + 2000 + 10000000.0 + 2.5 + 0.1 + 0.7 + 0.1 + + + From 55c599c8ca09b55ef8478d8b76200963229a59d2 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Tue, 9 Apr 2013 09:14:50 +0300 Subject: [PATCH 02/17] Atmospheric Light Scattering specific environment settings are only active when the rendering framework is on --- gui/dialogs/environment-settings.xml | 62 +++++++++++++++++++++++++++- 1 file changed, 61 insertions(+), 1 deletion(-) diff --git a/gui/dialogs/environment-settings.xml b/gui/dialogs/environment-settings.xml index d066cbd71..e0c797315 100644 --- a/gui/dialogs/environment-settings.xml +++ b/gui/dialogs/environment-settings.xml @@ -148,6 +148,9 @@ + + /sim/rendering/shaders/skydome + left 3 @@ -155,6 +158,9 @@ + + /sim/rendering/shaders/skydome + right 3 @@ -162,6 +168,9 @@ + + /sim/rendering/shaders/skydome + snow-thickness 3 2 @@ -176,6 +185,9 @@ + + /sim/rendering/shaders/skydome + left 3 @@ -183,6 +195,9 @@ + + /sim/rendering/shaders/skydome + left 4 @@ -190,6 +205,9 @@ + + /sim/rendering/shaders/skydome + right 4 @@ -197,6 +215,9 @@ + + /sim/rendering/shaders/skydome + dust-level 4 2 @@ -211,6 +232,9 @@ + + /sim/rendering/shaders/skydome + left 4 @@ -218,6 +242,9 @@ + + /sim/rendering/shaders/skydome + left 5 @@ -225,6 +252,9 @@ + + /sim/rendering/shaders/skydome + right 5 @@ -232,6 +262,9 @@ + + /sim/rendering/shaders/skydome + wetness 5 2 @@ -246,6 +279,9 @@ + + /sim/rendering/shaders/skydome + left 5 @@ -254,6 +290,9 @@ + + /sim/rendering/shaders/skydome + left 6 @@ -261,6 +300,9 @@ + + /sim/rendering/shaders/skydome + right 6 @@ -268,6 +310,9 @@ + + /sim/rendering/shaders/skydome + lichen-level 6 2 @@ -282,6 +327,9 @@ + + /sim/rendering/shaders/skydome + left 6 @@ -290,13 +338,19 @@ - + + /sim/rendering/shaders/skydome + + left 7 0 + + /sim/rendering/shaders/skydome + right 7 @@ -304,6 +358,9 @@ + + /sim/rendering/shaders/skydome + season 7 2 @@ -318,6 +375,9 @@ + + /sim/rendering/shaders/skydome + left 7 From 2f01deb6bdc6ae220aa81a704b4cf323a3dd0235 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Tue, 9 Apr 2013 09:41:27 +0300 Subject: [PATCH 03/17] Advanced Weather update - new cloud placement algorithms part I --- Nasal/local_weather/cloud_definitions.nas | 120 ++- .../cloud_placement_lowlevel.nas | 184 ++++ Nasal/local_weather/local_weather.nas | 18 +- Nasal/local_weather/weather_dynamics.nas | 6 +- Nasal/local_weather/weather_tiles.nas | 871 +++++++++++++++--- 5 files changed, 1056 insertions(+), 143 deletions(-) diff --git a/Nasal/local_weather/cloud_definitions.nas b/Nasal/local_weather/cloud_definitions.nas index e9e0a217a..1daf7859b 100644 --- a/Nasal/local_weather/cloud_definitions.nas +++ b/Nasal/local_weather/cloud_definitions.nas @@ -384,13 +384,13 @@ else if (type == "Altocumulus"){ #characterize the cloud cloudAssembly.bottom_shade = 0.7; - cloudAssembly.n_sprites = 10; - cloudAssembly.min_width = 400.0 * mult; - cloudAssembly.max_width = 700.0 * mult; + cloudAssembly.n_sprites = 6; + cloudAssembly.min_width = 40.0 * mult; + cloudAssembly.max_width = 600.0 * mult; cloudAssembly.min_height = 400.0 * mult; - cloudAssembly.max_height = 700.0 * mult; - cloudAssembly.min_cloud_width = 1200 * mult * mult; - cloudAssembly.min_cloud_height = 1200 * mult * mult; + cloudAssembly.max_height = 600.0 * mult; + cloudAssembly.min_cloud_width = 1000 * mult * mult; + cloudAssembly.min_cloud_height = 1000 * mult * mult; cloudAssembly.z_scale = 0.8; #signal that new routines are used @@ -424,16 +424,15 @@ else if (type == "Stratus (structured)"){ #signal that new routines are used path = "new"; - } -else if (type == "Altocumulus perlucidus"){ - - # new code + +else if (type == "Stratus structured CS"){ + cloudAssembly = local_weather.cloud.new(type, subtype); var mult = 1.0; - if (subtype == "small") {mult = 0.7;} - else {mult = 1.0;} + + mult = mult * local_weather.cloud_size_scale; # characterize the basic texture sheet cloudAssembly.texture_sheet = "/Models/Weather/altocumulus_sheet1.rgb"; @@ -441,7 +440,36 @@ else if (type == "Altocumulus perlucidus"){ cloudAssembly.num_tex_y = 3; #characterize the cloud - cloudAssembly.bottom_shade = 0.8; + cloudAssembly.bottom_shade = 0.4; + cloudAssembly.n_sprites = 6; + cloudAssembly.min_width = 1000.0 * mult; + cloudAssembly.max_width = 1000.0 * mult; + cloudAssembly.min_height = 1000.0 * mult; + cloudAssembly.max_height = 1000.0 * mult; + cloudAssembly.min_cloud_width = 1305 * mult; + cloudAssembly.min_cloud_height = 1305.0 * mult; + cloudAssembly.z_scale = 0.3; + + #signal that new routines are used + path = "new"; + } + +else if (type == "Altocumulus perlucidus"){ + + # new code + cloudAssembly = local_weather.cloud.new(type, subtype); + + var mult = 1.0; + if (subtype == "small") {mult = 0.7;} + else if (subtype == "huge") {mult = 1.5;} + + # characterize the basic texture sheet + cloudAssembly.texture_sheet = "/Models/Weather/altocumulus_sheet1.rgb"; + cloudAssembly.num_tex_x = 3; + cloudAssembly.num_tex_y = 3; + + #characterize the cloud + cloudAssembly.bottom_shade = 0.7; cloudAssembly.n_sprites = 25; cloudAssembly.min_width = 1700.0 * mult; cloudAssembly.max_width = 2500.0 * mult; @@ -508,7 +536,7 @@ else if (type == "Cirrocumulus (cloudlet)") { var mult = 1.0; if (subtype == "small") {mult = 0.6;} - else {mult = 1.0;} + else if (subtype == "huge") {mult = 1.5;} # characterize the basic texture sheet cloudAssembly.texture_sheet = "/Models/Weather/cirrocumulus_sheet1.rgb"; @@ -527,9 +555,6 @@ else if (type == "Cirrocumulus (cloudlet)") { cloudAssembly.z_scale = 0.3; path = "new"; - - - } else if (type == "Cirrocumulus (new)") { @@ -537,7 +562,7 @@ else if (type == "Cirrocumulus (new)") { var mult = 1.0; if (subtype == "small") {mult = 0.7;} - else {mult = 1.0;} + else {mult = 1.3;} # characterize the basic texture sheet cloudAssembly.texture_sheet = "/Models/Weather/cirrocumulus_sheet1.rgb"; @@ -559,6 +584,36 @@ else if (type == "Cirrocumulus (new)") { path = "new"; } +else if (type == "Fogpatch") { + + cloudAssembly = local_weather.cloud.new(type, subtype); + + var mult = 1.0; + if (subtype == "small") {mult = 0.7;} + else {mult = 1.0;} + + mult = mult * local_weather.cloud_size_scale; + + # characterize the basic texture sheet + cloudAssembly.texture_sheet = "/Models/Weather/fogpatch_sheet1.rgb"; + cloudAssembly.num_tex_x = 1; + cloudAssembly.num_tex_y = 1; + + #characterize the cloud + cloudAssembly.bottom_shade = 1.0; + cloudAssembly.n_sprites = 1; + cloudAssembly.min_width = 300.0 * mult; + cloudAssembly.max_width = 300.0 * mult; + cloudAssembly.min_height = 300.0 * mult; + cloudAssembly.max_height = 300.0 * mult; + cloudAssembly.min_cloud_width = 305.0 * mult; + cloudAssembly.min_cloud_height = 305.0 * mult; + cloudAssembly.z_scale = 0.5; + + #signal that new routines are used + path = "new"; + } + else if (type == "Nimbus") { cloudAssembly = local_weather.cloud.new(type, subtype); @@ -698,6 +753,35 @@ else if (type == "Cirrostratus") { path = "new"; } +else if (type == "Cirrostratus (small)") { + + cloudAssembly = local_weather.cloud.new(type, subtype); + + var mult = 1.0; + if (subtype == "small") {mult = 0.45;} + else {mult = 0.7;} + + # characterize the basic texture sheet + cloudAssembly.texture_sheet = "/Models/Weather/cirrostratus_sheet1.rgb"; + cloudAssembly.num_tex_x = 2; + cloudAssembly.num_tex_y = 2; + + #characterize the cloud + cloudAssembly.bottom_shade = 1.0; + cloudAssembly.n_sprites = 2; + cloudAssembly.min_width = 3500.0 * mult; + cloudAssembly.max_width = 4000.0 * mult; + cloudAssembly.min_height = 3500.0 * mult; + cloudAssembly.max_height = 4000.0 * mult; + cloudAssembly.min_cloud_width = 4500.0 * mult; + cloudAssembly.min_cloud_height = 4500.0 * mult; + cloudAssembly.z_scale = 0.5; + + #signal that new routines are used + path = "new"; + + } + else if (type == "Fog (thin)") { if (subtype == "small") { if (rn > 0.8) {path = "Models/Weather/stratus_thin1.xml";} diff --git a/Nasal/local_weather/cloud_placement_lowlevel.nas b/Nasal/local_weather/cloud_placement_lowlevel.nas index 5773994a7..bbf9554e1 100644 --- a/Nasal/local_weather/cloud_placement_lowlevel.nas +++ b/Nasal/local_weather/cloud_placement_lowlevel.nas @@ -80,6 +80,190 @@ for (var i=0; i 0.7) + { + flag = 1; + path = select_cloud_model(arg.type,"large") + } + else if (comp > 0.4) + { + flag = 1; + path = select_cloud_model(arg.type,"small") + } + + var lat = arg.blat + m_to_lat * (y * math.cos(arg.dir) - x * math.sin(arg.dir)); + var lon = arg.blon + m_to_lon * (x * math.cos(arg.dir) + y * math.sin(arg.dir)); + + var alt = arg.balt + arg.alt_var * 2 * (rand() - 0.5); + + if (flag > 0) + {create_cloud_vec(path, lat, lon, alt, 0.0); counter = counter +1;} + } + + } + print("Cloud count: ",counter); + +} + + +########################################################### +# place a stick bundle pattern +########################################################### + +var sgn = func (x) { + +if (x<0.0) {return -1.0;} +else {return 1.0;} +} + +var create_stick_bundle = func (arg) { + +var path = "Models/Weather/blank.ac"; +var base_size_scale = local_weather.cloud_size_scale; + +for (var i = 0; i 0.888) +# rn = 0.01; + +if (rn > 0.916) { # cloud scenario 1: weak cumulus development and blue thermals @@ -237,21 +242,22 @@ if (rn > 0.888) # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, 25000.0, 30000.0, 0.95, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.777) +else if (rn > 0.833) { # cloud scenario 2: some Cirrocumulus patches strength = rand() * 0.03; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_2_8_cirrocumulus(blat, blon, alt + alt_offset + 5000.0, alpha); - + #create_2_8_cirrocumulus(blat, blon, alt + alt_offset + 5000.0, alpha); + create_1_8_alttstratus_domains(blat, blon, alt + alt_offset + 5000.0, alpha); + create_2_8_cirrus(blat, blon, alt + alt_offset + 35000.0, alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.1, alt+alt_offset +30000.0, alt+alt_offset + 35000.0, 0.95, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.666) +else if (rn > 0.75) { # cloud scenario 3: Cirrostratus undulatus over weak cumulus @@ -264,19 +270,22 @@ else if (rn > 0.666) local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.15, alt+alt_offset +28000.0, alt+alt_offset + 32000.0, 0.95, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.555) +else if (rn > 0.666) { - # cloud scenario 4: Cirrostratus undulatus streak + # cloud scenario 4: Cirrocumulus mackerel sky strength = rand() * 0.03; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_1_8_cirrostratus_undulatus(blat, blon, alt + alt_offset + 32000.0, alpha); - + ##create_1_8_cirrostratus_undulatus(blat, blon, alt + alt_offset + 32000.0, alpha); + create_1_8_cirrocumulus_mackerel(blat, blon, alt + alt_offset + 32000.0, alpha); + #create_4_8_cirrus_bundle(blat, blon, alt + alt_offset + 32000.0, alpha); + + # and specify the atmosphere - local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.15, alt+alt_offset +28000.0, alt+alt_offset + 32000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.25, alt+alt_offset +28000.0, alt+alt_offset + 32000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.444) +else if (rn > 0.5833) { # cloud scenario 5: Cirrus @@ -291,25 +300,25 @@ else if (rn > 0.444) # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +28000.0, alt+alt_offset + 33000.0, 0.95, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.333) +else if (rn > 0.5) { # cloud scenario 6: strong Cirrus cover create_4_8_cirrus(blat, blon, alt + alt_offset + 35000.0, alpha); local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +28000.0, alt+alt_offset + 33000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.222) +else if (rn > 0.25) { # cloud scenario 7: clear local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +28000.0, alt+alt_offset + 33000.0, 1.0, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.111) +else if (rn > 0.166) { # cloud scenario 8: Stratiform hazy clouds local_weather.top_shade = 0.8; - create_2_8_alttstratus(blat, blon, alt+alt_offset, alpha); + create_2_8_alttstratus_domains(blat, blon, alt+alt_offset, alpha); local_weather.top_shade = 0.9; create_4_8_tstratus_undulatus(blat, blon, alt+alt_offset + 4000, alpha); @@ -317,17 +326,30 @@ else if (rn > 0.111) local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.25, alt+alt_offset +24000.0, alt+alt_offset + 26000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.0) +else if (rn > 0.0833) { # cloud scenario 9: Cirrocumulus - if (rand() > 0.7) # this is very expensive, so don't do it for every tile - {create_2_8_cirrocumulus_patches(blat, blon, alt + alt_offset + 26000.0, alpha);} - else - {create_2_8_cirrocumulus(blat, blon, alt + alt_offset + 26000.0, alpha);} + if (rand() > 0.4) # this is very expensive, so don't do it for every tile + {create_2_8_cirrocumulus_domains(blat, blon, alt + alt_offset + 26000.0, alpha);} + #else + # {create_2_8_cirrocumulus(blat, blon, alt + alt_offset + 26000.0, alpha);} # and specify the atmosphere - local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.2, alt+alt_offset +24000.0, alt+alt_offset + 26000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.2, alt+alt_offset +24000.0, alt+alt_offset + 26000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); + + } +else + { + # cloud scenario 10: amorphous Cirrostratus + + strength = rand() * 0.03; + local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); + + create_4_8_cirrus_bundle(blat, blon, alt + alt_offset + 32000.0, alpha); + + # and specify the atmosphere + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.45, alt+alt_offset +28000.0, alt+alt_offset + 32000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); } @@ -396,9 +418,16 @@ if (rand() < small_scale_persistence) else {rnd_store = rn;} -# rn = 0.1; +# daily modulation - layers are more pronounced during morning and evening and dissolve during the day + +var t = getprop("sim/time/utc/day-seconds"); +t = t + getprop("sim/time/local-offset"); +var sec_to_rad = 2.0 * math.pi/86400; +var t_factor1 = 0.5 * (1.0-math.cos((t * sec_to_rad))); + +#rn = 0.01; -if (rn > 0.875) +if (rn > 0.9) { # cloud scenario 1: possible Cirrus over Cumulus strength = 0.2 + rand() * 0.4; @@ -423,20 +452,21 @@ if (rn > 0.875) local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +28000.0, alt+alt_offset + 30000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.75) +else if (rn > 0.8) { # cloud scenario 2: Cirrostratus over weak Cumulus strength = 0.2 + rand() * 0.2; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_2_8_cirrostratus(blat, blon, alt+alt_offset+25000.0, alpha); + #create_2_8_cirrostratus(blat, blon, alt+alt_offset+25000.0, alpha); + create_2_8_cirrostratus_mackerel(blat, blon, alt+alt_offset+25000.0, alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.2, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.625) +else if (rn > 0.7) { # cloud scenario 3: Cirrocumulus sheet over Cumulus @@ -455,19 +485,26 @@ else if (rn > 0.625) local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 24000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.5) +else if (rn > 0.6) { # cloud scenario 4: Cirrostratus undulatus over weak Cumulus strength = 0.15 + rand() * 0.15; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_4_8_cirrostratus_undulatus(blat, blon, alt + alt_offset + 25000.0, alpha); + if (rand()>0.5) + { + create_4_8_cirrostratus_undulatus(blat, blon, alt + alt_offset + 25000.0, alpha); + } + else + { + create_4_8_cirrus_bundle(blat, blon, alt + alt_offset + 25000.0, alpha); + } # and specify the atmosphere - local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.15, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.35, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.375) +else if (rn > 0.5) { # cloud scenario 5: some scattered Altocumuli over Cumulus @@ -481,42 +518,71 @@ else if (rn > 0.375) # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.25) +else if (rn > 0.4) { # cloud scenario 6: Cirrocumulus over Cumulus strength = 0.2 + rand() * 0.1; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - if (rand() > 0.8) # this is very expensive, so don't do it for every tile - {create_2_8_cirrocumulus_patches(blat, blon, alt + alt_offset + 26000.0, alpha);} + if (rand() > 0.6) # this is very expensive, so don't do it for every tile + {create_2_8_cirrocumulus_domains(blat, blon, alt + alt_offset + 26000.0, alpha);} else - {create_2_8_cirrocumulus(blat, blon, alt + alt_offset + 26000.0, alpha);} + {create_1_8_alttstratus_domains(blat, blon, alt + alt_offset + 26000.0, alpha);} # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.3, alt+alt_offset +24000.0, alt+alt_offset + 26000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.125) +else if (rn > 0.3) { # cloud scenario 7: just Cumulus - strength = 0.3 + rand() * 0.1; + strength = 0.3 + rand() * 0.2; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); # and specify the atmosphere - local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.0) +else if (rn > 0.2) { # cloud scenario 8: Altocumulus Perlucidus over Cumulus strength = 0.2 + rand() * 0.1; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - - create_2_8_altocumulus_perlucidus(blat, blon, alt + alt_offset + 12000.0, alpha); + + + if (rand()>0.5* t_factor1) + {create_2_8_altocumulus_perlucidus_domains(blat, blon, alt + alt_offset + 12000.0, alpha);} # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); } +else if (rn > 0.1) + { + # cloud scenario 9: Thin Stratus over Cumulus + + strength = 0.2 + rand() * 0.1; + local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); + + if (rand()>0.5* t_factor1) + {create_2_8_alttstratus_domains(blat, blon, alt + alt_offset + 12000.0, alpha);} + + # and specify the atmosphere + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); + } +else + { + # cloud scenario 10: Mackerel Cirrocumulus + + strength = 0.3 + rand() * 0.1; + local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); + + if(rand() > 0.6) + {create_1_8_cirrocumulus_mackerel(blat, blon, alt + alt_offset + 20000.0, alpha);} + + # and specify the atmosphere + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.9, alt+alt_offset, alt+alt_offset + 2500.0); + } + # store convective altitude and strength @@ -584,7 +650,7 @@ else {rnd_store = rn;} -# rn = 0.05; +#rn = 0.85; if (rn > 0.9) { @@ -592,10 +658,11 @@ if (rn > 0.9) strength = 0.1 + rand() * 0.1; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - x = 2.0 * (rand()-0.5) * 5000; - y = 2.0 * (rand()-0.5) * 5000; - local_weather.create_streak("Altocumulus",blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 12000.0+alt+alt_offset,1500.0,30,1000.0,0.2,1200.0,30,1000.0,0.2,1200.0,alpha ,1.0); - + #x = 2.0 * (rand()-0.5) * 5000; + #y = 2.0 * (rand()-0.5) * 5000; + #local_weather.create_streak("Altocumulus",blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 12000.0+alt+alt_offset,1500.0,30,1000.0,0.2,1200.0,30,1000.0,0.2,1200.0,alpha ,1.0); + + create_2_8_altocumulus_domains(blat, blon, alt+alt_offset +12000.0, alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); @@ -603,17 +670,22 @@ if (rn > 0.9) } else if (rn > 0.8) { - # cloud scenario 2: Altocumulus streaks - strength = 0.15 + rand() * 0.2; + # cloud scenario 2: Perlucidus variations + strength = 0.1 + rand() * 0.15; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - x = 2.0 * (rand()-0.5) * 10000; - y = 2.0 * (rand()-0.5) * 10000; - local_weather.create_streak("Altocumulus",blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 12000.0+alt+alt_offset,1500.0,25,700.0,0.2,800.0,10,700.0,0.2,800.0,alpha ,1.4); - x = 2.0 * (rand()-0.5) * 10000; - y = 2.0 * (rand()-0.5) * 10000; - local_weather.create_streak("Altocumulus",blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 12000.0+alt+alt_offset,1500.0,22,750.0,0.2,1000.0,8,750.0,0.2,1000.0,alpha ,1.1); + #x = 2.0 * (rand()-0.5) * 10000; + #y = 2.0 * (rand()-0.5) * 10000; + #local_weather.create_streak("Altocumulus",blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 12000.0+alt+alt_offset,1500.0,25,700.0,0.2,800.0,10,700.0,0.2,800.0,alpha ,1.4); + #x = 2.0 * (rand()-0.5) * 10000; + #y = 2.0 * (rand()-0.5) * 10000; + #local_weather.create_streak("Altocumulus",blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 12000.0+alt+alt_offset,1500.0,22,750.0,0.2,1000.0,8,750.0,0.2,1000.0,alpha ,1.1); + if (rand() > 0.6) + {create_2_8_perlucidus_mackerel(blat, blon, alt+alt_offset +12000.0, alpha);} + else + {create_2_8_sstratus_hires_bundle(blat, blon, alt+alt_offset +12000.0, alpha);} + # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.85, alt+alt_offset, alt+alt_offset + 2500.0); @@ -638,23 +710,26 @@ else if (rn > 0.6) strength = 0.7 + rand() * 0.3; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_4_8_alttstratus_streaks(blat, blon, alt+alt_offset +10000.0, alpha); + #create_4_8_alttstratus_streaks(blat, blon, alt+alt_offset +10000.0, alpha); + create_4_8_alttstratus_domains(blat, blon, alt+alt_offset +10000.0, alpha); # and specify the atmosphere - local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +10000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); } else if (rn > 0.5) { - # cloud scenario 5: scattered Stratus + # cloud scenario 5: scattered Altocumulus perlucidus strength = 0.4 + rand() * 0.2; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); var size_offset = 0.5 * m_to_ft * local_weather.cloud_vertical_size_map["Stratus_structured"]; - local_weather.create_streak("Stratus (structured)",blat, blon, alt+6000.0+alt_offset+size_offset,1000.0,18,0.0,0.3,20000.0,18,0.0,0.3,20000.0,0.0,1.0); - + #local_weather.create_streak("Stratus (structured)",blat, blon, alt+6000.0+alt_offset+size_offset,1000.0,18,0.0,0.3,20000.0,18,0.0,0.3,20000.0,0.0,1.0); + create_4_8_sstratus_domains(blat, blon, alt+alt_offset+size_offset +6000.0, alpha); + #create_2_8_sstratus_hires_bundle(blat, blon, alt+alt_offset+size_offset +6000.0, alpha); + # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.2, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); @@ -689,10 +764,11 @@ else if (rn > 0.3) strength = 0.05 + rand() * 0.1; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_4_8_cirrocumulus_streaks(blat, blon, alt + 6000.0 + alt_offset, alpha); - + #create_4_8_cirrocumulus_streaks(blat, blon, alt + 6000.0 + alt_offset, alpha); + create_4_8_alttstratus_domains(blat, blon, alt + 6000.0 + alt_offset, alpha); + # and specify the atmosphere - local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.05, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.25, alt+alt_offset +6000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); } else if (rn > 0.2) @@ -801,9 +877,9 @@ if (rand() < small_scale_persistence) else {rnd_store = rn;} +#rn = 0.01; - -if (rn > 0.888) +if (rn > 0.9) { # cloud scenario 1: low Stratocumulus, thin streaks above @@ -812,82 +888,88 @@ if (rn > 0.888) create_detailed_stratocumulus_bank(blat, blon, alt+alt_offset,alpha); - create_4_8_alttstratus_streaks(blat, blon, alt+alt_offset+4000.0,alpha); + create_2_8_alttstratus_domains(blat, blon, alt+alt_offset+4000.0,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.75, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.777) +else if (rn > 0.8) { # cloud scenario 2: weak Cumulus, Stratus undulatus above strength = 0.2 + rand() * 0.2; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_6_8_tstratus_undulatus(blat, blon, alt+alt_offset+4000.0,alpha); + #create_6_8_tstratus_undulatus(blat, blon, alt+alt_offset+4000.0,alpha); + create_6_8_tstratus_mackerel(blat, blon, alt+alt_offset+4000.0,alpha); - create_2_8_alttstratus(blat, blon, alt+alt_offset+7000.0,alpha); + create_2_8_alttstratus_domains(blat, blon, alt+alt_offset+7000.0,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.8, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.666) +else if (rn > 0.7) { # cloud scenario 3: Stratocumulus banks with patches above create_detailed_stratocumulus_bank(blat, blon, alt+alt_offset,alpha); create_detailed_small_stratocumulus_bank(blat, blon, alt+alt_offset,alpha); - create_4_8_alttstratus_patches(blat, blon, alt+alt_offset+4000.0,alpha); + create_4_8_alttstratus_domains(blat, blon, alt+alt_offset+4000.0,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.0, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.7, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.555) +else if (rn > 0.6) { # cloud scenario 4: structured Stratus alt = alt + local_weather.cloud_vertical_size_map["Stratus"] * 0.5 * m_to_ft; create_4_8_sstratus_patches(blat, blon, alt+alt_offset,alpha); - create_2_8_alttstratus(blat, blon, alt+alt_offset+7000.0,alpha); + create_2_8_alttstratus_domains(blat, blon, alt+alt_offset+7000.0,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.25, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.7, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.444) +else if (rn > 0.5) { # cloud scenario 5: Stratus blending with Cumulus with Cirrocumulus above strength = 0.1 + rand() * 0.1; local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - create_4_8_tstratus_patches(blat, blon, alt+alt_offset,alpha); - - create_4_8_cirrocumulus_undulatus(blat, blon, alt+alt_offset + 12000.0,alpha); + #create_4_8_tstratus_patches(blat, blon, alt+alt_offset,alpha); + create_4_8_tstratus_domains(blat, blon, alt+alt_offset,alpha); + #create_4_8_cirrocumulus_undulatus(blat, blon, alt+alt_offset + 12000.0,alpha); + create_2_8_perlucidus_mackerel(blat, blon, alt+alt_offset + 12000.0,alpha); + # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.15, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.75, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.333) +else if (rn > 0.4) { # cloud scenario 6: small Stratocumulus banks create_detailed_small_stratocumulus_bank(blat, blon, alt+alt_offset,alpha); create_detailed_small_stratocumulus_bank(blat, blon, alt+alt_offset,alpha); - create_4_8_tstratus_patches(blat, blon, alt+alt_offset,alpha); - + #create_4_8_tstratus_patches(blat, blon, alt+alt_offset,alpha); + create_4_8_tstratus_domains(blat, blon, alt+alt_offset,alpha); + create_2_8_cirrostratus(blat, blon, alt+alt_offset + 25000.0,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.3, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.75, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.222) +else if (rn > 0.3) { # cloud scenario 7: blended structured and unstructured Stratiform clouds - create_4_8_tstratus_patches(blat, blon, alt+alt_offset,alpha); + #create_4_8_tstratus_patches(blat, blon, alt+alt_offset,alpha); + create_4_8_tstratus_domains(blat, blon, alt+alt_offset,alpha); + create_4_8_sstratus_patches(blat, blon, alt+alt_offset,alpha); create_2_8_cirrostratus(blat, blon, alt+alt_offset + 25000.0,alpha); @@ -895,7 +977,7 @@ else if (rn > 0.222) # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.2, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.75, alt+alt_offset, alt+alt_offset + 2500.0); } -else if (rn > 0.111) +else if (rn > 0.2) { # cloud scenario 8: Cumulus alleys beneath a high dense stratus cover @@ -903,12 +985,13 @@ else if (rn > 0.111) create_4_8_cumulus_alleys(blat, blon, alt+ alt_offset, alpha); local_weather.top_shade = 1.0; - create_6_8_tstratus_undulatus(blat, blon, alt+alt_offset + 6000.0,alpha); + #create_6_8_tstratus_undulatus(blat, blon, alt+alt_offset + 6000.0,alpha); + create_6_8_tstratus_mackerel(blat, blon, alt+alt_offset + 6000.0,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.5, alt+alt_offset +5500.0, alt+alt_offset + 6500.0, 0.65, alt+alt_offset + 6000.0, alt+alt_offset + 7500.0); } -else if (rn > 0.0) +else if (rn > 0.1) { # cloud scenario 9: weak Cumulus benath a high dense stratus cover @@ -917,15 +1000,29 @@ else if (rn > 0.0) strength = 0.2 + rand() * 0.2; #local_weather.create_cumosys(blat,blon, alt + alt_offset, get_n(strength), 20000.0); - var n = int(4000 * strength) * 0.2; + var n = int(3000 * strength) * 0.2; local_weather.cumulus_exclusion_layer(blat, blon, alt+alt_offset, n, 20000.0, 20000.0, alpha, 0.3,1.4 , size(elat), elat, elon, erad); local_weather.top_shade = 1.0; create_6_8_stratus(blat, blon, alt+alt_offset + 8000.0,alpha); + create_1_8_cirrus_bundle(blat, blon, alt+alt_offset + 34000.0,alpha); + # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset + 8000.0, vis + 15000.0, 0.7, alt+alt_offset +7500.0, alt+alt_offset + 8500.0, 0.65, alt+alt_offset + 8000.0, alt+alt_offset + 9500.0); } +else + { + # cloud scenario 10: broken structured Stratus cover + + + create_4_8_sstratus_bundle(blat, blon, alt+alt_offset,alpha); + + #create_2_8_cirrostratus(blat, blon, alt+alt_offset + 25000.0,alpha); + + # and specify the atmosphere + local_weather.set_atmosphere_ipoint(blat, blon, vis + 10000.0, alt+alt_offset, vis + 15000.0, 0.2, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.75, alt+alt_offset, alt+alt_offset + 2500.0); + } @@ -1022,7 +1119,9 @@ if (rn > 0.8) local_weather.create_effect_volume(2, blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 9000.0, 5000.0, beta, 0.0, alt + alt_offset, 5000.0, 0.3, -1, -1, -1,0 ,-1); local_weather.create_effect_volume(2, blat+get_lat(x,y,phi), blon+get_lon(x,y,phi), 8000.0, 4000.0, beta, 0.0, alt+alt_offset-300.0, 1500.0, 0.5, -1, -1, -1,0,-1 ); - create_4_8_sstratus_undulatus(blat, blon, alt+alt_offset +3000.0, alpha); + #create_4_8_sstratus_undulatus(blat, blon, alt+alt_offset +3000.0, alpha); + create_4_8_sstratus_bundle(blat, blon, alt+alt_offset +3000.0, alpha); + create_2_8_tstratus(blat, blon, alt+alt_offset +6000.0, alpha); # and specify the atmosphere @@ -1038,7 +1137,7 @@ else if (rn >0.6) create_8_8_stratus(blat, blon, alt+alt_offset,alpha); local_weather.create_effect_volume(3, blat, blon, 18000.0, 18000.0, 0.0, 0.0, 1800.0, 8000.0, -1, -1, -1, -1, 0,-1); local_weather.create_effect_volume(3, blat, blon, 14000.0, 14000.0, 0.0, 0.0, 1500.0, 6000.0, 0.1, -1, -1, -1,0,-1 ); - create_2_8_sstratus(blat, blon, alt+alt_offset+3000,alpha); + create_2_8_sstratus_bundle(blat, blon, alt+alt_offset+3000,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 17000.0, alt+alt_offset, vis + 25000.0, 0.3, alt+alt_offset +15000.0, alt+alt_offset + 20000.0, 0.6, alt+alt_offset, alt+alt_offset + 2500.0); @@ -1052,7 +1151,7 @@ else if (rn >0.4) alt = alt + local_weather.cloud_vertical_size_map["Stratus"] * 0.5 * m_to_ft; create_4_8_stratus(blat, blon, alt+alt_offset,alpha); create_4_8_stratus_patches(blat, blon, alt+alt_offset+3000,alpha); - create_4_8_sstratus_undulatus(blat, blon, alt+alt_offset+6000,alpha); + create_4_8_sstratus_bundle(blat, blon, alt+alt_offset+6000,alpha); create_2_8_tstratus(blat, blon, alt+alt_offset+8000,alpha); # and specify the atmosphere @@ -1065,7 +1164,7 @@ else if (rn >0.2) alt = alt + local_weather.cloud_vertical_size_map["Stratus"] * 0.5 * m_to_ft; create_6_8_stratus(blat, blon, alt+alt_offset,alpha); - create_2_8_sstratus(blat, blon, alt+alt_offset+6000,alpha); + create_2_8_sstratus_bundle(blat, blon, alt+alt_offset+6000,alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 15000.0, alt+alt_offset, vis + 24000.0, 0.2, alt+alt_offset +15000.0, alt+alt_offset + 22000.0, 0.7 - rand() * 0.1, alt+alt_offset, alt+alt_offset + 2500.0); @@ -1344,8 +1443,8 @@ else if (rn > 0.6) var size_offset = 0.5 * m_to_ft * local_weather.cloud_vertical_size_map["Stratus_structured"]; - create_2_8_sstratus_streak(blat, blon, alt+alt_offset + size_offset + 2000.0, alpha); - create_2_8_sstratus_streak(blat, blon, alt+alt_offset + size_offset + 4000.0, alpha); + create_2_8_sstratus_bundle(blat, blon, alt+alt_offset + size_offset + 2000.0, alpha); + create_2_8_sstratus_hires_bundle(blat, blon, alt+alt_offset + size_offset + 4000.0, alpha); # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 1000.0, alt+alt_offset, vis + 3000.0, 0.2, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.75, alt+alt_offset, alt+alt_offset + 2500.0); @@ -1371,8 +1470,9 @@ else if (rn > 0.2) var size_offset = 0.5 * m_to_ft * local_weather.cloud_vertical_size_map["Cirrocumulus"]; - create_4_8_cirrocumulus_undulatus(blat, blon, alt+alt_offset + size_offset + 6000.0, alpha); - + #create_4_8_cirrocumulus_undulatus(blat, blon, alt+alt_offset + size_offset + 6000.0, alpha); + create_2_8_perlucidus_mackerel(blat, blon, alt+alt_offset + size_offset + 6000.0, alpha); + # and specify the atmosphere local_weather.set_atmosphere_ipoint(blat, blon, vis + 1000.0, alt+alt_offset, vis + 3000.0, 0.2, alt+alt_offset +20000.0, alt+alt_offset + 25000.0, 0.72, alt+alt_offset, alt+alt_offset + 2500.0); } @@ -2371,12 +2471,14 @@ for (var i = n; i 0.75) + if (rn > 0.8) {create_4_8_stratus(blat, blon, altitude+metar_alt_offset, alpha);} - else if (rn > 0.5) + else if (rn > 0.6) {create_4_8_stratus_patches(blat, blon, altitude+metar_alt_offset, alpha);} - else if (rn > 0.25) + else if (rn > 0.4) {create_4_8_sstratus_patches(blat, blon, altitude+metar_alt_offset, alpha);} + else if (rn > 0.2) + {create_4_8_sstratus_bundle(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.0) {create_4_8_sstratus_undulatus(blat, blon, altitude+metar_alt_offset, alpha);} } @@ -2386,10 +2488,12 @@ for (var i = n; i 0.5) + if (rn > 0.3) {create_2_8_stratus(blat, blon, altitude+metar_alt_offset, alpha);} - else if (rn > 0.0) - {create_2_8_sstratus(blat, blon, altitude+metar_alt_offset, alpha);} + else if (rn > 0.6) + {create_2_8_sstratus_bundle(blat, blon, altitude+metar_alt_offset, alpha);} + else + {create_2_8_sstratus_hires_bundle(blat, blon, altitude+metar_alt_offset, alpha);} } else { @@ -2409,7 +2513,7 @@ for (var i = n; i 4) { if (altitude < 14000.0) - {create_6_8_tstratus_undulatus(blat, blon, altitude+metar_alt_offset, alpha);} + {create_6_8_tstratus_mackerel(blat, blon, altitude+metar_alt_offset, alpha);} else {create_6_8_cirrostratus(blat, blon, altitude+metar_alt_offset, alpha);} } @@ -2417,9 +2521,9 @@ for (var i = n; i 0.75) - {create_4_8_tstratus_patches(blat, blon, altitude+metar_alt_offset, alpha);} + {create_4_8_tstratus_domains(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.5) - {create_4_8_alttstratus_streaks(blat, blon, altitude+metar_alt_offset, alpha);} + {create_4_8_alttstratus_domains(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.25) {create_4_8_alttstratus_patches(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.0) @@ -2433,11 +2537,11 @@ for (var i = n; i 0.75) {create_2_8_tstratus(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.5) - {create_2_8_sstratus(blat, blon, altitude+metar_alt_offset, alpha);} + {create_2_8_sstratus_bundle(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.25) - {create_2_8_altocumulus_perlucidus(blat, blon, altitude+metar_alt_offset, alpha);} + {create_2_8_altocumulus_perlucidus_domains(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.0) - {create_2_8_alttstratus(blat, blon, altitude+metar_alt_offset, alpha);} + {create_2_8_alttstratus_domains(blat, blon, altitude+metar_alt_offset, alpha);} } else { @@ -2445,9 +2549,9 @@ for (var i = n; i 0.9) {create_2_8_cirrocumulus_patches(blat, blon, altitude+metar_alt_offset, alpha);} if (rn > 0.4) - {create_2_8_cirrocumulus(blat, blon, altitude+metar_alt_offset, alpha);} + {create_1_8_alttstratus_domains(blat, blon, altitude+metar_alt_offset, alpha);} else if (rn > 0.0) - {create_2_8_alttstratus(blat, blon, altitude+metar_alt_offset, alpha);} + {create_2_8_alttstratus_domains(blat, blon, altitude+metar_alt_offset, alpha);} } } @@ -2901,6 +3005,37 @@ if (local_weather.hardcoded_clouds_flag == 1) {alt = alt - local_weather.offset_ local_weather.create_undulatus("Stratus (thin)",lat, lon, alt,300.0,10,4000.0,0.1,400.0,50,800.0,0.1,100.0, 1000.0, alpha,1.0); } +var create_6_8_tstratus_mackerel = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 3000; +var y = 2.0 * (rand()-0.5) * 3000; + +var arg = {}; + +arg.cloud_spacing = 900.0; +arg.undulatus_spacing = 4200.0; +arg.undulatus_slant = 0.4; +arg.undulatus_amplitude = 2000.0; +arg.aspect = 0.5; +arg.Dx = 100.0; +arg.Dy = 100.0; +arg.xsize = 35000.0 + rand() * 10000.0; +arg.ysize = 35000.0 + rand() * 10000.0; +arg.blat = lat + get_lat(x,y,phi); +arg.blon = lon + get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.size_bias = 0.5; +arg.type = "Stratus (thin)"; + +local_weather.create_adv_undulatus(arg); +} + + + var create_6_8_cirrostratus = func (lat, lon, alt, alpha) { if (local_weather.hardcoded_clouds_flag == 1) {alt = alt - local_weather.offset_map["Cirrostratus"];} @@ -2993,7 +3128,36 @@ for (var i=0; i<22; i=i+1) local_weather.create_streak("Stratus (thin)",lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), alt,300.0,m,1000.0,0.2,500.0,n,1000.0,0.2,500.0,alpha+beta,1.0); } +} + +var create_4_8_tstratus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 36000.0; +arg.ysize = 36000.0; +arg.min_domain_size_x = 5000.0; +arg.max_domain_size_x = 24000.0; +arg.min_domain_size_y = 5000.0; +arg.max_domain_size_y = 24000.0; +arg.node_fraction = 0.0; +arg.halo_fraction = 0.4; +arg.n_domains = 12; +arg.n = 30; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Stratus (thin)"; +arg.subtype = "large"; +arg.ntype = "Altocumulus perlucidus"; +arg.nsubtype = "large"; +arg.htype = "Stratus (thin)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); } @@ -3217,7 +3381,9 @@ var tri = 1.0 + 0.4 * rand(); # create_cumulus_alleys = func (blat, blong, balt, alt_var, nx, xoffset, edgex, x_var, ny, yoffset, edgey, y_var, und_strength, direction, tri) -local_weather.create_cumulus_alleys(lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), alt, 0.0, 9, 3500.0,0.2, 500.0, 30 ,1130.0, 0.2, 300.0, 1000.0, alpha,tri); +#local_weather.create_cumulus_alleys(lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), alt, 0.0, 9, 3500.0,0.2, 500.0, 30 ,1130.0, 0.2, 300.0, 1000.0, alpha,tri);#local_weather.create_cumulus_alleys(lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), alt, 0.0, 9, 3500.0,0.2, 500.0, 30 ,1130.0, 0.2, 300.0, 1000.0, alpha,tri); + +local_weather.create_cumulus_alleys(lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), alt, 0.0, 8, 3930.0,0.2, 500.0, 25 ,1350.0, 0.2, 300.0, 1000.0, alpha,tri);#local_weather.create_cumulus_alleys(lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), alt, 0.0, 9, 3500.0,0.2, 500.0, 30 ,1130.0, 0.2, 300.0, 1000.0, alpha,tri); } @@ -3250,6 +3416,387 @@ local_weather.create_streak("Cirrus",lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), } +var create_4_8_sstratus_bundle = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var arg = {}; + +arg.cloud_spacing = 1500.0; +arg.stick_length_min = 6; +arg.stick_length_max = 12; +arg.stick_Dphi_min = 15.0 * math.pi/180.0; +arg.stick_Dphi_max = 55.0 * math.pi/180.0; +arg.Dx = 0.0; +arg.Dy = 0.0; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Stratus structured CS"; + +local_weather.cloud_size_scale = 1.5; + +for (var i=0; i<4; i=i+1) + { + var x = 2.0 * (rand()-0.5) * 15000.0; + var y = 2.0 * (rand()-0.5) * 20000.0; + var rel_size_x = 0.8 + rand() * 0.2; + var rel_size_y = 0.5 + rand() * 0.5; + arg.xsize = 20000.0 * rel_size_x; + arg.ysize = 16000.0 * rel_size_y; + arg.n_sticks = int (20 * rel_size_y); + arg.blat = lat+get_lat(x,y,phi); + arg.blon = lon+get_lon(x,y,phi); + local_weather.create_stick_bundle(arg); + } + +local_weather.cloud_size_scale = 1.0; +} + + +var create_4_8_sstratus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.min_domain_size_x = 10000.0; +arg.max_domain_size_x = 20000.0; +arg.min_domain_size_y = 10000.0; +arg.max_domain_size_y = 20000.0; +arg.node_fraction = 0.0; +arg.halo_fraction = 0.6; +arg.n_domains = 8; +arg.n = 30; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Stratus (structured)"; +arg.subtype = "large"; +arg.ntype = "Altocumulus perlucidus"; +arg.nsubtype = "large"; +arg.htype = "Stratus (structured)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} + +var create_4_8_cirrus_bundle = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 12000; +var y = 2.0 * (rand()-0.5) * 12000; + +var arg = {}; + +arg.cloud_spacing = 1100.0; +arg.n_sticks = 17; +arg.stick_length_min = 16; +arg.stick_length_max = 34; +arg.stick_Dphi_min = 15.0 * math.pi/180.0; +arg.stick_Dphi_max = 45.0 * math.pi/180.0; +arg.Dx = 0.0; +arg.Dy = 250.0; +arg.xsize = 40000.0; +arg.ysize = 40000.0; +arg.blat = lat+get_lat(x,y,phi); +arg.blon = lon+get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Fogpatch"; + +local_weather.cloud_size_scale = 12.0; +local_weather.create_stick_bundle(arg); +local_weather.cloud_size_scale = 1.0; +} + + +var create_4_8_alttstratus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.min_domain_size_x = 6000.0; +arg.max_domain_size_x = 12000.0; +arg.min_domain_size_y = 3000.0; +arg.max_domain_size_y = 6000.0; +arg.node_fraction = 0.1; +arg.halo_fraction = 0.7; +arg.n_domains = 40; +arg.n = 30; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Cirrocumulus (cloudlet)"; +arg.subtype = "large"; +arg.ntype = "Stratus (thin)"; +arg.nsubtype = "small"; +arg.htype = "Cirrocumulus (cloudlet)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} + + +var create_2_8_sstratus_bundle = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 12000; +var y = 2.0 * (rand()-0.5) * 12000; + +var arg = {}; + +arg.cloud_spacing = 1500.0; +arg.n_sticks = 30; +arg.stick_length_min = 6; +arg.stick_length_max = 12; +arg.stick_Dphi_min = 15.0 * math.pi/180.0; +arg.stick_Dphi_max = 55.0 * math.pi/180.0; +arg.Dx = 0.0; +arg.Dy = 0.0; +arg.xsize = 20000.0 + rand() * 2000.0; +arg.ysize = 8000.0 + rand() * 8000.0; +arg.blat = lat+get_lat(x,y,phi); +arg.blon = lon+get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Stratus structured CS"; + +local_weather.cloud_size_scale = 1.5; +local_weather.create_stick_bundle(arg); +local_weather.cloud_size_scale = 1.0; +} + +var create_2_8_sstratus_hires_bundle = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 20000; +var y = 2.0 * (rand()-0.5) * 20000; + +var arg = {}; + +arg.cloud_spacing = 500.0; +arg.n_sticks = 40; +arg.stick_length_min = 8; +arg.stick_length_max = 16; +arg.stick_Dphi_min = 15.0 * math.pi/180.0; +arg.stick_Dphi_max = 55.0 * math.pi/180.0; +arg.Dx = 200.0; +arg.Dy = 200.0; +arg.xsize = 12000.0 + rand() * 2000.0; +arg.ysize = 6000.0 + rand() * 5000.0; +arg.blat = lat+get_lat(x,y,phi); +arg.blon = lon+get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Stratus structured CS"; + +local_weather.cloud_size_scale = 0.7; +local_weather.create_stick_bundle(arg); + +var x = 2.0 * (rand()-0.5) * 20000; +var y = 2.0 * (rand()-0.5) * 20000; +arg.blat = lat+get_lat(x,y,phi); +arg.blon = lon+get_lon(x,y,phi); +arg.xsize = 12000.0 + rand() * 2000.0; +arg.ysize = 6000.0 + rand() * 5000.0; +local_weather.create_stick_bundle(arg); + +local_weather.cloud_size_scale = 1.0; +} + +var create_2_8_cirrostratus_mackerel = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 12000; +var y = 2.0 * (rand()-0.5) * 12000; + +var arg = {}; + +arg.cloud_spacing = 250.0; +arg.undulatus_spacing = 2400.0; +arg.undulatus_slant = 0.0; +arg.undulatus_amplitude = 800.0; +arg.aspect = 0.7; +arg.Dx = 100.0; +arg.Dy = 0.0; +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.blat = lat + get_lat(x,y,phi); +arg.blon = lon + get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.size_bias = 0.0; +arg.type = "Cirrostratus (small)"; + +local_weather.create_adv_undulatus(arg); +} + +var create_2_8_perlucidus_mackerel = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 12000; +var y = 2.0 * (rand()-0.5) * 12000; + +var arg = {}; + +arg.cloud_spacing = 150.0; +arg.undulatus_spacing = 2100.0; +arg.undulatus_slant = 30.0 + rand() * 40; +arg.undulatus_amplitude = 200.0 + rand() * 100.0; +arg.aspect = 0.7; +arg.Dx = 100.0; +arg.Dy = 0.0; +arg.xsize = 22000.0 + rand() * 10000.0; +arg.ysize = 32000.0 + rand() * 10000.0; +arg.blat = lat + get_lat(x,y,phi); +arg.blon = lon + get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.size_bias = 0.0; +arg.type = "Cirrocumulus (cloudlet)"; + +local_weather.create_adv_undulatus(arg); +} + + +var create_2_8_alttstratus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.min_domain_size_x = 6000.0; +arg.max_domain_size_x = 12000.0; +arg.min_domain_size_y = 3000.0; +arg.max_domain_size_y = 6000.0; +arg.node_fraction = 0.1; +arg.halo_fraction = 0.7; +arg.n_domains = 20; +arg.n = 30; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Cirrocumulus (cloudlet)"; +arg.subtype = "large"; +arg.ntype = "Stratus (thin)"; +arg.nsubtype = "small"; +arg.htype = "Cirrocumulus (cloudlet)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} + + + +var create_2_8_altocumulus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.min_domain_size_x = 10000.0; +arg.max_domain_size_x = 20000.0; +arg.min_domain_size_y = 10000.0; +arg.max_domain_size_y = 10000.0; +arg.node_fraction = 0.0; +arg.halo_fraction = 0.6; +arg.n_domains = 15; +arg.n = 60; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Altocumulus"; +arg.subtype = "large"; +arg.ntype = "Altocumulus"; +arg.nsubtype = "large"; +arg.htype = "Altocumulus"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} + + + + +var create_2_8_altocumulus_perlucidus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.min_domain_size_x = 15000.0; +arg.max_domain_size_x = 22000.0; +arg.min_domain_size_y = 6000.0; +arg.max_domain_size_y = 8000.0; +arg.node_fraction = 0.1; +arg.halo_fraction = 0.6; +arg.n_domains = 14; +arg.n = 30; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Altocumulus perlucidus"; +arg.subtype = "small"; +arg.ntype = "Altocumulus perlucidus"; +arg.nsubtype = "large"; +arg.htype = "Cirrocumulus (cloudlet)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} + +var create_2_8_cirrocumulus_domains = func (lat, lon, alt, alpha) { + +var arg = {}; + +arg.xsize = 25000.0; +arg.ysize = 25000.0; +arg.min_domain_size_x = 8000.0; +arg.max_domain_size_x = 10000.0; +arg.min_domain_size_y = 3000.0; +arg.max_domain_size_y = 5000.0; +arg.node_fraction = 0.0; +arg.halo_fraction = 0.7; +arg.n_domains = 10; +arg.n = 200; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Cirrocumulus (new)"; +arg.subtype = "large"; +arg.ntype = "Cirrocumulus (new)"; +arg.nsubtype = "large"; +arg.htype = "Cirrocumulus (new)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} + + var create_2_8_stratus = func (lat, lon, alt, alpha) { if (local_weather.hardcoded_clouds_flag == 1) {alt = alt - local_weather.offset_map["Stratus"];} @@ -3415,7 +3962,66 @@ for (var i=0; i<2; i=i+1) } } +var create_1_8_cirrocumulus_mackerel = func (lat, lon, alt, alpha) { +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 12000; +var y = 2.0 * (rand()-0.5) * 12000; + +var arg = {}; + +arg.cloud_spacing = 40.0; +arg.undulatus_spacing = 320.0; +arg.undulatus_slant = 20.0; +arg.undulatus_amplitude = 100.0; +arg.aspect = 0.7; +arg.Dx = 30.0; +arg.Dy = 5.0; +arg.xsize = 7000.0 + rand() * 5000.0; +arg.ysize = 12000.0 + rand() * 4000.0; +arg.blat = lat+get_lat(x,y,phi); +arg.blon = lon+get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.size_bias = 0.0; +arg.type = "Cirrocumulus (new)"; +#arg.type = "Fogpatch"; + +local_weather.create_adv_undulatus(arg); +} + +var create_1_8_alttstratus_domains = func (lat, lon, alt, alpha) { + +if (local_weather.hardcoded_clouds_flag == 1) {alt = alt - 300.0;} + +var arg = {}; + +arg.xsize = 35000.0; +arg.ysize = 35000.0; +arg.min_domain_size_x = 6000.0; +arg.max_domain_size_x = 12000.0; +arg.min_domain_size_y = 3000.0; +arg.max_domain_size_y = 6000.0; +arg.node_fraction = 0.1; +arg.halo_fraction = 0.7; +arg.n_domains = 7; +arg.n = 30; +arg.blat = lat; +arg.blon = lon; +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Cirrocumulus (cloudlet)"; +arg.subtype = "large"; +arg.ntype = "Stratus (thin)"; +arg.nsubtype = "small"; +arg.htype = "Cirrocumulus (cloudlet)"; +arg.hsubtype = "small"; + +local_weather.create_domains(arg); +} @@ -3470,6 +4076,39 @@ local_weather.create_streak("Cirrus",lat+get_lat(x,y,phi), lon+get_lon(x,y,phi), } +var create_1_8_cirrus_bundle = func (lat, lon, alt, alpha) { + +var phi = alpha * math.pi/180.0; + +var x = 2.0 * (rand()-0.5) * 12000; +var y = 2.0 * (rand()-0.5) * 12000; + +var arg = {}; + +arg.cloud_spacing = 1100.0; +arg.n_sticks = 4; +arg.stick_length_min = 16; +arg.stick_length_max = 34; +arg.stick_Dphi_min = 15.0 * math.pi/180.0; +arg.stick_Dphi_max = 45.0 * math.pi/180.0; +arg.Dx = 0.0; +arg.Dy = 250.0; +arg.xsize = 40000.0; +arg.ysize = 40000.0; +arg.blat = lat+get_lat(x,y,phi); +arg.blon = lon+get_lon(x,y,phi); +arg.balt = alt; +arg.alt_var = 0.0; +arg.dir = alpha; +arg.type = "Fogpatch"; + +local_weather.cloud_size_scale = 12.0; +local_weather.create_stick_bundle(arg); +local_weather.cloud_size_scale = 1.0; +} + + + var create_1_8_cirrostratus_undulatus = func (lat, lon, alt, alpha) { if (local_weather.hardcoded_clouds_flag == 1) {alt = alt - local_weather.offset_map["Cirrostratus"];} From 2c6a962a349e11aef93d6958e70da00919e7e3d0 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Tue, 9 Apr 2013 09:52:19 +0300 Subject: [PATCH 04/17] Modified cloud lighting with dependence on air pollution --- Effects/cloud.eff | 6 ++++++ Nasal/local_weather/local_weather.nas | 12 ++++++------ Shaders/3dcloud-lightfield.vert | 9 +++++---- 3 files changed, 17 insertions(+), 10 deletions(-) diff --git a/Effects/cloud.eff b/Effects/cloud.eff index fa22fa610..f888436a1 100644 --- a/Effects/cloud.eff +++ b/Effects/cloud.eff @@ -11,6 +11,7 @@ /sim/rendering/eye-altitude-m /environment/cloud-self-shading /environment/moonlight + /environment/air-pollution-norm /environment/visibility-m @@ -107,6 +108,11 @@ float moonlight + + air_pollution + float + air_pollution + visibility float diff --git a/Nasal/local_weather/local_weather.nas b/Nasal/local_weather/local_weather.nas index ce9a6bb3b..003fae88a 100644 --- a/Nasal/local_weather/local_weather.nas +++ b/Nasal/local_weather/local_weather.nas @@ -699,7 +699,7 @@ else # compute the cloud layer self shading correction var sun_angle = 1.57079632675 - getprop("/sim/time/sun-angle-rad"); -var cloud_layer_shading = 1.0 - ((1.0 - scatt_max) * math.pow(math.cos(sun_angle),100.0)); +var cloud_layer_shading = 1.0 - (0.8*(1.0 - scatt_max) * math.pow(math.cos(sun_angle),100.0)); # compute the overcast haze @@ -4125,11 +4125,11 @@ debug.dump(geodinfo(lat, lon)); -#var info = {}; - -#for (var i = 0; i< 100000; i=i+1) -# { -# info = geodinfo(lat, lon); +#var info = {}; + +#for (var i = 0; i< 100000; i=i+1) +# { +# info = geodinfo(lat, lon); # } diff --git a/Shaders/3dcloud-lightfield.vert b/Shaders/3dcloud-lightfield.vert index a3e580bfe..0d1797f61 100644 --- a/Shaders/3dcloud-lightfield.vert +++ b/Shaders/3dcloud-lightfield.vert @@ -12,6 +12,7 @@ uniform float altitude; uniform float cloud_self_shading; uniform float visibility; uniform float moonlight; +uniform float air_pollution; attribute vec3 usrAttr1; attribute vec3 usrAttr2; @@ -151,8 +152,8 @@ void main(void) float lightArg = (terminator-yprime_alt)/100000.0; - light_diffuse.b = light_func(lightArg, 1.330e-05, 0.264, 2.227, 1.08e-05, 1.0); - light_diffuse.g = light_func(lightArg, 3.931e-06, 0.264, 3.827, 7.93e-06, 1.0); + light_diffuse.b = light_func(lightArg -1.2 * air_pollution, 1.330e-05, 0.264, 2.227, 1.08e-05, 1.0); + light_diffuse.g = light_func(lightArg -0.6 * air_pollution, 3.931e-06, 0.264, 3.827, 7.93e-06, 1.0); light_diffuse.r = light_func(lightArg, 8.305e-06, 0.161, 3.827, 3.04e-05, 1.0); light_diffuse.a = 1.0; @@ -160,9 +161,9 @@ void main(void) light_diffuse.rgb = intensity * normalize(mix(light_diffuse.rgb, shadedFogColor, (1.0 - smoothstep(0.5,0.9, min(scattering, cloud_self_shading) )))); // correct ambient light intensity and hue before sunrise - if (earthShade < 0.8) + if (earthShade < 0.6) { - light_diffuse.rgb = intensity * normalize(mix(light_diffuse.rgb, shadedFogColor, 1.0 -smoothstep(0.1, 0.8,earthShade ) )); + light_diffuse.rgb = intensity * normalize(mix(light_diffuse.rgb, shadedFogColor, 1.0 -smoothstep(0.1, 0.6,earthShade ) )); } From 4d3a00bf681e504c483eb46cbfeff0efea31b785 Mon Sep 17 00:00:00 2001 From: James Turner Date: Wed, 20 Mar 2013 12:24:14 +0000 Subject: [PATCH 05/17] Use Nasal to provide GPS search functions. --- Nasal/route_manager.nas | 6 ++ gui/dialogs/gps.xml | 152 ++++++++++++++++++++++++++++++---------- 2 files changed, 120 insertions(+), 38 deletions(-) diff --git a/Nasal/route_manager.nas b/Nasal/route_manager.nas index 3ccfefff1..92b860065 100644 --- a/Nasal/route_manager.nas +++ b/Nasal/route_manager.nas @@ -82,6 +82,12 @@ var RouteManagerDelegate = { fgcommand("activate-flightplan", props.Node.new({"activate": 0})); }, + endOfFlightPlan: func + { + debug.dump("end of flight-plan, deactivating"); + fgcommand("activate-flightplan", props.Node.new({"activate": 0})); + }, + waypointsChanged: func { }, diff --git a/gui/dialogs/gps.xml b/gui/dialogs/gps.xml index b3722091f..62c9f7092 100644 --- a/gui/dialogs/gps.xml +++ b/gui/dialogs/gps.xml @@ -4,23 +4,118 @@ 430 false - + 1); + + if (size(searchResults) < 1) { + scratchValid.setBoolValue(0); + return; + } + + updateScratch(); + } + + var updateScratch = func + { + var result = searchResults[dlg.getNode("scratch-index").getValue()]; + if (result == nil) { + scratchValid.setBoolValue(0); + return; + } + + var ty = result.type; + scratchValid.setBoolValue(1); + scratch.getNode("type", 1).setValue(ty); + scratch.getNode("latitude-deg", 1).setValue(result.lat); + scratch.getNode("longitude-deg", 1).setValue(result.lon); + scratch.getNode("altitude-ft", 1).setValue(result.elevation); + scratch.getNode("ident", 1).setValue(result.id); + scratch.getNode("name", 1).setValue(result.name); + + if (ty == 'vor') { + scratch.getNode("frequency-mhz", 1).setValue(result.frequency); + } elsif (ty == 'ndb') { + scratch.getNode("frequency-khz", 1).setValue(result.frequency); + } + + var cd = positioned.courseAndDistance(result); + scratch.getNode("mag-bearing-deg", 1).setValue(cd[0] + magvar()); + scratch.getNode("distance-nm", 1).setValue(cd[1]); + + gui.dialog_update("gps"); + } + var doSearch = func() + { + var ty = dlg.getNode("search-type").getValue(); + var query = dlg.getNode("search-query").getValue(); + searchResults = positioned.sortByRange(positioned.findByIdent(query, ty)); + updateSearchResults(); + } + + var doSearchNames = func + { + var ty = dlg.getNode("search-type").getValue(); + var query = dlg.getNode("search-query").getValue(); + searchResults = positioned.sortByRange(positioned.findByName(query, ty)); + updateSearchResults(); + } + + var doSearchNearest = func + { + var ty = dlg.getNode("search-type").getValue(); + searchResults = positioned.findWithinRange(200.0, ty); + updateSearchResults(); + } + + var doLoadRouteWaypoint = func + { + var fp = flightplan(); + searchResults = []; + for (var i=0; i < fp.getPlanSize(); i+=1) { + append(searchResults, fp.getWP(i)); + } + updateSearchResults(); + } + + var doScratchPrevious = func + { + var index = dlg.getNode("scratch-index").getValue(); + if (index == 0) return; + dlg.getNode("scratch-index").setValue(index - 1); + dlg.getNode("scratch-has-next", 1).setValue(size(searchResults) > 1); + updateScratch(); + } + + var doScratchNext = func + { + var index = dlg.getNode("scratch-index").getValue(); + var lastIndex = size(searchResults) - 1; + if (index == lastIndex) return; + + dlg.getNode("scratch-has-next", 1).setValue((index + 1) < lastIndex); + dlg.getNode("scratch-index").setValue(index + 1); + updateScratch(); + } + + var searchResults = []; + updateSearchResults(); + var slaved = props.globals.getNode("/instrumentation/nav[0]/slaved-to-gps", 1); - + ]]> + gps vbox @@ -336,36 +431,21 @@ Search nasal - + @@ -484,7 +560,7 @@ From b64dd768d36c1345776244b197026a2a3a7deb12 Mon Sep 17 00:00:00 2001 From: James Turner Date: Sun, 7 Apr 2013 21:45:29 +0100 Subject: [PATCH 06/17] Move more high-level GPS logic to Nasal/XML. --- Nasal/route_manager.nas | 69 +++++++++++++++++++++++++++++------ gui/dialogs/gps.xml | 62 ++++++++++++++++++++----------- gui/dialogs/route-manager.xml | 33 ++++++++++++++++- 3 files changed, 129 insertions(+), 35 deletions(-) diff --git a/Nasal/route_manager.nas b/Nasal/route_manager.nas index 92b860065..a3f1e2a3e 100644 --- a/Nasal/route_manager.nas +++ b/Nasal/route_manager.nas @@ -1,13 +1,13 @@ -# route_manager.nas - default FlightPlan delegate corresponding to the build -# in route-manager dialog. Intended to provide a sensible default behaviour, -# but be disabled by an aircraft-specific FMS / GPS system. +# route_manager.nas - FlightPlan delegate(s) corresponding to the built- +# in route-manager dialog and GPS. Intended to provide a sensible default behaviour, +# but can be disabled by an aircraft-specific FMS / GPS system. var RouteManagerDelegate = { new: func(fp) { - # if this property is set, don't build a delegate at all - if (getprop('/autopilot/route-manager/disable-fms')) - return nil; - + # if this property is set, don't build a delegate at all + if (getprop('/autopilot/route-manager/disable-route-manager')) + return nil; + var m = { parents: [RouteManagerDelegate] }; m.flightplan = fp; return m; @@ -86,19 +86,66 @@ var RouteManagerDelegate = { { debug.dump("end of flight-plan, deactivating"); fgcommand("activate-flightplan", props.Node.new({"activate": 0})); - }, + } +}; + + +var FMSDelegate = { + new: func(fp) { + # if this property is set, don't build a delegate at all + if (getprop('/autopilot/route-manager/disable-fms')) + return nil; + + var m = { parents: [FMSDelegate], flightplan:fp, landingCheck:nil }; + return m; + }, + + _landingCheckTimeout: func + { + var cur = me.flightplan.currentWP(); + var wow = getprop('gear/gear[0]/wow'); + var gs = getprop('velocities/groundspeed-kt'); + if (wow and (gs < 25)) { + debug.dump('touchdown on destination runway, end of route.'); + me.landingCheck.stop(); + # record touch-down time? + me.flightplan.finish(); + } + }, waypointsChanged: func { }, + endOfFlightPlan: func + { + debug.dump('end of flight-plan'); + }, + currentWaypointChanged: func { - debug.dump('saw current WP changed, now ' ~ me.flightplan.current); + if (me.landingCheck != nil) { + me.landingCheck.stop(); + me.landingCheck = nil; # delete timer + } + + #debug.dump('saw current WP changed, now ' ~ me.flightplan.current); + var active = me.flightplan.currentWP(); + if (active == nil) return; + + if (active.alt_cstr_type != 'none') { + debug.dump('new WP has valid altitude restriction, setting on AP'); + setprop('/autopilot/settings/target-altitude-ft', active.alt_cstr); + } + + var activeRunway = active.runway(); + if ((activeRunway != nil) and (activeRunway.id == me.flightplan.destination_runway.id)) { + me.landingCheck = maketimer(2.0, me, FMSDelegate._landingCheckTimeout); + me.landingCheck.start(); + } } }; -# debug.dump('register routemanager delegate factory'); - +registerFlightPlanDelegate(FMSDelegate.new); registerFlightPlanDelegate(RouteManagerDelegate.new); diff --git a/gui/dialogs/gps.xml b/gui/dialogs/gps.xml index 62c9f7092..73d99691b 100644 --- a/gui/dialogs/gps.xml +++ b/gui/dialogs/gps.xml @@ -11,14 +11,17 @@ var cmd = gps.getNode("command", 1); var scratch = gps.getNode("scratch", 1); var scratchValid = scratch.getNode("valid", 1); - - var updateSearchResults = func - { - debug.dump('search results is:', searchResults); + var searchIsWaypoints = 0; + var anySpec = 'vor,airport,heliport,ils,seaport,fix,ndb,waypoint,tacan,city,town'; - dlg.getNode("scratch-index", 1).setValue(0); - dlg.getNode("scratch-has-next", 1).setBoolValue(size(searchResults) > 1); + var updateSearchResults = func(isWpts, index = 0) + { + searchIsWaypoints = isWpts; + dlg.getNode("scratch-index", 1).setValue(index); + var lastIndex = size(searchResults) - 1; + dlg.getNode("scratch-has-next", 1).setValue((index + 1) < lastIndex); + if (size(searchResults) < 1) { scratchValid.setBoolValue(0); return; @@ -34,23 +37,33 @@ scratchValid.setBoolValue(0); return; } - - var ty = result.type; + scratchValid.setBoolValue(1); - scratch.getNode("type", 1).setValue(ty); scratch.getNode("latitude-deg", 1).setValue(result.lat); scratch.getNode("longitude-deg", 1).setValue(result.lon); - scratch.getNode("altitude-ft", 1).setValue(result.elevation); scratch.getNode("ident", 1).setValue(result.id); - scratch.getNode("name", 1).setValue(result.name); + var cd = nil; - if (ty == 'vor') { - scratch.getNode("frequency-mhz", 1).setValue(result.frequency); - } elsif (ty == 'ndb') { - scratch.getNode("frequency-khz", 1).setValue(result.frequency); + if (searchIsWaypoints) { + scratch.getNode("type", 1).setValue('WPT'); + + cd = result.courseAndDistanceFrom(geo.aircraft_position()); + } else { + var ty = result.type; + scratch.getNode("type", 1).setValue(ty); + scratch.getNode("name", 1).setValue(result.name); + scratch.getNode("altitude-ft", 1).setValue(result.elevation); + + if (ty == 'vor') { + scratch.getNode("frequency-mhz", 1).setValue(result.frequency); + } elsif (ty == 'ndb') { + scratch.getNode("frequency-khz", 1).setValue(result.frequency); + } + + cd = positioned.courseAndDistance(result); } - - var cd = positioned.courseAndDistance(result); + + scratch.getNode("mag-bearing-deg", 1).setValue(cd[0] + magvar()); scratch.getNode("distance-nm", 1).setValue(cd[1]); @@ -60,24 +73,27 @@ var doSearch = func() { var ty = dlg.getNode("search-type").getValue(); + if (ty == 'any') ty = anySpec; + var query = dlg.getNode("search-query").getValue(); searchResults = positioned.sortByRange(positioned.findByIdent(query, ty)); - updateSearchResults(); + updateSearchResults(0); } var doSearchNames = func { var ty = dlg.getNode("search-type").getValue(); + if (ty == 'any') ty = anySpec; var query = dlg.getNode("search-query").getValue(); searchResults = positioned.sortByRange(positioned.findByName(query, ty)); - updateSearchResults(); + updateSearchResults(0); } var doSearchNearest = func { var ty = dlg.getNode("search-type").getValue(); searchResults = positioned.findWithinRange(200.0, ty); - updateSearchResults(); + updateSearchResults(0); } var doLoadRouteWaypoint = func @@ -87,7 +103,7 @@ for (var i=0; i < fp.getPlanSize(); i+=1) { append(searchResults, fp.getWP(i)); } - updateSearchResults(); + updateSearchResults(1, fp.current); } var doScratchPrevious = func @@ -111,7 +127,7 @@ } var searchResults = []; - updateSearchResults(); + updateSearchResults(0); var slaved = props.globals.getNode("/instrumentation/nav[0]/slaved-to-gps", 1); ]]> @@ -399,6 +415,8 @@ ndb fix wpt + city + town true dialog-apply diff --git a/gui/dialogs/route-manager.xml b/gui/dialogs/route-manager.xml index 1781c7471..1b72bb38e 100644 --- a/gui/dialogs/route-manager.xml +++ b/gui/dialogs/route-manager.xml @@ -224,9 +224,38 @@ command interface /autopilot/route-manager/input: gui.dialog_update("route-manager", "approach"); } - + var initPosition = func { + var routeActive = routem.getNode("active").getValue(); + if (routeActive) return; + + # FIXME have user waypoints check + var fp = flightplan(); + + var airborne = getprop('/gear/gear[0]/wow') == 0; + if (airborne) { + debug.dump('route-manager dialog, init in-air, clearing departure settings'); + fp.departure = nil; + return; + } + + + + # we're on the ground, find the nearest airport to start from + if (fp.departure == nil) { + var apts = findAirportsWithinRange(25.0); + if (size(apts) == 0) return; # no airports nearby + fp.departure = apts[0]; # use the closest one + } + + if (fp.departure_runway == nil) { + debug.dump('selecting departure runway'); + var rwy = fp.departure.findBestRunwayForPos( geo.aircraft_position() ); + fp.departure_runway = rwy; + } + } + # initialise departure values based on current position - cmd.setValue("@posinit"); + initPosition(); updateRunways(); updateSIDs(); From e969dbc8f496b2f81ae7f146ebe9cd348df06190 Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Wed, 10 Apr 2013 21:25:59 +0100 Subject: [PATCH 07/17] Improve air-to-air refueling by supporting multiple contact points offset from the tanker center, and an offset probe/recepticle position on the receiving aircraft. --- Nasal/geo.nas | 6 +++++ Nasal/tanker.nas | 59 ++++++++++++++++++++++++++++++++++++++++++++---- 2 files changed, 60 insertions(+), 5 deletions(-) diff --git a/Nasal/geo.nas b/Nasal/geo.nas index c0d73fd6f..024a52b68 100644 --- a/Nasal/geo.nas +++ b/Nasal/geo.nas @@ -163,6 +163,12 @@ var Coord = { me._pupdate(); course *= D2R; dist /= ERAD; + + if (dist < 0.0) { + dist = abs(dist); + course = course - math.pi; + } + me._lat = math.asin(math.sin(me._lat) * math.cos(dist) + math.cos(me._lat) * math.sin(dist) * math.cos(course)); diff --git a/Nasal/tanker.nas b/Nasal/tanker.nas index 420d09fd2..18d962693 100644 --- a/Nasal/tanker.nas +++ b/Nasal/tanker.nas @@ -70,7 +70,7 @@ var identity = { var Tanker = { - new: func(aiid, callsign, tacan, type, model, kias, maxfuel, pattern, heading, coord) { + new: func(aiid, callsign, tacan, type, model, kias, maxfuel, pattern, contacts, heading, coord) { var m = { parents: [Tanker] }; m.callsign = callsign; m.tacan = tacan; @@ -79,6 +79,7 @@ var Tanker = { m.out_of_range_time = 0; m.interval = 10; m.length = pattern; + m.contacts = contacts; m.roll = 0; m.coord = geo.Coord.new(coord); m.anchor = geo.Coord.new(coord).apply_course_distance(m.track_course, m.length); # ARCP @@ -218,9 +219,43 @@ var Tanker = { me.brgN.setDoubleValue(me.bearing); me.elevN.setDoubleValue(elev); - me.contactN.setBoolValue(me.distance < ac_contact_dist and - dalt > 0 and - abs(view.normdeg(me.bearing - ac_hdg)) < 20); + # Determine if any of the contact points are in contact + var offset_x = getprop("/systems/refuel/offset-x-m") or 0; + var offset_y = getprop("/systems/refuel/offset-y-m") or 0; + var offset_z = getprop("/systems/refuel/offset-z-m") or 0; + var roll = getprop("/orientation/roll-deg") * globals.D2R; + + # Determine contact position + var probe_pos = geo.Coord.new(me.ac); + + probe_pos.apply_course_distance(ac_hdg, offset_x); + probe_pos.apply_course_distance(ac_hdg + 90, offset_y * math.cos(roll) + offset_z * math.sin(roll)); + probe_pos.set_alt(me.ac.alt() + offset_z * math.cos(roll) - offset_y * math.sin(roll)); + + me.contactN.setBoolValue(0); + + foreach (var c; me.contacts) { + var drogue_pos = geo.Coord.new(me.coord); + + # Offset longitudonally + drogue_pos.apply_course_distance(me.course, c.x); + + var r = me.roll * globals.D2R; + + # Offset laterally, taking into account any roll + drogue_pos.apply_course_distance(me.course +90, c.y * math.cos(r) + c.z * math.sin(r)); + + # Offset vertically, again, taking into account any roll + drogue_pos.set_alt(drogue_pos.alt() + c.z * math.cos(r) - c.y * math.sin(r)); + + #print("Distance: " ~ probe_pos.distance_to(drogue_pos) ~ " vs. " ~ me.distance); + + if (probe_pos.distance_to(drogue_pos) < ac_contact_dist and + abs(view.normdeg(me.course - ac_hdg)) < 20) { + # Contact! + me.contactN.setBoolValue(1); + } + } me.hOffsetN.setDoubleValue(me.bearing - ac_hdg); me.vOffsetN.setDoubleValue(elev - ac_pitch); @@ -278,13 +313,27 @@ var create_tanker = func(tanker_node, course) { var spd = tanker_node.getNode("speed-kts", 1).getValue() or 250; var pattern = (tanker_node.getNode("pattern-length-nm", 1).getValue() or 50) * NM2M; var maxfuel = tanker_node.getNode("max-fuel-transfer-lbs-min", 1).getValue() or 6000; + + var contacts = []; + + foreach (var contact; tanker_node.getChildren("contact")) { + var x = (contact.getNode("x-m") != nil) ? contact.getNode("x-m").getValue() : 0; + var y = (contact.getNode("y-m") != nil) ? contact.getNode("y-m").getValue() : 0; + var z = (contact.getNode("z-m") != nil) ? contact.getNode("z-m").getValue() : 0; + append(contacts, { "x" : x, "y" : y, "z" : z }); + } + + + if (size(contacts) == 0) { + append(contacts, {x: 0, y:0, z:0}); + } var alt = int(10 + rand() * 15) * 1000; # FL100--FL250 alt = skip_cloud_layer(alt * FT2M); var dist = 6000 + rand() * 4000; var coord = geo.aircraft_position().apply_course_distance(course, dist).set_alt(alt); - Tanker.new(aiid, callsign, tacanid, type, model, spd, maxfuel, pattern, course, coord); + Tanker.new(aiid, callsign, tacanid, type, model, spd, maxfuel, pattern, contacts, course, coord); } # Request a new tanker From 5fc821c4c1f861cd125b5254acc499446bec5197 Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Wed, 10 Apr 2013 21:53:21 +0100 Subject: [PATCH 08/17] Further AAR improvements: - Make the A330-MRTT drogues HOT=false so you can't crash into them - Add offset for the probe on the A-4F - Correct the deviation due to roll, making it match the piloted aircraft. --- Nasal/tanker.nas | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Nasal/tanker.nas b/Nasal/tanker.nas index 18d962693..c4ed56850 100644 --- a/Nasal/tanker.nas +++ b/Nasal/tanker.nas @@ -156,7 +156,7 @@ var Tanker = { } var distance = dt * (me.ktas - me.headwind) * NM2M / 3600; - var deviation = me.roll ? 0.5 * dt * 1085.941 * math.tan(me.roll * D2R) / me.ktas : 0; + var deviation = me.roll ? dt * 1085.941 * math.tan(me.roll * D2R) / me.ktas : 0; if (me.mode == "leg") { if (me.lastmode != "leg") { From 9177ee698e162eb4a032a9a3e4ab5c199088ad88 Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Wed, 10 Apr 2013 23:11:12 +0100 Subject: [PATCH 09/17] AAR bug - default fuel transfer rate to 6000 lbs per minute. --- Aircraft/Generic/aar.nas | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Aircraft/Generic/aar.nas b/Aircraft/Generic/aar.nas index c5bf8039c..a2e09c748 100644 --- a/Aircraft/Generic/aar.nas +++ b/Aircraft/Generic/aar.nas @@ -81,7 +81,7 @@ var update_loop = func { # and the aircraft maximum rate. Both are expressed # in lbs/min var fuel_rate = math.min(tankers[0].getNode("refuel/max-fuel-transfer-lbs-min", 1).getValue() or 6000, - refuelingN.getNode("max-fuel-transfer-lbs-min", 1).getValue()); + refuelingN.getNode("max-fuel-transfer-lbs-min", 1).getValue() or 6000); var received = UPDATE_PERIOD * fuel_rate / 60; consumed -= received; } From fd4e61869bc377a352da3fa3350dbdcea79cfe20 Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Fri, 12 Apr 2013 20:24:53 +0100 Subject: [PATCH 10/17] Add support for blocks in the joystick nasal config library. --- Nasal/joystick.nas | 26 +++++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/Nasal/joystick.nas b/Nasal/joystick.nas index 9ed5eb2ae..3f8ef7ff8 100644 --- a/Nasal/joystick.nas +++ b/Nasal/joystick.nas @@ -1,6 +1,7 @@ # Joystick configuration library. var DIALOGROOT = "/sim/gui/dialogs/joystick-config"; var MAX_AXES = 8; +var MAX_NASALS = 8; var MAX_BUTTONS = 24; # Hash of the custom axis/buttons @@ -629,7 +630,24 @@ var readConfig = func(dialog_root="/sim/gui/dialogs/joystick-config") { btn.getNode("binding", 1).setValue("None"); btn.removeChild("original_binding"); } - } + } + + # Set up Nasal code. + var nasals = js.getChildren("nasal"); + + for (var nasal = 0; nasal < MAX_NASALS; nasal = nasal + 1) { + var nas = props.globals.getNode(dialog_root ~ "/nasal[" ~ nasal ~ "]", 1); + nas.remove(); + nas = props.globals.getNode(dialog_root ~ "/nasal[" ~ nasal ~ "]", 1); + + # Note that we can't simply use an index into the buttons array + # as that doesn't work for a sparsley populated set of buttons. + # E.g. one with n="3" + var a = js.getNode("nasal[" ~ nasal ~ "]"); + if (a != nil) { + props.copy(a, nas.getNode("original_script", 1)); + } + } } var writeConfig = func(dialog_root="/sim/gui/dialogs/joystick-config", reset=0) { @@ -647,6 +665,12 @@ var writeConfig = func(dialog_root="/sim/gui/dialogs/joystick-config", reset=0) config.getNode("name", 1).setValue(id); } + var nasals = props.globals.getNode(dialog_root).getChildren("nasal"); + forindex (var nas; nasals) { + var nasalscript = config.getNode("nasal[" ~ nas ~ "]", 1); + props.copy(props.globals.getNode(dialog_root ~ "/nasal[" ~ nas ~ "]/original_script", 1), nasalscript); + } + var axes = props.globals.getNode(dialog_root).getChildren("axis"); forindex (var axis; axes) { var name = getprop(dialog_root ~ "/axis[" ~ axis ~ "]/binding"); From cad64a9711d940c6ae31fe1702c20431e6433e57 Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Fri, 12 Apr 2013 20:52:04 +0100 Subject: [PATCH 11/17] Normalize angles for bearings on tanker. Patch from Jean PELLOTIER. --- Nasal/tanker.nas | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Nasal/tanker.nas b/Nasal/tanker.nas index c4ed56850..ada0f8194 100644 --- a/Nasal/tanker.nas +++ b/Nasal/tanker.nas @@ -257,8 +257,8 @@ var Tanker = { } } - me.hOffsetN.setDoubleValue(me.bearing - ac_hdg); - me.vOffsetN.setDoubleValue(elev - ac_pitch); + me.hOffsetN.setDoubleValue(view.normdeg(me.bearing - ac_hdg)); + me.vOffsetN.setDoubleValue(view.normdeg(elev - ac_pitch)); var droll = me.roll_target - me.roll; if (droll > 0) { From f9da4387e62a883f6e9675ffc1e969f1e62c27ec Mon Sep 17 00:00:00 2001 From: James Turner Date: Sun, 14 Apr 2013 16:04:56 +0100 Subject: [PATCH 12/17] Initial work on a KLN-94 GPS. Not functional yet, patience. --- Aircraft/Instruments-3d/kln94/auxPages.nas | 0 Aircraft/Instruments-3d/kln94/cdi.svg | 249 ++++ .../Instruments-3d/kln94/flightplanPages.nas | 0 Aircraft/Instruments-3d/kln94/kln94.ac | 1100 +++++++++++++++++ Aircraft/Instruments-3d/kln94/kln94.blend | Bin 0 -> 605232 bytes Aircraft/Instruments-3d/kln94/kln94.nas | 385 ++++++ Aircraft/Instruments-3d/kln94/kln94.png | Bin 0 -> 89883 bytes Aircraft/Instruments-3d/kln94/kln94.xml | 164 +++ Aircraft/Instruments-3d/kln94/knob.rgb | Bin 0 -> 1088 bytes Aircraft/Instruments-3d/kln94/navPages.nas | 80 ++ .../Instruments-3d/kln94/settingPages.nas | 0 .../Instruments-3d/kln94/waypointPages.nas | 0 12 files changed, 1978 insertions(+) create mode 100644 Aircraft/Instruments-3d/kln94/auxPages.nas create mode 100644 Aircraft/Instruments-3d/kln94/cdi.svg create mode 100644 Aircraft/Instruments-3d/kln94/flightplanPages.nas create mode 100644 Aircraft/Instruments-3d/kln94/kln94.ac create mode 100644 Aircraft/Instruments-3d/kln94/kln94.blend create mode 100644 Aircraft/Instruments-3d/kln94/kln94.nas create mode 100644 Aircraft/Instruments-3d/kln94/kln94.png create mode 100644 Aircraft/Instruments-3d/kln94/kln94.xml create mode 100644 Aircraft/Instruments-3d/kln94/knob.rgb create mode 100644 Aircraft/Instruments-3d/kln94/navPages.nas create mode 100644 Aircraft/Instruments-3d/kln94/settingPages.nas create mode 100644 Aircraft/Instruments-3d/kln94/waypointPages.nas diff --git a/Aircraft/Instruments-3d/kln94/auxPages.nas b/Aircraft/Instruments-3d/kln94/auxPages.nas new file mode 100644 index 000000000..e69de29bb diff --git a/Aircraft/Instruments-3d/kln94/cdi.svg b/Aircraft/Instruments-3d/kln94/cdi.svg new file mode 100644 index 000000000..6344701fa --- /dev/null +++ b/Aircraft/Instruments-3d/kln94/cdi.svg @@ -0,0 +1,249 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Aircraft/Instruments-3d/kln94/flightplanPages.nas b/Aircraft/Instruments-3d/kln94/flightplanPages.nas new file mode 100644 index 000000000..e69de29bb diff --git a/Aircraft/Instruments-3d/kln94/kln94.ac b/Aircraft/Instruments-3d/kln94/kln94.ac new file mode 100644 index 000000000..95f2e35c7 --- /dev/null +++ b/Aircraft/Instruments-3d/kln94/kln94.ac @@ -0,0 +1,1100 @@ +AC3Db +MATERIAL "DefaultWhite" rgb 1.0000 1.0000 1.0000 amb 0.2000 0.2000 0.2000 emis 0.0000 0.0000 0.0000 spec 0.5000 0.5000 0.5000 shi 10 trans 0.0000 +MATERIAL "ac3dmat1" rgb 1.0000 1.0000 1.0000 amb 1.0000 1.0000 1.0000 emis 0.0000 0.0000 0.0000 spec 0.0000 0.0000 0.0000 shi 50 trans 0.0000 +OBJECT world +name "Blender_export__kln94.ac" +kids 14 +OBJECT poly +name "alt-btn" +loc 0.0055797 -0.0150158 0.0137356 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 -0.0050766 +-0.0012127 0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +5 0.385231 0.051645 +2 0.385231 0.019019 +1 0.440236 0.019019 +6 0.440236 0.051645 +SURF 0X30 +mat 1 +refs 4 +0 0.437719 0.049125 +7 0.437719 0.045280 +6 0.389657 0.045280 +1 0.389657 0.049125 +SURF 0X30 +mat 1 +refs 4 +4 0.389657 0.049125 +3 0.389657 0.045280 +2 0.437719 0.045280 +5 0.437719 0.049125 +SURF 0X30 +mat 1 +refs 4 +7 0.388697 0.023085 +4 0.388697 0.020392 +5 0.438579 0.020392 +6 0.438579 0.023085 +SURF 0X30 +mat 1 +refs 4 +0 0.388184 0.023874 +1 0.388184 0.021447 +2 0.437528 0.021447 +3 0.437528 0.023874 +kids 0 +OBJECT poly +name "base" +loc -0.0000000 0.0000000 -0.0000000 +texture "kln94.png" +texrep 1 1 +numvert 8 +0.0050000 0.0302263 0.0793500 +0.0050000 0.0302263 -0.0793500 +0.0050000 -0.0207000 -0.0793500 +0.0050000 -0.0207000 0.0793500 +-0.0050000 -0.0207000 0.0793500 +-0.0050000 -0.0207000 -0.0793500 +-0.0050000 0.0302119 -0.0793500 +-0.0050000 0.0302119 0.0793500 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +0 0.000001 0.315633 +3 0.000001 0.000000 +2 0.998895 0.000000 +1 0.998895 0.315633 +SURF 0X30 +mat 1 +refs 4 +3 0.722656 0.652778 +4 0.964844 0.652778 +5 0.964844 0.685981 +2 0.722656 0.685981 +SURF 0X30 +mat 1 +refs 4 +7 0.722656 0.652778 +0 0.964844 0.652778 +1 0.964844 0.685981 +6 0.722656 0.685981 +SURF 0X30 +mat 1 +refs 4 +0 0.722656 0.652778 +7 0.964844 0.652778 +4 0.964844 0.685981 +3 0.722656 0.685981 +SURF 0X30 +mat 1 +refs 4 +2 0.722656 0.652778 +5 0.964844 0.652778 +6 0.964844 0.685981 +1 0.722656 0.685981 +kids 0 +OBJECT poly +name "clr-btn" +loc 0.0055797 -0.0149416 -0.0292896 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 -0.0050766 +-0.0012127 -0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +7 0.660486 0.023405 +6 0.660486 0.020978 +5 0.709829 0.020978 +4 0.709829 0.023405 +SURF 0X30 +mat 1 +refs 4 +0 0.660998 0.022616 +3 0.660998 0.019923 +2 0.710881 0.019923 +1 0.710881 0.022616 +SURF 0X30 +mat 1 +refs 4 +3 0.661959 0.048656 +4 0.661959 0.044811 +5 0.710020 0.044811 +2 0.710020 0.048656 +SURF 0X30 +mat 1 +refs 4 +7 0.710020 0.048656 +0 0.710020 0.044811 +1 0.661959 0.044811 +6 0.661959 0.048656 +SURF 0X30 +mat 1 +refs 4 +2 0.657532 0.051176 +5 0.657532 0.018550 +6 0.712538 0.018550 +1 0.712538 0.051176 +kids 0 +OBJECT poly +name "crsr-btn" +loc 0.0055797 0.0147900 -0.0631796 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 -0.0050766 +-0.0012127 0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +5 0.869303 0.242886 +2 0.869303 0.210260 +1 0.924310 0.210260 +6 0.924310 0.242886 +SURF 0X30 +mat 1 +refs 4 +0 0.921792 0.240366 +7 0.921792 0.236521 +6 0.873731 0.236521 +1 0.873731 0.240366 +SURF 0X30 +mat 1 +refs 4 +4 0.873731 0.240366 +3 0.873731 0.236521 +2 0.921792 0.236521 +5 0.921792 0.240366 +SURF 0X30 +mat 1 +refs 4 +7 0.872769 0.214326 +4 0.872769 0.211633 +5 0.922653 0.211633 +6 0.922653 0.214326 +SURF 0X30 +mat 1 +refs 4 +0 0.872257 0.215115 +1 0.872257 0.212688 +2 0.921600 0.212688 +3 0.921600 0.215115 +kids 0 +OBJECT poly +name "dto-btn" +loc 0.0055797 -0.0150158 -0.0150005 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 -0.0050766 +-0.0012127 0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +5 0.567964 0.050395 +2 0.567964 0.017769 +1 0.622970 0.017769 +6 0.622970 0.050395 +SURF 0X30 +mat 1 +refs 4 +0 0.620452 0.047875 +7 0.620452 0.044030 +6 0.572391 0.044030 +1 0.572391 0.047875 +SURF 0X30 +mat 1 +refs 4 +4 0.572391 0.047875 +3 0.572391 0.044030 +2 0.620452 0.044030 +5 0.620452 0.047875 +SURF 0X30 +mat 1 +refs 4 +7 0.571430 0.021835 +4 0.571430 0.019142 +5 0.621313 0.019142 +6 0.621313 0.021835 +SURF 0X30 +mat 1 +refs 4 +0 0.570918 0.022624 +1 0.570918 0.020197 +2 0.620261 0.020197 +3 0.620261 0.022624 +kids 0 +OBJECT poly +name "ent-btn" +loc 0.0055797 -0.0148610 -0.0438817 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 -0.0050766 +-0.0012127 0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +5 0.750032 0.053176 +2 0.750032 0.020550 +1 0.805038 0.020550 +6 0.805038 0.053176 +SURF 0X30 +mat 1 +refs 4 +0 0.802520 0.050656 +7 0.802520 0.046811 +6 0.754459 0.046811 +1 0.754459 0.050656 +SURF 0X30 +mat 1 +refs 4 +4 0.754459 0.050656 +3 0.754459 0.046811 +2 0.802520 0.046811 +5 0.802520 0.050656 +SURF 0X30 +mat 1 +refs 4 +7 0.753498 0.024616 +4 0.753498 0.021923 +5 0.803381 0.021923 +6 0.803381 0.024616 +SURF 0X30 +mat 1 +refs 4 +0 0.752986 0.025405 +1 0.752986 0.022978 +2 0.802329 0.022978 +3 0.802329 0.025405 +kids 0 +OBJECT poly +name "knob-brightness" +loc 0.0070680 -0.0108757 0.0640361 +texture "kln94.png" +texrep 1 1 +numvert 25 +0.0003175 0.0001219 0.0000000 +-0.0019742 0.0001219 0.0042385 +-0.0019742 -0.0019974 0.0036706 +-0.0019742 -0.0035487 0.0021192 +-0.0019742 -0.0041166 0.0000000 +-0.0019742 -0.0035487 -0.0021192 +-0.0019742 -0.0019973 -0.0036706 +-0.0019742 0.0001219 -0.0042385 +-0.0019742 0.0022411 -0.0036706 +-0.0019742 0.0037925 -0.0021192 +-0.0019742 0.0043604 0.0000000 +-0.0019742 0.0037925 0.0021192 +-0.0019742 0.0022411 0.0036706 +0.0019834 0.0001219 0.0042385 +0.0019834 -0.0019974 0.0036706 +0.0019834 -0.0035487 0.0021192 +0.0019834 -0.0041166 0.0000000 +0.0019888 -0.0035487 -0.0021192 +0.0019888 -0.0019973 -0.0036706 +0.0019888 0.0001219 -0.0042385 +0.0019888 0.0022411 -0.0036706 +0.0019888 0.0037925 -0.0021192 +0.0019834 0.0043604 0.0000000 +0.0019834 0.0037925 0.0021192 +0.0019834 0.0022411 0.0036706 +numsurf 24 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +24 0.873306 0.113743 +13 0.867723 0.092904 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +13 0.867723 0.092904 +14 0.873306 0.072065 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +14 0.873306 0.072065 +15 0.888562 0.056810 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +15 0.888562 0.056810 +16 0.909401 0.051226 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +16 0.909401 0.051226 +17 0.930240 0.056810 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +17 0.930240 0.056810 +18 0.945495 0.072065 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +18 0.945495 0.072065 +19 0.951079 0.092904 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +19 0.951079 0.092904 +20 0.945495 0.113743 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +20 0.945495 0.113743 +21 0.930240 0.128999 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +21 0.930240 0.128999 +22 0.909401 0.134582 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +22 0.909401 0.134582 +23 0.888562 0.128999 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +23 0.888562 0.128999 +24 0.873306 0.113743 +SURF 0X30 +mat 1 +refs 4 +24 0.873306 0.113743 +12 0.873306 0.113743 +1 0.867723 0.092904 +13 0.867723 0.092904 +SURF 0X30 +mat 1 +refs 4 +13 0.867723 0.092904 +1 0.867723 0.092904 +2 0.873306 0.072065 +14 0.873306 0.072065 +SURF 0X30 +mat 1 +refs 4 +14 0.873306 0.072065 +2 0.873306 0.072065 +3 0.888562 0.056810 +15 0.888562 0.056810 +SURF 0X30 +mat 1 +refs 4 +15 0.888562 0.056810 +3 0.888562 0.056810 +4 0.909401 0.051226 +16 0.909401 0.051226 +SURF 0X30 +mat 1 +refs 4 +16 0.909401 0.051226 +4 0.909401 0.051226 +5 0.930240 0.056810 +17 0.930240 0.056810 +SURF 0X30 +mat 1 +refs 4 +17 0.930240 0.056810 +5 0.930240 0.056810 +6 0.945495 0.072065 +18 0.945495 0.072065 +SURF 0X30 +mat 1 +refs 4 +18 0.945495 0.072065 +6 0.945495 0.072065 +7 0.951079 0.092904 +19 0.951079 0.092904 +SURF 0X30 +mat 1 +refs 4 +19 0.951079 0.092904 +7 0.951079 0.092904 +8 0.945495 0.113743 +20 0.945495 0.113743 +SURF 0X30 +mat 1 +refs 4 +20 0.945495 0.113743 +8 0.945495 0.113743 +9 0.930240 0.128999 +21 0.930240 0.128999 +SURF 0X30 +mat 1 +refs 4 +21 0.930240 0.128999 +9 0.930240 0.128999 +10 0.909401 0.134582 +22 0.909401 0.134582 +SURF 0X30 +mat 1 +refs 4 +22 0.909401 0.134582 +10 0.909401 0.134582 +11 0.888562 0.128999 +23 0.888562 0.128999 +SURF 0X30 +mat 1 +refs 4 +23 0.888562 0.128999 +11 0.888562 0.128999 +12 0.873306 0.113743 +24 0.873306 0.113743 +kids 0 +OBJECT poly +name "knob-inner" +loc 0.0112497 -0.0038825 -0.0621865 +texture "kln94.png" +texrep 1 1 +numvert 25 +0.0017683 0.0000000 0.0000000 +-0.0017683 -0.0000000 0.0065408 +-0.0017683 -0.0032704 0.0056645 +-0.0017683 -0.0056645 0.0032704 +-0.0017683 -0.0065408 0.0000000 +-0.0017683 -0.0056645 -0.0032704 +-0.0017683 -0.0032704 -0.0056645 +-0.0017683 0.0000000 -0.0065408 +-0.0017683 0.0032704 -0.0056645 +-0.0017683 0.0056645 -0.0032704 +-0.0017683 0.0065408 0.0000000 +-0.0017683 0.0056645 0.0032704 +-0.0017683 0.0032704 0.0056645 +0.0017683 -0.0000000 0.0065408 +0.0017683 -0.0032704 0.0056645 +0.0017683 -0.0056645 0.0032704 +0.0017683 -0.0065408 0.0000000 +0.0017683 -0.0056645 -0.0032704 +0.0017683 -0.0032704 -0.0056645 +0.0017683 0.0000000 -0.0065408 +0.0017683 0.0032704 -0.0056645 +0.0017683 0.0056645 -0.0032704 +0.0017683 0.0065408 0.0000000 +0.0017683 0.0056645 0.0032704 +0.0017683 0.0032704 0.0056645 +numsurf 24 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +24 0.873306 0.113743 +13 0.867723 0.092904 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +13 0.867723 0.092904 +14 0.873306 0.072065 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +14 0.873306 0.072065 +15 0.888562 0.056810 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +15 0.888562 0.056810 +16 0.909401 0.051226 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +16 0.909401 0.051226 +17 0.930240 0.056810 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +17 0.930240 0.056810 +18 0.945495 0.072065 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +18 0.945495 0.072065 +19 0.951079 0.092904 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +19 0.951079 0.092904 +20 0.945495 0.113743 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +20 0.945495 0.113743 +21 0.930240 0.128999 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +21 0.930240 0.128999 +22 0.909401 0.134582 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +22 0.909401 0.134582 +23 0.888562 0.128999 +SURF 0X30 +mat 1 +refs 3 +0 0.909401 0.092904 +23 0.888562 0.128999 +24 0.873306 0.113743 +SURF 0X30 +mat 1 +refs 4 +24 0.873306 0.113743 +12 0.873306 0.113743 +1 0.867723 0.092904 +13 0.867723 0.092904 +SURF 0X30 +mat 1 +refs 4 +13 0.867723 0.092904 +1 0.867723 0.092904 +2 0.873306 0.072065 +14 0.873306 0.072065 +SURF 0X30 +mat 1 +refs 4 +14 0.873306 0.072065 +2 0.873306 0.072065 +3 0.888562 0.056810 +15 0.888562 0.056810 +SURF 0X30 +mat 1 +refs 4 +15 0.888562 0.056810 +3 0.888562 0.056810 +4 0.909401 0.051226 +16 0.909401 0.051226 +SURF 0X30 +mat 1 +refs 4 +16 0.909401 0.051226 +4 0.909401 0.051226 +5 0.930240 0.056810 +17 0.930240 0.056810 +SURF 0X30 +mat 1 +refs 4 +17 0.930240 0.056810 +5 0.930240 0.056810 +6 0.945495 0.072065 +18 0.945495 0.072065 +SURF 0X30 +mat 1 +refs 4 +18 0.945495 0.072065 +6 0.945495 0.072065 +7 0.951079 0.092904 +19 0.951079 0.092904 +SURF 0X30 +mat 1 +refs 4 +19 0.951079 0.092904 +7 0.951079 0.092904 +8 0.945495 0.113743 +20 0.945495 0.113743 +SURF 0X30 +mat 1 +refs 4 +20 0.945495 0.113743 +8 0.945495 0.113743 +9 0.930240 0.128999 +21 0.930240 0.128999 +SURF 0X30 +mat 1 +refs 4 +21 0.930240 0.128999 +9 0.930240 0.128999 +10 0.909401 0.134582 +22 0.909401 0.134582 +SURF 0X30 +mat 1 +refs 4 +22 0.909401 0.134582 +10 0.909401 0.134582 +11 0.888562 0.128999 +23 0.888562 0.128999 +SURF 0X30 +mat 1 +refs 4 +23 0.888562 0.128999 +11 0.888562 0.128999 +12 0.873306 0.113743 +24 0.873306 0.113743 +kids 0 +OBJECT poly +name "knob-outer" +loc 0.0065490 -0.0038825 -0.0621865 +texture "kln94.png" +texrep 1 1 +numvert 25 +0.0024725 0.0045729 0.0079206 +0.0024725 0.0079206 0.0045729 +0.0024725 0.0091459 0.0000000 +0.0024725 0.0079206 -0.0045730 +0.0024725 0.0045729 -0.0079206 +0.0024725 0.0000000 -0.0091459 +0.0024725 -0.0045729 -0.0079206 +0.0024725 -0.0079206 -0.0045730 +0.0024725 -0.0091459 0.0000000 +0.0024725 -0.0079206 0.0045729 +0.0024725 -0.0045730 0.0079206 +0.0024725 -0.0000000 0.0091459 +-0.0013043 0.0045729 0.0079206 +-0.0013043 0.0079206 0.0045729 +-0.0013043 0.0091459 0.0000000 +-0.0013043 0.0079206 -0.0045730 +-0.0013043 0.0045729 -0.0079206 +-0.0013043 0.0000000 -0.0091459 +-0.0013043 -0.0045729 -0.0079206 +-0.0013043 -0.0079206 -0.0045730 +-0.0013043 -0.0091459 0.0000000 +-0.0013043 -0.0079206 0.0045729 +-0.0013043 -0.0045730 0.0079206 +-0.0013043 -0.0000000 0.0091459 +0.0024725 -0.0000000 0.0000000 +numsurf 24 +SURF 0X30 +mat 1 +refs 4 +12 0.880262 0.143374 +0 0.880262 0.143374 +1 0.858931 0.122043 +13 0.858931 0.122043 +SURF 0X30 +mat 1 +refs 4 +2 0.909401 0.151182 +14 0.909401 0.151182 +13 0.880262 0.143374 +1 0.880262 0.143374 +SURF 0X30 +mat 1 +refs 4 +3 0.938540 0.143374 +15 0.938540 0.143374 +14 0.909401 0.151182 +2 0.909401 0.151182 +SURF 0X30 +mat 1 +refs 4 +4 0.959871 0.122043 +16 0.959871 0.122043 +15 0.938540 0.143374 +3 0.938540 0.143374 +SURF 0X30 +mat 1 +refs 4 +5 0.967679 0.092904 +17 0.967679 0.092904 +16 0.959871 0.122043 +4 0.959871 0.122043 +SURF 0X30 +mat 1 +refs 4 +6 0.959871 0.063765 +18 0.959871 0.063765 +17 0.967679 0.092904 +5 0.967679 0.092904 +SURF 0X30 +mat 1 +refs 4 +7 0.938540 0.042434 +19 0.938540 0.042434 +18 0.959871 0.063765 +6 0.959871 0.063765 +SURF 0X30 +mat 1 +refs 4 +8 0.909401 0.034626 +20 0.909401 0.034626 +19 0.938540 0.042434 +7 0.938540 0.042434 +SURF 0X30 +mat 1 +refs 4 +9 0.880262 0.042434 +21 0.880262 0.042434 +20 0.909401 0.034626 +8 0.909401 0.034626 +SURF 0X30 +mat 1 +refs 4 +10 0.858931 0.063765 +22 0.858931 0.063765 +21 0.880262 0.042434 +9 0.880262 0.042434 +SURF 0X30 +mat 1 +refs 4 +11 0.851123 0.092904 +23 0.851123 0.092904 +22 0.858931 0.063765 +10 0.858931 0.063765 +SURF 0X30 +mat 1 +refs 4 +0 0.858931 0.122043 +12 0.858931 0.122043 +23 0.851123 0.092904 +11 0.851123 0.092904 +SURF 0X30 +mat 1 +refs 3 +1 0.909401 0.092904 +0 0.880262 0.143374 +24 0.858931 0.122043 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +2 0.909401 0.151182 +1 0.880262 0.143374 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +3 0.938540 0.143374 +2 0.909401 0.151182 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +4 0.959871 0.122043 +3 0.938540 0.143374 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +5 0.967679 0.092904 +4 0.959871 0.122043 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +6 0.959871 0.063765 +5 0.967679 0.092904 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +7 0.938540 0.042434 +6 0.959871 0.063765 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +8 0.909401 0.034626 +7 0.938540 0.042434 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +9 0.880262 0.042434 +8 0.909401 0.034626 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +10 0.858931 0.063765 +9 0.880262 0.042434 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +11 0.851123 0.092904 +10 0.858931 0.063765 +SURF 0X30 +mat 1 +refs 3 +24 0.909401 0.092904 +0 0.858931 0.122043 +11 0.851123 0.092904 +kids 0 +OBJECT poly +name "msg-btn" +loc 0.0055797 -0.0151679 0.0430479 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 -0.0050766 +0.0012127 -0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 0.0050766 +0.0012127 0.0027196 -0.0050766 +-0.0012127 0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +5 0.202809 0.051645 +2 0.202809 0.019019 +1 0.257814 0.019019 +6 0.257814 0.051645 +SURF 0X30 +mat 1 +refs 4 +0 0.255297 0.049125 +7 0.255297 0.045280 +6 0.207236 0.045280 +1 0.207236 0.049125 +SURF 0X30 +mat 1 +refs 4 +4 0.207236 0.049125 +3 0.207236 0.045280 +2 0.255297 0.045280 +5 0.255297 0.049125 +SURF 0X30 +mat 1 +refs 4 +7 0.206275 0.023085 +4 0.206275 0.020392 +5 0.256157 0.020392 +6 0.256157 0.023085 +SURF 0X30 +mat 1 +refs 4 +0 0.205763 0.023874 +1 0.205763 0.021447 +2 0.255106 0.021447 +3 0.255106 0.023874 +kids 0 +OBJECT poly +name "nrst-btn" +loc 0.0055797 -0.0150223 -0.0007310 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 -0.0050766 +-0.0012127 -0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +7 0.478419 0.023874 +6 0.478419 0.021447 +5 0.527762 0.021447 +4 0.527762 0.023874 +SURF 0X30 +mat 1 +refs 4 +0 0.478931 0.023085 +3 0.478931 0.020392 +2 0.528814 0.020392 +1 0.528814 0.023085 +SURF 0X30 +mat 1 +refs 4 +3 0.479892 0.049125 +4 0.479892 0.045280 +5 0.527953 0.045280 +2 0.527953 0.049125 +SURF 0X30 +mat 1 +refs 4 +7 0.527953 0.049125 +0 0.527953 0.045280 +1 0.479892 0.045280 +6 0.479892 0.049125 +SURF 0X30 +mat 1 +refs 4 +2 0.475465 0.051645 +5 0.475465 0.019019 +6 0.530471 0.019019 +1 0.530471 0.051645 +kids 0 +OBJECT poly +name "obs-btn" +loc 0.0055797 -0.0150158 0.0285507 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 -0.0050766 +-0.0012127 -0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +7 0.295512 0.023874 +6 0.295512 0.021447 +5 0.344855 0.021447 +4 0.344855 0.023874 +SURF 0X30 +mat 1 +refs 4 +0 0.296024 0.023085 +3 0.296024 0.020392 +2 0.345907 0.020392 +1 0.345907 0.023085 +SURF 0X30 +mat 1 +refs 4 +3 0.296985 0.049125 +4 0.296985 0.045280 +5 0.345046 0.045280 +2 0.345046 0.049125 +SURF 0X30 +mat 1 +refs 4 +7 0.345046 0.049125 +0 0.345046 0.045280 +1 0.296985 0.045280 +6 0.296985 0.049125 +SURF 0X30 +mat 1 +refs 4 +2 0.292558 0.051645 +5 0.292558 0.019019 +6 0.347564 0.019019 +1 0.347564 0.051645 +kids 0 +OBJECT poly +name "proc-btn" +loc 0.0055797 0.0146801 0.0588151 +texture "kln94.png" +texrep 1 1 +numvert 8 +-0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 -0.0050766 +0.0012127 0.0027196 0.0050766 +-0.0012127 0.0027196 0.0050766 +-0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 0.0050766 +0.0012127 -0.0027196 -0.0050766 +-0.0012127 -0.0027196 -0.0050766 +numsurf 5 +SURF 0X30 +mat 1 +refs 4 +7 0.104981 0.212771 +6 0.104981 0.210345 +5 0.154325 0.210345 +4 0.154325 0.212771 +SURF 0X30 +mat 1 +refs 4 +0 0.106544 0.213032 +3 0.106544 0.210340 +2 0.156427 0.210340 +1 0.156427 0.213032 +SURF 0X30 +mat 1 +refs 4 +3 0.106454 0.238023 +4 0.106454 0.234178 +5 0.154516 0.234178 +2 0.154516 0.238023 +SURF 0X30 +mat 1 +refs 4 +7 0.154516 0.238023 +0 0.154516 0.234178 +1 0.106454 0.234178 +6 0.106454 0.238023 +SURF 0X30 +mat 1 +refs 4 +2 0.102028 0.240543 +5 0.102028 0.207917 +6 0.157033 0.207917 +1 0.157033 0.240543 +kids 0 +OBJECT poly +name "screen" +loc 0.0052287 0.0083597 0.0029861 +numvert 4 +-0.0000000 -0.0169880 -0.0441660 +-0.0000000 0.0169880 -0.0441660 +0.0000000 -0.0169880 0.0441660 +0.0000000 0.0169880 0.0441660 +numsurf 1 +SURF 0X20 +mat 0 +refs 4 +3 0 0 +2 0 0 +0 0 0 +1 0 0 +kids 0 diff --git a/Aircraft/Instruments-3d/kln94/kln94.blend b/Aircraft/Instruments-3d/kln94/kln94.blend new file mode 100644 index 0000000000000000000000000000000000000000..c117b2aea08f33f3ebaa53d9c397628b48518a6d GIT binary patch literal 605232 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%0A!Z6Qmdnh_F$HT!;yzdF+f$p= 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 0) { + # show 'M' symbol + } + + if (me._enterAction != nil) { + # show 'ENT' symbol + } + + }, + + _updatePageBar : func + { + # hide in NAV-4 mode + if (me.inNav4Mode()) { + me._pageBarGroup.setVisible(0); + return; + } + + if (me._cursorActive) { + me._pageBarText.setText(''); + var t = ' * CRSR * ' ~ me.pageNames[activePage] ~ ' * CRSR *'; + me._pageBarInverseText.setText(t); + return; + } + + # assemble the string + var barString = ''; + var inverseBarString = ''; + var activePage = me.pageIndex[0]; + + for (var i=0; i < 10; i += 1) { + if (activePage == i) { + var sep = me.isMultiPage() ? '+' : ' '; + inverseBarString ~= me.pageNames[i] ~ sep ~ me.pageIndex[1]; + barString ~= ' '; # 5 spaces + } else { + barString ~= ' ' ~ me.pageNames[i]; + if (i < activePage) + inverseBarString ~= ' '; # 4 spaces + } + } + + me._pageBarText.setText(barString); + me._pageBarInverseText.setText(inverseBarString); + }, + + _setInverted: func(line, firstcol, numcols=1) + { + var t = me._pageAreaInverted; + var cellW = 20.0; + var lineH = (KLN94.canvas_settings.view[1] - KLN94.PAGE_BAR_HEIGHT) / 5; + t.setTranslation(firstcol * cellW, (line + 0.5) * lineH); + t.setText(substr(me._pageAreaLines[line].getText(), firstcol, numcols)); + t.setVisible(1); + }, + + _setBlink: func(line, firstcol, numcols=1) + { + + }, + + isPageActive: func(nm, idx) + { + if (me._page == nil) return 0; + return (me._page.section == nm) and (me._page.index == idx); + }, + + isMultiPage: func { return me._page.isMulti(); }, + + toggleCursor: func + { + me._cursorActive = !me._cursorActive; + if (me._cursorActive) { + me._cursorField = 0; + } + + me._updatePageBar(); + }, + + messageButton: func + { + if (me._messageScreenActive) { + me._messages = me._messages[1:]; # pop front + if (size(me._messages) == 0) { + me._messageScreenActive = 0; + # refresh normal screen + return; + } + + me._buildMessageScreen(); + return; + } + + if (size(me._messages) == 0) { + debug.dump('no messages to show'); + return; + } + + me._messageScreenActive = 1; + me._buildMessageScreen(); + }, + + _buildMessageScreen: func + { + + }, + + # Nav4 mode is special + inNav4Mode: func { return me.isPageActive(NAV, 4); }, + + formatDuration: func(timeInSeconds) + { + if (timeInSeconds > 60) { + return sprintf("0:%02d", timeInSeconds); + } + + if (timeInSeconds > 3600) { + var mins = int(timeInSeconds / 60); + var secs = timeInSeconds - (mins * 60); + return sprintf("%d:%02d", mins, secs); + } + + var hours = int(timeInSeconds / 3600); + timeInSeconds -= (hours * 3600); + var mins = int(timeInSeconds / 60); + var secs = timeInSeconds - (mins * 60); + return sprintf("%d:%02d:%02d", hours, mins, secs); + }, + + formatLatitude: func(lat) + { + var north = (lat >= 0.0); + var latDeg = int(lat); + var latMinutes = math.abs(lat - latDeg) * 60; + return sprintf('%s%02d*%04.1f', north ? "N" : "S", abs(latDeg), latMinutes); + }, + + formatLongitude: func(lon) + { + var east = (lon >= 0.0); + var lonDeg = int(lon); + var lonMinutes = math.abs(lon - lonDeg) * 60; + sprintf("%s%03d*%04.1f", east ? 'E' : 'W', abs(lonDeg), lonMinutes); + }, +}; + + +reload_gps = func +{ + kln94._setActivePage(nil); # force existing page to be undisplayed cleanly + + # make the cdu instance available inside the module namespace + # we are going to load into. + # for a reload this also wipes the existing namespace, which we want + globals['kln94_NS'] = { gps: kln94, KLN94:KLN94 }; + + var pages = ['navPages.nas', 'infoPages.nas', 'flightplanPages.nas', 'settingPages.nas', 'auxPages.nas']; + + #var settings = props.globals.getNode('/instrumentation/cdu/settings'); + foreach (var path; pages) { + # resolve the path in FG_ROOT, and --fg-aircraft dir, etc + var abspath = resolvepath('Aircraft/Instruments-3d/kln94/' ~ path); + if (io.stat(abspath) == nil) { + debug.dump('KN94 page not found:', path, abspath); + continue; + } + + # load pages code into a seperate namespace which we defined above + # also means we can clean out that namespace later + io.load_nasal(abspath, 'kln94_NS'); + } + # cdu.displayPageByTag(getprop('/instrumentation/cdu/settings/boot-page')); +}; + +setlistener("/nasal/canvas/loaded", func +{ + # create base PGS + kln94 = KLN94.new('/instrumentation/gps', {"node": "screen"}); + reload_gps(); +}, 1); diff --git a/Aircraft/Instruments-3d/kln94/kln94.png b/Aircraft/Instruments-3d/kln94/kln94.png new file mode 100644 index 0000000000000000000000000000000000000000..f2227e14e76b2c0d8e6051e625d7f23312d1288b GIT binary patch literal 89883 zcmbTe1ymf{)-DPJLht~=EkJ@p<8Hy--8uw!cMTfcEx5Y`cSs2C?iOfV8*OOl%RXoC z|DJp98}E(rdaN#)HP@Wq{MKC6Rclpsgo=_h1}ZTs92^{mtc-*j92~;SCIZ}>*DtGU z&$)+}6^f&bt_vI-8tz|Tc)0IbgfANQRvJ34I*JPXCJuHi#-JS zUpDQ`T#es*+S%H>@OuhT{Y!)YW&1BNfa?9fR9tO@sB{!n-itdpo4w~^VPj#Z5=MRh z{=J~HsX4!zgw)^FU-pEkEL~k4`2heA4-Xa(4i*Pz3jiA*A0L2~9l*}c{G!3^;$`n@ z?8$8JLj7+e|Jac*b1`wYa&)zFuz&xTUE?nfZmvR9RDU`8pU>Yo?HvEdk-f{`QN6?m z@HBP=u(7ZL{>So5MZuRC`Nf^hj9nd^H5?plg+G}%INQH>H*Oqz{|Dy3j{M)C|B~{HJJ>loo4NdjQt}|5qCRP0maE3!}ae_)jhgqnjrHdMk$H6vA)$34p$?7) zj)vToMOzPT&49`y!+Fh3{`M6oLv2f$K*WEScKomHH7RQf);+vG^Y@Z|CJ0lfaYk0* zIuHM%q#!ZOoW#1~6Ug<_Tt&>P;YFxBqZuUQ6*IlGp`vzh%3hiHvs+G`=BTxsI1Ykb zk$QkLs03P~d@qO-h!|~lh`tD0?7LVPDrWDt0%~!*EREgUf}GulJ}1cMj5bRP(qg!+ zohwenUh?GLjnJG4IArbLHjmtFo_jQSAV29m`byLF_xV^nJ`86X8DRHBh_l--Y^>;n zu9SF9Zp8X5SSI9&9B&4oGgP134cDQyZ+D9T-s!gYM`;HGRkV4fx7%;!sq`1Dc3@v? z;{TXheMoau+D#k<9VB(`m)?mcOva46)k=}_QARLD9t+!j85P4<({TiXXCZ*zRZXUo?|Yw2=77n`UZcrT=)WJ|hba+wlqBalny zgJpQWepkwom3rR&fdn5~E7L+w#h6LzVd+xyYX=KNs|~5WCI>=;?FaV9iC~8Is9WgF z=m%}SN8#j%y^~u9?H0Q@Id?C7BBii1lu$sm7-!6=N)^W3YZn;*0=l*lZc1E-Hb_8T z3Mg=TY~)UV7(EoKBwJ&9usMDjzVq?V4fudp^Dw-)HPDYbiTJCoCl9z(_*H6u_I4tU z0wg3~CvqZMu5D({BWM!P4$#YgGvfEyuaFMBkD27^N8o-VFjPEB59dSizW&c9sz*ZU zo2{Rv*pz7(YN9O52DZh%kC{}JY2QxrC)Jq=_gwb(sfZ;weLV!vxW26r;;)bCokpw` zT1-old=+T%>bq4Dc7FHv2EHTQ%^KnLEYZSNcbkhu`(w%596eLRD~dFmcH8u4)g)gJ zcRnPzmCd|_3Pgkb{GY+fJ68R>iTXG?M)es>auA?)Wb~8;GG23b&)BW5q4wDR#3VpK zIbdBOL2^abX7XJ%5x9HM>4(zCbSm^x<&K}n_fKLZt7?QCNO{|6{>DFotQ zyfM|Uld!nwZfD3WCX{36!NTb8zEBt>u<;uXq*LbZb&}PD3fN+!=NBJqGOBC zCoZPaNP??JkCVPN(Si+Ek2RRa6c3aDCHHheD|9y7*nE2?ICSFcIu9#l5;>c4^c)NY z+ARWe*0H$lhpQgkE>C=Qg!B@Y-=ZwP8Vk{6&&Qb%Y~5pLGxy|@I%ux|CU| zvOBA1*gPN<&B%Ptdgr9sG69bbNk(*r(csSX57L z2u!4j&Ko4S_jvk685RkJswF)Js@X2!Nvs7mTa>kjaupmmM_v={uD9A-g#^B_VHIyp zqFyVk8h_K9J26M@SP9h(0LFpoZqyc!MuKNfvak=O$=+8MOP2I=KDTy#>R9tK%W&+j z?);vulYQ!8VF@keRgZzC2N2f(hW2o!Gkz@zMSVX8eSSB%eodCLZo5kzodwLqY+G}x zU)g6nFzbY7cnc6hy5 zqg=muwcWoTw6hxr-X=L_Tv`npHfl9nEgz@wjC%<(=`&u<$!qMybv)8cw87S zJ5Pyz@!Wh4qDIuVM6+D~CFQPt!04P}o!7ZF{ykza1rTPAxK$W#9jIS??h>_ogxh@t zmGM7dnT!n5>ddrH9{2O8sIJ7)Y-mWcKCG;V7O_lBX=Y*EthDz~&Jd~^Qq*M*5o$<# znGz+en*wg`L{<*`_-vhmrw^3Wb7Ot=8DSKoF=rzh8qSzqJtzD>DI@IDS|`#;b94G- zr6aDzV54QS+c`&^F}VVI>v@D+ZE<0bIDEdzm^P<{HEb0KjxoP~#S7NQF3Y10cSFp` z%8A{Cb&teRLC${=xA483YldR+Wrnyj-6OL6Lh6I{a|D&tj3xwSx{DM2nPj=E4}OEe zNpX>LHo6gi5afb2QiNVZ62nJ7?ABViFZLD8d39h?`|tAKWu3LY^7d}YEr%dqU9VED zUS|lqbo%O!-YW~P9>9!+GQ|V%V3CO_sdTx6qw~aZt0zLLgL_F`{N{UNr)*Lh2j}+q zkeTTO>UiA(G-jAC&s6~(VjUe;R{-o+n}{F_Sk-Q-`sX7A*&1tA39t7#UV|~jW78=h zpjzZInCLmtgY&MO#Csz?&dV8wAb1~?>%YR=tL!uG6V)ZqXL`T$Hrb(1YVCsf!ygB2 zFtwsF7|Ond%uHF%2i%e?z9ICKBIC`q1yV`x)Dn!y1wzvDk*-oc3aRjx4r`9k? zkUQ#gq=pfAVDLO2cQlHKQp_My^)`w1wzMPuN^K-IQktz#VYvOa_JMzKEWVwA0ke@7 z9%qQ^vlLu3hIiYFt1`b%+~!m)_-_5JALa1|*sxWvxFT#eB*z^&I=e6A4f<0Lm!S`c zO^9&z-e>zsP;I+Sx|CcHDKFFe6y!DevxXI^Z^*dNHfT|j2mqCcR96Op3cx+_mWD|A0W+5)G{6+stOwD!yyOBnNh zxsY=u*F)`TOasR?GVi@QZMy;W8mIXH*)O4cyUexfm3!b+$u>_}5I8`mZt0WD@m2fI z%=$*w^mI7wTYU9=g0-psA%;e$CECQg2@AXuQ=&KjLa0EGXL?jb#)gTKk2CTDFla9mAx^424H%uN$j93cR@?P~>uHpHMP!eC)= zTb~GY2`P@3rfo1RsTl6yU2h`(sTI~y>4bRy#EgDVwnyiNUwMrY0i+yK+gmYpD{)lR z<<>%fs*SOxP9Vjk^q#Ur%t2b5VA+;nh4*?u;!_B{2LA7NV;`wblv>VCz%z$%awK1k zSFXCBWfEY5O&515@+1whvb7oDO*V8*FCP5cWkpAYS7qv&&6L0S*&1k2X0;!DKs^lt z3FZ`Ung$uGK?;I@_BSgxf6MQD4GsJzJtf3oA8#xY5>g1H*&tj6Qv=oo&Rq>U_Cr(f zG~l#^DprKTRyVzsjc(!)mJ~%!V#xR=79ddf^i1yKPCv(u^Ye3jmcx^)n<$ms8}5*M zN$XP3NEU_YpGM|<#c~Wiwvxq zqD^Z5Ko?e-D>JEFdXGY~nZJIOX^WJnq$lDYhz@LF<_ZxsXnB^+5M~Cm`D{$@c;T*6 zRu0=et`zcrtY}XVNrIk#pp7ALk9=5i%Q+Y0`TizsI>Ug4PmTp^V9=-~+{wc66SZA5 zW9b27)MEOk+r%etQWnLD7Ik;+QB9?GrWMWs@}^E-(Dn!;K=#TkjbWR_6g%9uZQ^+QwK=c8Dg>y$5uAJE9u9K;?Lf|DL&=e*iX17QAiuCEn!63o+tOWecMdF-{0GGbQb;o>2L z-fI(%5(Ct_NEI_%e#CWd(|-c)PVN}WIY;T;E&@My&$+$$^nW|%7@)O8>X}Y{&hF?mh>r$ z(?xHlW=J?o6aNn;qRubBjKRo>%xZ9&Y26p0_rU@rO}(SE&M#PYSrqtI1HFOe89}V0DZs+dw- zJXExlt63Jy9yoNC#f{+W-!qKvg8mF;{}fy>mB|L9b3RWV&@@;Kf-dPzoX>tD3;??u z*l|CG+!P7tg>pV0c8uy8{c1f(Qp398vjnI3Nw@5|?Wzy~`hr^A?};Z_b3jH?7RT|t z8toAZ*}k8SaihT}X}6oZ_C{~hF;7<24IizfilZwUmgoPk*njT0JT4RRTH4+bpL z`!fzwSTmKr^-!LoiK|ptypN?O1hKA(HLPzMt(kgoX@D3KGk{&FONeoC7cW4qsbi{N zMio?UxkkYCF{U~$!5<1;eP6gSQ1`IorZ;SDcGar2;BnZ;vuPI}wc2P^<6#@M}#EjGj3xm_$kgRzciK)h0LuJltTf;0=~Vomh?4(-hY55uD_ z28Rm9?l(pK&z8H1u!ZceIRw*gGAnb3um3QE6TK$8mop0LH{^XVvp$!8Y^Xz^MzOy5 z^g6xHFT)r%BGz^=HC^&5Er)?f_^kkrrJe*k9+6<7ST0WW*cQfX1)%A;YzO#<6E$MR zS77R*<@0;J)RG6K7DW~?PqSa+=eSMjk7hjF5VJ$(P-oQ*K+!Fi%)V2l{WpyswNSna ziAbnH`6+8hd;j(BTrMX&1GdiK_U&(Sw0KQRNXw@S z9bH7$xtOk7YJ$nbMopd=uqn{1zp{$ZTe{D3e1Bl2VS;a?cJkdH+_h>}7VcYpI6@FB z@B_N16cJD6Ubz7*HW1@NJI#JWjbxd#t+oc*PA&deQAiD(S9TTbYzr5h9<(tyD#~=l z8d3(9Xy*!mLwdxNy+lK)D{GzCD1~A$z|`kixtAFa9>Xr}0Wh*ypATWsP#GxJhRA$M`*4{_`+W9hCt6!h|- zGr1W{Ys&!1ow!qqLG&AU1PvtnB&9iMEyL@f$>S!f_3tXFvZj; zQCUariP!;$8!az7O@OOL@|uV|xtx>Ihtb>`-y1Qiuh$xvh$n+vB^CVE(uj3mo|7Z8 zN!--&-Mm+NFr0l%8cm|^bV2>v{Abg&UWH`OV7qsLtlOLZ2D@nlmVVvhVSG2>HsP{0 z?Jx+_S`C{me;yp$c{hzaZahVHod=jCVY|=AN62U`G@l$jJe_=eB>Kzek0n0G-C+~$ zhtnDd>;5$Y@HMQ>Kk&SD3W<_I9kC*AT~G-X1`1<@W)su>nd)mLo|Ht3 zVr`~pV_C*Bw*)$&(*-^JZH6fgew_CFVRMiY15kg7t0{#~st>7luXn;)hrs55NKn|) z7O@a&K=I6mj(elgMY#T({V&M@0ZW3lmw}RZq_O5D~xc`~m~8+Q!{K zAEOSFra$wG6Qtj^eAYb=qmQq>(K#eFVycGo4!1sTER;?mUkO6-J4kzs*xM{((&H`!WtN@GDM_)gn4+7H&Nnp|wEM z&3~4XPWS1>MBS*SdJA$0mcr*f}T2QXA?OO~8 zSbu(IfHS}C*kHTu>B*0}N$>rUULW*RF@YApc&1e70uAw8ik9>A56;j|)bk!c^T>QB z<<@sMDxL!y_+jTVrOiKd`SccEUKWb3V%+a4WEO|fre{XZoi~{P3g}NeW2u?H*&>Gb zPi`tBK8AU(wKC7~&&-q*=6O@95tGT}@xL);gnJ0nXI+VM?e<#`__T_+cvDX~qRr+l zBgHq35}lHeFA-WJMCbrtaCtFTU>RVQCMurRJSbbilWa!dflbSJ*8R2xT4dLRPjo`c-9})zfYCIhA~3tV zh!=>waXwA@(D*ztV|?!(n%;)^YKtLnBX}O zF0Ku5dlqkC6=mt}F2zn6i>uG&Yg^qUpz}$G@+fMwn@d9y5HcERs!#n{+^Qz)k$=xq z7tB4IB!|;j_#;nb1^%!C<+;v)EUBm4KC^H8&RTrffQ=o<9{ zwM0iRr+n||(Vg9_s?(rGKOhv-gg(d-uE>%VqUzLt_X1wHIFdxNNF*^klI!;+dCuzx1)Q>iTcZ&y1F}=x4De0- z^(S>n-%%f9!1S`5M6Nf*a$K56&I zV6oGuwVK4|vv=!ZYYqhNITBh+e#Y()Q!AjxPGf0vx{^WX%J@enB`#BGmbM#&9Ez7I zA$!Nz{WoT#D}yNwa&9KV`+F|Mdw4sV&`$Ok@g@d9G!IHV++QU*sW+X?B$6Fxd78K9 z>2`HHsstfu-2I?E*uHngV9yYd&>i>mevO|? zchY2&X2AI+gvrWQfvGP5c7M7GO8prO>VDo>NRJ4;7kn*ZBgke-97qi({8{iH$G145 zg>e+bXZmRXfKGH5EGvQ9?5JXCoYll^XI|uSUg;Qn7Cs%nZjo0F{$h5E?{BJH<9o?o zA&-QR39K*|$0r2Wi7E|4WTN*Od6`9#-ba)FLsMQhA}dl|evQevjnDaD2aHEN^y=(rkV z71fgY-IJ9OK8XHR48Oq{ef(W3Kxa?Iqd`P-jxD3^`_&YxKD-?-m@C8lI`R8B}y zj1}0U!;XH9i1ATMpvlqCE2;Sc{#J9rUzCHQ-*i>$w~TL<ZB>kojG@xmu{6~Q{P%&`oUb$NYswo-^r{Ras0sn8yA5?hZ8Q?-WcF6wOzdv zyTESzx8SW}AgU-Q$v?eabR1`E5zdC&CWH0g9l1v8^Nh;i%W1*0!o!~6&|P+~1CA8_ z&Ax>G-}zg{kHDeTJ~0B>o;JF+ZWh7|v?c!!)&lQfePezN^>%GoqTEc&^Qj6?wy*L zt{uTrqXBtfN|*2gke*cF*HA~xNA3;93GL$LC*y)Lj}I&n2$rR#Uj{1^L3kYY{mJta zRcKw+>6aA-x}l4j`E~ru^@P5Rl2WvVC(&EEB9l(Eo4EqexK`6RI8K2_t3KG|(g1}= z8yLmPx%=y^j(T7xFn7E4NB!2)i9r!;|Hz5QfQJ2LKyF5HBNgTp_WOYXfMwZEo-ip8 z^W*t@_A4%E;g_f0AIs%Qm08_R&#{CB0^EjMt*h=sN1bDmm|7XH>UY1^4kf<%ny2|-e){iRzAgP57Dr_aoeEK^cl0|U{BdVoE4e6K1=(@&cj7%Jn32E`GL{&$YcsKEOv0roEg(@T~K>Sr_Z*ZA0fmrw{w{U5AD6ZDK#q{3M6-~-dHW@ z$+ak69<2pg_pItON(`K{3=V5#)DR^xmoM{mS8L{IH(x?PqXD~%ftD#$y8e_uW5c|& zeI>4rWitM7|75Vt%O>~8lkv-*aW%D6@&fl)(t&1ZYv~TJhiB`#B{h#0J`<}ix*cs) z?Qb83lztfj3k7)nNzrds!=B(X*e9jD0aJXJ-W+ubmTV~esLO5R8I$jI2%$F;QdcnQ zPto)=MB-*MU*{q9_L+nr7*OJ8cznXBzV0!z_%q2S`&H2=o0ul>;S|5z z=+r|_y`QLZ0*Iewr6oWm(4$LrJ?tD`m9{c^;cI=D(Q$4a|Ad_HfmwpGa&)TkD$dYS zS(8god~4nx{Z@&lZympUI=Gq0IS|=Vd)+3G8^PXq2Yb~xL{~|U-w2}J);4o$nG>~K zFnA8ge!de4) zC$1&CR?yAGdXAx@4=2FL%)J|YP27jQBHX)o>RJsh>Gd$}ju9;#sPW>7K^3g@z#(@E z?4QkHlpD%3FC++<|5<{qY!ZH)@deCKQ-#G4-ZMBaAgUVw)A9>|5ACjMlj#mUkbP^& z=3(>f;kjUM*tfM*vB4!KN2Ks}cGmqliGIT22AsqoE$zC#`ItS{#w@5z~(JyUWsdvn@KQLo0%ZN*b@&Kom2ei|JmVkF3e$Z4ZKkbuHF`&=>Rzo@rI zuDrI|pdTjetg&sSe~0&bwlMq0UJ=9+ALA*s8Il}btU>Va=;{i^$F03 z{t9GGEAJrUpZrjd-nbMx!sy<{K zo}6djA2HG!5GFtB5ymqQ;>0h`p{J?+G9o9GdE64BW}W*{3Xr+xL;Ivb0*n3*Aw5y+ zIT@hHf8Qff3M+^y_nGIrGg>nlRcXQGY^5hU=9ZSGs+E_MvWePnFpQMh5N$6BCq)wF zFwD_=hp}^VnX_8<30!FjJoqwg z!9tOo89Ps=I3+W#GzyaymM&36t!w<6xJw>kYi{9Rz2by1v%8Ro0o8^FY?|X!~1FK2a=6pF+rS(KKg(tdmy zsgUOyIHlLmpVpR_W(9??-)g#`Kf8c%Oz=|D92>2er2O@C@do@?d?6@_?W6s$Kg6?6 zbvIJ_zd4dnoU<1CD3WZl)>OyMOXK$X;g2+3#8PHhlNiM9kUSjNf8}HYJhm&unba;1 zif>4o8;a@4zqU8h4IZl&P)5wvxf*8@d4ugEYlZ|p3Jn*^Z|~2JTKsPc=F#FVzq|9(ee{tC7$)10gAjlHdY5cojwRtqjo4#!e&d;S6hvTB1I;`> z;QvM=D7KhYqO~EXJ;^o+GhW$kv6uDn7Vt}j{~b{g7%Qb9~i?zdPJNkXPKZlI-P8&Cdi9R*#g@bn9Vj5O31!f*l3Sba|B zq{b=>KuABdC&}N1E`T^nb@E-3HntgAmbX+G)>LS}BzLY@btDbR!1yeY^DffOd>$h^ z3(s={%&_XtqRB4MlQG{Dvz z9>c%|X@Xip+^f8k9ELpl-06A}v$*k9P~Qd5aaXbfsU9f8u0nL~m_Jx#e5TE}=MrBM zVmGrdu0iWzyR&G%2cEHyP*TH7ovvyb2H!OepBJZ82+!3Hb3X-JB|M=G0hIH5-2f+n}Gi#+PZ-Hk1+Yy?$# z^!Ek~SbQ!R)j1-X6Z9RuB7S&zZr~h(>m{Ti=fiXvS(Ql+5fG3MN#$~zMWHtVm;8`{ z=q8*zE@j0|9y9sM0;J9}z=vgtJbZ!RpT(0SMU(@b08Bj_fC?Vxgf zCLKFe1D@mg$ON?j)42E=(KDvfAe!##oOqeUWpZFna5lbqX{&+2Iv|Fug^Zpeam zxcso=nmN#D-F3;3qM>l0$gV4?Wvq{&?wV!#9`ff-udI|#{ygRlM^y`+;uHV!!=1-< zS>#Zohik%@NsU&Fa#b>AB~BjT^ZszHDdarPBdNpbD~}`kYS)d0Mh!q|O54r-7lWPi z&VH1(>PWG&k?PE08bQzN_aZG{My%bXtWgLphrH4HXW|8XXDVVM@2Z%F5>tw*ATvwb z(CgtDDHbJT27pg>rERGcWHydVP{UK37oJR1Yu1p!z3qXp95P`-#lyA3 zG?yN36@F{bv3bCPcC)QpLeVY)mE08pL|t1!o2++qMf&|jMi#l0NB@v?(zHmDv}qSW z&6WkexS8qXmLXXMVP>Ds41fcgtObqs*=T=$(w>vE)-y@P4DBx$aXVgN}(I! z?W;1d@9P`k=$M_=4C zAW?P6hNSHYXhJsFN7rvI%`K|>X~A*?p#pI(xAg#JK#+#iLBh)_B& z5cCNW3EE~8Y;KB~dJ&eYlgc>Bk*AHu z$q%%i)wYpWj!NFA-;>KaLu`S>NxK%dLOV$*xM?S@$!UItCzX@gjn;;$wGN-mq>Fd7 zpYq_gP@HjNPg=pRs+Z%^NX&k8x1JE$dUGqO040>E8;|%4G-{96`rH&>ZP2|b7n!%u zw`afAS9Y8TP{$l!Rf}O~9Bmrr8(#SNgWdO1r$=UYCGNmxdTI5eO5EVc5NbMsKSB<| zR7q&z#JkFMhlg+c$L6?ny*=M4!IY=-XN4|JRy#5_cdsMtsRZLVZdldP4!d9wg1hGH zuAfO-ZPJURS%v4{{Amt$d%Cwds}$mqxsn1(Y7?2SJ0x>}=Sn`$9I*-;(tfSw_tqv2 zQz@BJ<(k>TMXcqERvS~Zv(b`sJ@~riwNSre9|}7okMt)Tc42)}CD?|uBrFG9<2!yx zFXE`F_>CKjS)mJ)qaTu8a)?}_df&|9y27r@rh=?`S@Oz=awg?!X3j7?_A<8qd|o(3 zP@Ce&gUc{(&AG%N0oCdX;il&k$s=W#THkmqRB^rLVA?PoZYLT5oBY-LS>ZV|ay$X> zI|8lU?+R%Vav4r`H!RuSzbimwR-&BUtsZMgdo!N1CA7CfQ2PN?Z_(|1n3Tqv4aAH| zYkIjI*tckR4wjGF8>hX#=Niu~tk!O_neTkodf@j|Q_xjB6KNcS>h_6@0&mUYS>CvS z-aMJTp8HNl2aH25#PvBHf|XVro-m1&*O$0&d!bBrbJ7e?E_n~oRu(MT&}v>iOzM?B zDQpfaYiXN(9dr4ix4F9Lu5xv8BPcAiZ+_>X#}bfx6E^P2j8YS8^+ia!a#@B+J9#13 zd(&ZVo8xG4bTl$Wx^QCmJO1jO?`y?YcQpI6E1l4Re`iOpKO%8j z`2|JQpz+-kZkA8arGWsDOF_EECfgJ5Q{j>N*KG#$b>Fj)tO20^EtXw$=K87$Thl?M zSUa5|#n^rRsrS5?VYOU=k@%0Vjl-rwlC|q33yrr<((8t2!G*8L8-aq}zTTho2BtNu zg}6Agf1qb^4Y4wt5^@J?Re}~RNI9yyGE2-9y9Y%42;6&I8iU*s6({VBj&5*9a|%ctgK&M?}Oy5UjhdAM&N zFI1d?YNH&a9FE5Ke8a~-1AjDREsyD;UgUp#^!+_p8|c~9p@p&+rLE?rm%-!(9JTLu zCZ|%KUC0A%F+4#?V9eG5?p2+1x-YF+$CS)$NOH6jjT8o3P>UMDb^5XA&rCA867^eJ z<7Crq5idFIEqUU=l($sZ-uUEOU2l@5fTqtzFI3d1YX#qU*?b!xyq(khoHW-sLNR|F zr_ts~f5=RHUWwG@Z}Z(Cni47+Ks)GOwvi^U&*4D{`*l3YpB>x##%2ofxHb9lm)pv{ z53}-KEFIBB{^gXj0QD&!6}fg!p75_f3Ec^_pAa_Q1Xc<;ot`k7UWc43dwqXAhywRc z^CPg9#VyBRqHR2bVL8rMST^&S+K-qTd<4hm=k#97$PNO)kmC934D}wKRq?%}(<#DSP`HBUP%Vh0!zNDZtM%bDmN7kl18TRG{gw+;HaE*)vV*=>b>7D8hP>PczDllcsYAffImJPwiIPKB)ptjS2`hCR-oJ#@N@ zd=wfVNl<4gzsEsH0fXUH?DSrD-hckX=z|fRDn1Jz9H2i4IakcKnE&~Si1Jyy+V_$$LSy;^P2TE2 zy3xhkH8##!OJaDN)Y7@00far@T5OHu67~Z;?M}5!Ps^Q%?Q=ew-nxLD8%=JTO?*1j z1z}H81{0i4Bbw3xUbn(R2BjRUZ=Z~AUcZ;0iE&DDiR?zW7xK&7UDssz$zs|^e&256 zBnRz+MeKf%ulNwaqO!*jnSZ5?{Y%2~G1Nvoe~-Sk;!et1z6 zCEYYT+2OV?!+i=D_;5uf@da}#5|MYfGRN4AaD)|#kWf?ZyrUU?B=288IuuQrEi2xd8N>MT z@_s=+uPF8y$eJ|r0xP9vulSi|5yt-`mEG72g%(IGkd-T}OY9%k6(deL$g4}IztI6! z8nSV1%eOQverA)>!ns|732PGI=a@6ixL#vWMw_>nLn8xxsCfL~GY_voRyxLAiK)tD zo1^T{{Jf>H4Z^c-bq5lXHR#98n`}Z)7uN;8Mu%s#fx?!=8=Xl0wCfVy`5x6itebgQ zb=u{oKEqw$E=*G+)zO>n<)U|Ro$z@W`?qusJR&>ln0mO@^YqJ7=D&|4bs}>8F)+Fw z?z^CO2j%NNg;kBk8*o!8^NidtuZ_%+clRA}ZadyU+Ul5IBYFm8!(@%dsPU%#I7I0j&0;}rv>|P z->A1zZLeEA$H}@8l90F_@#+N7d`{3L_!1+h5(cPRQrF+KLAx15>h|WnrQr{P>;9R# zumNo77wX?b8!Wf4?Jse_GPwlOANwL-i5^-u+UijpyL~WNwAvxEP+D7cF>KO}lMNG{ zUwx|eIYwM4#LCfqyN@FGB%hRI3wz%vr<^@~#~H|f8e=sHB*|*IoigJ8ML45< zit{}#S}jgsHiuyMw?ivu?C+D>iU*!t%J34u72E)S=7!Xb%b7ygMWHTb5!4TlVqxC{ zYA<6GVCvw!wJk<{wt?N_FlIL4FIhQyMX~&m^>SAvK#{SIr+Sg>ug-^9dt3P%DK)qe zJj1g@fWdb2KZ^xuhkH6U`J{>i=qkC9#%Q+58;;?(8Yh9~P+%fI7`Zn9{Fy1|x%k`IAiJTp?Qojk2HmD6DQ^L&dm-w*wOU+9Tp? z`3||sHbVoNJptqT^36_}53*{=;X~ih1V+cFkyfnv>rISPJ6T-6>U!2rS)1G*6o`&A z5p+0dk6`-9(Xy4_eLZf3|DIWc@8SS`M0j#7{=UrUvJT~@Ry{3W?y9Y+QnIxD2v#Wp zrn;0u-YQxPDiZy^pVL1!3%O~x3tub6n%)u8T+M2eSLB$BCx2bS zAS$5#HkGG$qZ)cyyVV3K?mFyYVz0>vV6KPT6zY8~{v=eah`Gt})KnKO0@IbtDTGj@ z0Vl`PIGk2H=btl^a#v4_Q-IA8-WPWKeJ}UmVgU}lnwUiP++~+-h)TF69FE%8#W57b zmYe%IZWqYGy*fdVnzlBUKYe`u!`Ss>2g*@3Gal-z*c}hc3(x^>F{9Aj&45Qg-u5kw z0sZ%pCf6>evpUhx#(IR4)s%Q%UBZ5wtK#Vthf17y?|Lz@(V+*cZ#LmoO61iotL?3R z>H+~ODDqr!jqYsbl?tk$l2;{^9L(R7&M9Qd<*@czO%XWV>d5AYw2>|BM}=I3LMI?+jYLw%6XmG8MkGF|=PdGP}d8K6*CB%W8uf1-7f|7bI zb^P#KXO3_Ktw50lz;Gz&?o{(K@R^C2zozQ)J`A*|w`|#Rs^B2~Js_5o8NkvrP$c!v z$a_+%@PfJR06R#&}Al-L|Wo;&8W6lR*u zXLU2%MbGLnwXI)B(jzm&JSUI~O_$6ZXulgmO^`*@oO}#9#0y6z;@0a zFa#RCml7!lAMUB^DTEn@?gp}WVp{GwbbnL10}reYc?ZB z`sK2|n~JRcbo$Aos3E=GxD6huj>&EtWtVcr#qKGDE(bM>$0@R6HIj=VO^W2M2C|0Q zF|9-u(IZ!iXY>7Uwu{$z4|A}WtM=IzDe4$~*QMu}#<*Tt9y`(F=DwuQ1z)s!`CRy9 zUXzx9KeJ-|@Ns~M1sB$C&mFcbpdCPba9n?j9`aUbShcb)8#lcJ{yH81Zo2%g70zt-D}Qz zw$c|__uV8?mwQ3_?d8fIeq?j=9``>uOiKWSG~S*g>@Butz7|3NqGN0Fq(y4K463(-*2Fom-s zt{g0g&v#4+Vz;tjq9dnpX;&J>9#K&$%mxurli9Vyt7Knhf(dFg=LUAG*PDL zyV8QmRgg;+O!-bKE2Q7xgL2;;u@`RX9zY+xwhH`>ExC z7`~l+zqx@Fhx=2Pi7t=g+K?w=yCskF{HtPhvF0?z_4^%>2m{CT?(fav-RASV-D%X5 zdbX)Cj7>j&Y4l6ijkFBUOaFK>kEr<27k1>z8+Ii&(^#llGLci5?N7%4I8imlx8`#* z9t^n7jhQEE+k3S5t~r!;MAvV}$cc5^IsT+w1IUfpgFR+~I!pBXqywXsvx5$}jqvSP z=nEewqEu6Tzw{}ca`s*;^PYY6In){wa(fGY`1V)pavPD{-gX1od?j-{KgwF@6cwIm zM)-U6bHd5HeXSIi8gHn5kp-FA_sYUJ~rN&myV5y3~x8) z)Y7t@E`AMgg3mL{ygq1EceTRbAe?OQvs3#zu=#HP(VH{IX~|FL$5R-7hHTGxuCWf( z`38l`2Lm%{ce#3s!70wDzJ-N5LX)Q8q&-uR}&ROTn zS?jEG*5b>|+_Cq4?_XWlwSVln_QuD5RvzP~e`+ja^l09LKA)v=R_G;hlI7GQ)5CJc z=%8Cc%RGmMgRzPCZ;p=VppvqD4YO6jyd~PZwbbG@Z0+gTElUV{+ygizxuxxQQn^7> zwkoS`MjYuu&Ae1KP3{#ZP5gB2)pWXE8iw6{hqcp(E(3H+tLD^p*8dS2MT%Du9J2NN zIIm=f|CNG>gVE8I5Twz97yqfp;?R^3^0Ma*HU54<^9T^$pi7LB{}sdh!bdn^n&}QB zU&u}K(ujNZVE38k>!(H<(&;wf9fzZfj-sL>=c=lzrkRnEQlkiwa})I%D{bx9uluRY zoby<}-zEg#euf{8y)!1=T{=8T5prHUKP&MTIh7A+vr5*R9_->+z&--%dr64A-mYtgf@K z8u=5guO9pMF^tq$>k4dTMH_aaS=(zGpYP7>8^vpPcefm$gmdf)gRk17E@6W^vyll{ zdX;!&IZmiM2cX-tNnN^x_hcAGqx z2Dn>9Vdrz!cgg~l^ym(NJW%L;YlN5YhVm0@+4u_CuMd2a zr67>J7w33^e}J^crl(=od=L-&3W(^g#{i%+oPgt8jZ+GlNT;8p={;GRF;0s`@rFW5 zbj3)8h>X$#?=@Lw!L3`fnci=e9~OX2f=qs8$wW7oz^7qT@6Ne6xIPX@OOD_@PvkNV z=f6H^X_?u@3%hH&SY$rTG6#=Qx&9V8@rZ+V1ah`#!*o5@m~}_x%k9I88TgfQ(Y(@G z8MfFQ3ijq3OeDdviXcjN?kiPo$M=He7xVUtIgz?9%K^tremKFbM6&Kn==W>l7n-l{ zw{SKyM96`$*!2vTo2b+jQX#phhs%XdliOZVCZbf{+)J~F2<@^XRW$CZmrJ=~xA~i! zaa*f%F-C+AnCK(-GD-0;{ApG4E9T0KyL9;a_U6X*w;?J)&e9qk#b5S~q+j1NOfsU< z7d*g6Gl!^8H|R;|MaiTW;Ex1S(IQY!zPjs(^PQbhrjkj2jVGN2O7@0dj;v>-OIrBfOSywidev;tQV;)52&UNgQ#~cI&J*B0t?md?^gsv?v&nQ16@@_OC zlP@fg7-gz9sE{Z`bObS1Ik%U@<8o8Q|WXl623e_`shotdB`@Z@-z#dX&s;HBchcaMb-pVe{yVzgD$sOg zG)yvX=~L#I6ntL9A`$Rbkq=wTja{2F!p$`@U?+3&-(64Es}5c*zP$HcFQ3@7BA^1= z+Q-AiPnf2=4Vaf2l|kC*xZ|>ab%)vkAVQzwsBt-lzd-{A1eL?KrKf*CIuL?iDuYVV zaL8e;dXCN7HmL3_G^f_Ze&*LFbJrOL71Rx-IOi_*t$jfv^LT-tmLuM5{{*W(NGs?M z8yFrsa^utBUQ{mesg#ZwnvpgH~b zW|Xu_4#*%8d+ur2Oor#2-^In`sCy3%Ey8qU580i-?k;W%C0!{wy84}P)E{*x2>qb~ z&8UJ;z~`6N)Vc>9O3ju7qay|kVgWP)N|q;F0m7 zRWBGM8%T-gqxHwkeaCR8n>`zr{7g(v8=MbVVN`9CMVdxu+Y>j>%}gWX<(X>03O?U7 z5g2@4umKB#jzMX^$Y)PgDF}x;HJaCh)(C!c`RRbbVQ2DLPYO}&OCL=HRTVGx-}+Of zG9(QR4LKaK!Xv3HAi^2}VUxgPAS_1^J;o3tUGNS2Tny3sEdOEWbwiL5f8>RW2_J8{i+55P+YE9sNA zZ~hK0bhy)%rqQO;(Vf}O2a7U|ql*9g@0(L4X`y61OxEw5_UE4#s1)_>L{KqB0IKwN zI;rfh?#DE;g~Z+x(JhjuUhy&PbbEq1jjvvn21t(x6P||R->+>4USCnqtDh@fAqJVg zJYXgKQf!}`tNVLtQ49H% zfHA}gkzq#s6}H!N`<6cinZWq07cIzcL@wr)&!-J=W`JeFqT8&cQlewIn}PW|HTi9k zF{$F}4}B&lRb20GFN}^?dpYe^rMD&u;3EnjePFyW*eyB-{Ej#s`#zPb{(Q9;1aIuGk_KLG^KwTJjDH3u`P_k=m9*>fT0_kk~1G zsBg{=AiBI3)2)1nvZ-g7f48SF6EI$if;M}nCML4ImC#0DbJRhJVvQ8U$QM;5_k>C4+v56qV}>dWB>Yl`E(vh!LcQTB_Fu zPUN#rouLK6P5+uBVCS#XSuj9RAUaUT-FS{Xm;KE&3>C#m38hq$=D*W+MT?O~5Vr%K z^~KG9&lQXp@4Z0SoL}W|_%{MycEH}-^G3q|?c7KPqA=O89zC$))1A-`$)8q5$HzwE z1Ld6Ea$aWm%Dz83|L6l?d2XTU1-?T>pFU1repO_ivC2kU+} zl=vBb>$=J2Z6<5G)HqO}kN}$?o}_<9#nvPm|GmbIaa)V?*)48_{Ji!8d!PEu4r=Cv z{vFC=!1H{5A&L4gXVwNrYQ|@s$ocn+&rg6ILikve|2&n`y{B4eH0t~N1x*w%6=`mV z`+ZUOVQ!XA968{2`NFVT;(co_)A56QIXBrZST33W zjp%6xPOpyp-utml-xI*;t^$MOZHYo5dQ1^^=em)?fJ*IAN@3fH_eeC@{OqFTPWybp zS-0+bzoEYvDgCHrx4hqQ_2<`5!mL$^BJS0~$3JQ5byZ7rw6~Y+R&~8D*XWBFl5L*% z#)7gAfU}!`;#~6MP;w#xu|}l0D!tM}^AH zf>SRCr*s&Ruv-owj-zW@^0+zbc|aC2#18yizNBjQvL^@2G(ch)wid5jJ!vHH+?G`p z8i6DsL(OUUnMJ2@nsLn0aV-g*LeL=(aM9vJf;)xfr7s0DY|@*75}Y`ztgMV>nG+X3 z4+Z?v_1OJ%^G#eg1m~fMKIXwQjmn?a+T$B*Bvjbo7ag_w9f9Tc#U&+dno#TU(8>?1 z25p~^jo!1|r*;i{)k$Hm)Wc0k^dl#qX;#P3$suvN9O?-iwj%ZurDCCtV;wYK7XweY zTjNL?teqwO#);=<5=yj$E!x&vZY)Y(B1@t$%tTI-9gN_`hCn&k)t zJnhFta!=5oJW^6YZndT03fhYx+1CH%qQ z-1Fm!z(HE{UrhIT006^O=)-_@#vDb*B=^pWJAeRxKW6BQ7^F_(g;hA6Qxzaxs<&bpwbrY*#JXWJm*jDMGA%!@Lt8{SIK`{~;zvO-=l3Gcz(D-4CvGpR zjUNsqedx(1IX>nwQ$Y|{yWXu()X;C`A$wRrvQ$rtBDq2GDndgI#hnpp&vRigjTp}T zXoweL)pF|;jg*vITYBlbl^su3V|HZ>g#++KqRBP6i)Q#Ts!?5xtET(_i7LJc+x_Fp zYdypkk}Ksjw_bJC4Fo-8;ReG4X`tIF8Q=f}@44D(6r}S!hof!XY;x|Ew$u!H95R$S zp%;Q9N*XQI^Ae-Gd2J3qhf;))LkK%CU*TF9RGW_HNYg#q)iF1QhHy{Y?+`h6{>1i* zlSzii+E>`t$fg!?;STGOvb|qaAtUGxLXv%%Zh-+}G7>IzN%xB-4NQ5XPfwZpj4;$J z?t#-%f&&_aH)```n~xZiZlk+yFNzUbH!m)4akboxPKo8sZXRlJQA(`-f#oos^((zI zuY|I&7Dvr0v)I$E@g5y|(Z}*GI)@dPM%IDk?PU}eg3H)7G&t_M+0>Tv8I_L~;Efn@ zwn^(BHY~HbKHNyBt0DD$2TcbPHz}JOwe=0qqlCTTITg3`VBSJ=%44}D{1^qBSu8u- zN&8Xe6zlYY%o5QU`mtn>3^fV6U}-uKIZT!V^E?gB-CJ}THdi`3JG*PTLYqo3x6>uh z8|HIg~(pI7*VETNRo#0?C{DeiDBdL)@skmgz+Ar;7Jbai8&%yE9aB~q?y>+@m( z`}a=445pd}llaJ6WbPjA!(or*;oa?k6(o8ArT6S70AjULM6bl z3h9gx@XvVZ(+@Y@E%v%2g9m`uK|>o%h%xupNLRWlvGnt; zeN5R_3A-ht6>;gpIk@duja~pi-ij2vN6WMNHtxW47iJPJ7@2WThpDag%)Z~|AW_xi zwe-jw!@S_OLPl@p>s%uw8?>9OuOL#sAVR6j6LsvteQi`9d3X)=@zeDu>UWniVfRcUi88wfVrUK7t=!B~7 zGiGD%Rvb}S`jW`G9eE@6)y>IpJdc_O9~^*Nnfc|oj}xF$v{v4=3bQb%(AjvdA{+mF z`1~P|ZzPsL9bde1-v{`BV!0&VK@Z0=k&BuQDn=*RDF=`Yi}U(^4+RMWC^S%8@m0*o z6O9c4 zE`rhYkWpDJ{&?&)TQ+&H-4HXhViJJN*^~J7Z6A$k%laLz52vvyf%WO*-W?5A2*1XUZJ`71{e-Zvc{1@L(ppTu({4|6*wI+hM2j~QbjGM@#{fab}F3{r40h=x+T z?9G1Y&5mqxhL1xI{@bCOm$Va!SoZg0tADHUXL=OA-xUx#kzerrr-JEw1myL0$DcU< z?FcWwM{#(6VSfIb*fRwIiG5%1gKq!7U-Z2K0FfCbE}DO(1qB$WjfFm@0I69l0oQ+y zlTPnIIvg#JRuFt@j97PS?&A#ctXXPUp3W%Xa!TB>!Fc+wF}E~L5a|4E-Cp&a;ZU-G zx)s)R#GF@UmPRvWYAjgiZ$%Hlb8_k79dKkWDAwOnQ>h9GTli31U^_1}YyX>h@z)1z zjiqJ;?VtaH8$O}6S^X;2M;jshK^PisY*jwD8S-};(tz{Kf`Id4kvRVCaKDEr6KX&} zX-%Ujc3a7!SXq=|absVIRqa1IP#eOnpKg;E8rG3Fdd%ia>g7K0xlR zR7%JG-x78Y7q+G7%@j>9&za(p^rLVJAA>jguKNpj`hFKQyd(C zE3Jsox!?f5+<1Klza7`vuZ3dUQ&k4h&9gS0zIEL#>oM$&qAQ=$aql(FO^K_nd0r?~ z{0P;HK`w#Dy7@9kE=_d7#gAh5jSa-}BKuaHs#w3U0Soo~jef@+M-N3b0m`l=#jSov z>ThBVcqnGE;*XK_wtwZTZ?yoGixH6a<5x;ahN6(~=cc;-PPwS+74e$Pc09`OmG60I;i2LTlyVhZYSp^ z?iaOzVmErmQxPbnC?R;3(1^gRsMo92J;Ydp3smt-PJ(6go;AdT+Js7zsAK8x%blELrO8R;*yen|IhF_Cm&k~|L_~T zNI(Tj*Aa-t>|Tpm%8UNw8(2Iu1cgX!j{kex>0HO)`7eE(u2xox7m^PU-AM*|I@0xP z>_!ehY*KO_N=jn!kuYMPQ;0YSy$9V*F1q~k2Hq#t&GKhcM3SGCnV`=QLRBq&GVf3a zy?3qF)s}PXEvvtKqBvmqQi-@Z$kt+3@}jR&B8ZoBVEE|UnwL_6u#83)c?V3iMyH>v z`{3)5n}%X9p&|yfg`??7Q-xgVjfi)MtwMuJ^>)GH$xzW7_76VnxN+WHqll-cH4P&~~TGBq@6ErW~`2ixtSo$%W`6ot*`Jzej**UQWNJ4ioVr zS(GxcmO{ah=a@uaB4}26tjGQmMAs3HCeHfD4U3ziSwNb#4<)#{uNE4di9I6pb|#C; zfy~3}Q5E;ke)?E|&JiCh@*xoaP7EMyQ3Q+^Dy`?tc^yGG!!qQ}Upc+u9&H!s^^QAn zP=%1b$E`&^%*PZ;w*xA`xImGK4U3C4Gate|xC$drsBZ>K+ z@cbI2D^JPs!M_PpYJ%F=Mr44g)bN`&J zGB-M0YP)P4Yihq|Qc5xP9q!{-IzF1kY-KO^uFT390A)N`+|2#oe?Q%sQhXIg7R$#Z zdq1X42XF#J3Yt0$Kpd~!&bDKR$rqR-fg}TC;Nhz; z_iI})Njy!|)9`4et8BED41p0{4OLv(6IlH3bW=IH?^iGY&`-mRTYV7LweL#5f(r3` zK7quzCuDrgG#%H;4dm~`BprhfmRD&#wPv}&j_%xePjzc;_$+PuDxLx8<$cn_Nb>Y| z%r%P!y#fbfl19by%i)Z?yKlzx&YOx8`LCrYu>*7yGVOnpj@$cz{J-!3FRW5M!^You z?T`3YfV4Ck%aR$Zv4$wfbmqt>8Fq(~0u)8E0(zS7N8qjhEL|eK_f)@FfKE^Gx?>iB`k?tpwyinU?4 z+zyGD9OYpIkfV&;G~e!7C(%kFe)t+YP_}Ch0_twVjiHos{SK6wM%Rkn*{TA=FPVD3 z*U2{0)!7cieR!UCfrb$Vfo-49n+OJp&pZTi-;ncJabt-F`h*MZ^Cz>%?ldu;Mbh4$A+W=c3A+a_PEjgZg6ETLXZW;M8jcRnXvuya%l0 zajCh5MIq+%P~_i>gT~hu+8xXDK5vekjO^ZGb121|6vyj+Uv2pY2*xB>xRQ4OBLfTS zrjjxVOu%l%fnQx5SWlujuo4CS>FNcP$(uL&3&ipp1oxCqs)x3=_7!SCt8MZr4qBnm zZU(N+=e&~#CZUljf_|n}xiZiO z?b>t#>Rw7~WW6?;n7@RR?+_jCZa!)Wp3t;>GJlypZQsb;%k)(Y5ZMJlWn-Lszk-Gj zdb9ULg!uqli$4>lPkMC)6Rs1sIb{d({pkZ06VNKpxA25yNDQcr1+sLBR=RMqRzpBQ zPllBcwr^dYEZARZHW)K=7mMHIy zD^TGKXyN^3z7kMc!BK#ABvJm;a|4+_?b>{UpZH)c9y&^V+olCrQIJ|Xk{-+(AQC?2 zig}QO{s;dhzJ^;`aJ@H5%~gm{yZxi!Mn$-U6KtdmYDFGL*u4EsJOK^PL=hTMK6l@3 z<)-m|?fNA4ZT6AUaSg}}l~DP&+)X>kXK!Jy`|hv$>ENI`CL5S<`Ro&g4fL5Cyh}C3Eg$O$cu5&<|L%Y#k;MZ04(vT|lo* zpOlX>2wjcZ@zr-V6dbq&}K`HIUHcj zS}bNbNrjvWU5z+=o$t?~@%{dPVAcf9?n#dmQzwrMoR+ubj1?~1Ko1b^?GgBM zkN}9edc7R3e}t?!vX9Yk+XpUEf3Ka;W*<-dN1~>KTRDL-{QlFv55lYoTXLL#FQtT_ zNBWQdW0eMyQQ`py`ozEY%mbBT{<$MSwgY5h`h$;x(f_L8cOW&C`!U}S`vE@C?hctN zMTY(la|n!p1@Uii9YF?Y$IVZPLr?yd?1Z4WzlY&(egYo8Lz|p&)SrqC7y+pNKP>zI z`80h4Srb0~8Ed_;ud;%`OM0L}4GRmSGd>y;I{29^V81%Z2Vrql!=w=aM%1f5`dc~m z3(0phQ>tG-h?0II**^UA0Mf!@dbP&p{ZzBs;%mSIfLanpiAn?If{wYq{zwNG4$dO(eUA3f(`^%IMZwTj;E-@wF8>z&Rya zsnywK7wWb&dp>tjeS`kc5(D&&va-)E0jRF!0lquT4(YwEK7|)-nbT=^y1cWXLLk0E z?wNM|J0M)s1EOCeeR9k!KwM)7U~TZb-KH6Pqu%#-4NoYyCFjR8 zK79j|!0imsou_f3`Mk7@k1K(62Oe%b=_HR3wxRa2@oU9I!Gxh!H&{A1^n7E;=N=ya zIy8FgWoIs<-VmOZss4VqaJH|>UaO9CSc92MwYXAi|EE{f7E^U|ny~8!G5Ar0rJbD} z^KO=|$&L(*$apsZpq#43r))K3WMmLXECcEc3rEMZ7u$lxvb?;!7G`FBf`WqK1;K^$ zOdK{(eyuM!L#lLdx^yvL%l15b&-(1yObdLcW!Aa*gz|c><#vuK>GH!9Nz;wJ8c4P7 zRkm(<2r(O#d1mWLgx4wU^$u|GA%(dSAx6;U-MRH$b<^c~(mC*=-$~n6Noz7q_A*W(d(EX^A5h1 z1~;9m3<~ofYP?u<&qx>=Qn(%$yH&pS6NC93%2Vjy9pc=To(*=c4&U7j7Zg|L&BzN+r@+1#V_K> zsou-PUXO5-2=dwA_mbEJ`mJ-X4%ETcIMW>AC|Wpk+KK zWl?0v6Tmoee6K2$1#D|KoW;UJAR>#ND`N-nJyG!X(o(v1ipCAagmF26E3yBnvOrTv<`{Uf&szDD^7JDmHuK)|% z>#TNc#Hu`)^1ht{_Ulhh5|Ka^ENx&-&)`kUZi*XT$;}N7LN`v7;nBz57tY>Ot@fg6 ze4DWiB-IOx&SX7>WGS60fgK@t*DZI~fixgFT-)T1{R4QIqV9>%dPQ3_2GoVsNqYgSJoC69Xjbc{gHM^O~N(^@;66|j{(+iY2p$?0(5J!zi z{SzDDw5LQ@K&2Uu1WTK^S5K-L`0_ET8B3O?8y`f!MjYn%=N>U{;?yPt|DdNXeWi%|;@MJn) zm_#hv&7ppBa&kA=q2Ru#3EHD*x4&N}#?m|i%sPGB$t`^tQfHFPkf(P;{m+WhBTz{Wv|oV7joN4R}T?0_AZDwTy*WEwVUS({pmC zUq<`ysFuURkaxCCaGnphuS9t@zRo!4Ctn*GHl226VooWZJt%B6<9IKypx#5Rl;%h> z4EAVMQdTy%Z_=Keoj1H8>gi@c+)pLCWQy>+^`|m&f6DCJ)E!4OYuQvwVe<3mbf+@7 z)obabQVN~HXun1nrnQ@V&^D}6HI`gZP&TnfXDOgKbJLE`V}TBeJ$6%X==%Dx2DY&B zV=yGWys^mLO_DEp!F?v|Xzw>aSoyE>}8TL$DD>L5n<54ebac$Ha8d>orIEM&f-fT5ac*IYJ zR5#aus9GV#x}-1AAA3TkEWcPwd30^Mj^!ieogR-pcXjoxh~*j5x629ZN{yyd>E~&d z)$tbYM@e~`MN`o~B`F8s2lI6V;R4EaiZ);R2}8PQ9<`pb>NZmhNIs@aFZ2^%5*Os8 zxN2&iQi(6BRH>{FY+QSwxP!VI=Ul_Tz4*+lrq)4cEUsUJ>g&6j^2WSuestk5`Kayf z_T%sxd$DHdk6GbsdBwWxAp(?q72BAaClbc;Vj6pwCUcoOw{z*#`{M(5G>*H(Ik!1t z=m|P8g4mzth_m+?M#F)Ahq=N=%v=WeZ^o^aKJnkZSc-a9C%=xr5e6|e-*pNJ8Na;t z8h01HiB$a*5?e)Fe0v!C9-T9vv@%yrTI71L0&=QpX+y(z>mZ;B*$$Z{D~e)TI4z93 zV`dq*$SzWvw6c8y`8|V02MrgBzF5YqW&j4&C{nMitE)>t-D%|PVX3XEns9S-3#~}j zy}O$7i(~oJ*53Xp?sHdXCf$((UDBTCq`}9cY$MCUxs@pL;yj-^V|!7*NDP@&^dDr! zgUP)IuivKX6;9xMHKJVPjyii{lhZ%H=U&7ABNPg~aG2MDT=$aaX21N-p;D5~GOHGa ztHfl={Nl5XmQqba?lC>O@OFMRZbG)a(upwi(L%)5L9OLh?WuDdQK;~3!{?SZ93+?Y zmZ{lFdBI%5>93<@rO!w?_oMh&HyFoq`sa!cKHE>vtTegkk9^!%-&^#P`u4&sQLFx) zEga@4c1A(Jr+*R!p**ZGo27^IJ6wKubgZ6ZNLwgB`qIlT6MFf5qfN0!DExJcYEt#A zgY9kMBG=cuZoXzbmuq0d%tIAKeuQ#5P~>Nzo0!!++J@gKZs#;o4R4vTPmTyP!v2^~ zC#12W68i(IuCVojb_y@OA&0nsY^iaSg06g>Z6;H8ME^WZpY&RcE0lQ>Jl=BR@6V*Vf{*v?j?NvP3U; z?K#Nh6PRkv^ow{G^smsT%{#e@wVDmX0s=uofnU~n)L-Oo^XpCPCMKc%5)R4_XDozo z$=?{agu6{mz4nc$;wBEQBOsEb#)&{`OHU;{&KvO$q$l{HXMn zM2{LFfoJ$FnE6N`u2KIg`RL<8TE!XUcHem~NbE*mjdLkE-&|;a05O7*cymKR!NTB*htynVA$JzcJuh=j>Dg&3(cMkXu@9AlRILp z-fTJUF=vlK4zdWPBasg@ib!6O##^CaNK4mMvEWdY3H6=}Y%*wXglIuzYQjW?w*(c- zo0Z~C6c1neTz0kLzyk9pgOkLQ!trx5Swi5p2%wL{FK{%5Utk~~M}JRh^(~mM_UZJI zBJo~AZGZY1WlDlXN#`e}?a0f={AKIr*BN3Db&0fD%#g_&@XpR$3y9e)q8>ZiD_0bC zZ20>rg)g=}D9D!)=?jIz1tL3e*42q)lN^y3{|_w_5dvF17K_q3T~&{ zZRXcpmgQ(gkPOkF{u*tZD$*fE@Dy%(I){hN45M=MP^pU9enSyHBNW(~I z8%e-}p~D~CvaP&~%QpHBnVX38l2;fIqo-!=cY24u;Y>KEZ`1V8OWtL$9=AgolUF{` zer>?*NsE-E;_+!2luO-5yQMKf+oVZGBf3IOrMOTYN))Q_z%O4t=s`fI_2Yu`Llta3 zxg7hh9D$W57u`JA%AL_7r|FHUS)_(JL?Upx{W9^~O1_q~h z%VS1))Pr7yXjA1I2p_%E=wc8?1F=4(!CV@lFnmu#5&a<9z&U}516S8<<|#vLgI<~P zHzf{BwvScJ z8Vo75o6gO8zBx2%6rJA?CXwsZOf*Cka`0Jod5kVLK#Yisac1}yw@b$kX|LgTUXUxD zt!g{-8LI`)$Iw?FH(E~Z&#$Tw8fG6QaWHe8yO_D~ouYot}e0~9Sz7cJebS*+uA z+~*eEHY^)PrwkprA}qD)?H^RR7VHUF?=4VPa|l|{iow1Pmc$fprC6)ojTo70kDl)g zQqLCQELL1lvCjSkM{}d2t%OMJEmiF&Pr0j&?4O9^jKI29%=Ra(NnD+jErF)1FVaK|`ZNg7?7UMP63FJm`em!eZDdbUS)Q1EO42QjU@-E}Klq{Tx%R#4 z)N#5!*I?4_rJxPZ>vKJqJ~GX1i%p{isqdLbB31n=TqmuS3VN!V)@nN%1&*R#dR=(v z6l-Kjnm=E=YSBB*kr(C6n>ee?7LLpr#9M2XU!4)UyEqTVnYpn*QfkccrFkm_Ik@Ib zupBL&^h+m16Io`v=b3_@7nP&e-(Dyt8`Rh)&pnMgOj%(}o&d98)_svs?B@jsKiar* zFKjB}(VFDqJbob%6~a9I7EKfBYV>G7;%@UptKz!0q`)Qh4+FgucMmh4G)x-JDxVP8 z5n2xigrj-oP}cU5j?wo`{AvT-!_#mDl

$dNU-^K7|H{h0dPR>~U&tR_!4L2#4@i z{Yq`h@trezke<1;FqA?H#sL>j#5wF_%&a&)SE!AD^V%_Qgv>7b$MFEAoy7(2e5*qI#XwR&)OsqKE8K1nr&sn!H)HvCXq#kpS* z7^Rz1)rY_P+FG~l!%5(vuzEFCz|@9WQFa+ice7QrVAo<}T>RF$p!xpSN9oxDnrS~Z z>*#a$j>{M71oVsKYxZQ7n_@S5cCW=!YT(QQJNyt9tVaC?$DJ|}EvqVc@ketV>gotF zmk$S?rB;$D{Z2(CU3QlON96DEad)u<$T0VL;{5RSwBFxjMsz@(G1h7+_>MBISfc`oAf33cDXyec2?^5s6cK0W(!)!I}*pgU6AG<)o>qsH~MB zg{kbnOqYw5D=zYg@qN7#M&%S8YeS+;dmc4FlB82y;mseA}MjLiv@1r2TBZkiHxtk zT_4*s+x6e>c->(naw=tQg-`HQo2Gd$9`C3f6;#wETa3k2Ug&64+fmYc#aozu9Gkq_ zX7RrK!DA(-G1pl-!F<=Z9Vp)?Xkk!1jvMEcek3!1|bzLt5do%~LkTQoWvU7zqd<+5C4W@zg=qMO(nHMixl;#sjcVf~V%|3Z5cfl(sM-vf9sCPl{9+-+W(?O_UK; zus>Ab&!uOiWsR;!haQP$i4vdUYgum~=3+B|!#6VJj&ToM4_(ntdOCh?gdeYXP;J<# z1fLuq${g4z<@9_N3k=|ABY>Pl23k`cuL$eHMyT6G!Zv8b*^_&OSo~eDWR3O-H`d;S zLs=Zy4e_ux2HiRi#1Elpufsplvs-S=1$Le65lXpc+45g@kX+1f6eopd>V6&u>H z_1{BbI7%gkoCJv9%JjJNH|L&lQ%Ti|-K^usywFdz8CTp;e0cz?(-d71UR=&fmtB@2 zvBfrz8tNfo4tD&WQYU}aNkTuYLhkH;Nb)#KJ)&ULwePLzL>v#gcF|O@gKAopQ(Tdw zOzyb=VseiyB-R1ntU($CS_!7$_h{5_LB>bbS7p@0=|9P z7aiHF=&u)-3iiZ$d(-cDnpf=FPiUtC(J9rc2uJQ4aBD8Lu;(f`-zFvxdhS(hvM2w&X$;Q%S^)QFjW=ZmDZ{ap1K*>@U+aEts67g}k=Wqy zFvGa7s3=3olFu2j?3z>Ce6@X9pA{9Fp&Kcvoa>oTaC8oV3Q#d0`h$}R>Qc6ae%Q>$ zj*lsX#aWq|86vzHD6PwXH=5|3zq?f~rvmrz&MRHV$pw_tH?@Dp7dcxm#%J0$sC89&PCBC;N zD8N7I@^b{#1(hg>A)FR-yV-*#SN7IQ zZ!ao9#lg_((r?N75P$cRi!Erv`6aaFWbc^b2kkjx!WFHW+_|@twvRK!$0sy3c zJj7y~E!@^lp5leoBZYTQ?XEea?AM3xxbVVsz#8T0vIYYWR%-@$9K8Q%tb^$l#m zfu!*)>Si_@*$$f^c}x-Xv5?Tov1+a=EaR}5g*SrqG)~4i&O=nwj+cVg?2W+q$QQXb=+dMP{ zjb!JMh%0WSv?Qch#ubGrAQfcW8g(knoK2?@Bq&?aq;7dO^l3a zkJ#DKp}c5B$cZm)5M4K|W7H7T<-()WRdiVSX*jnn{{c3GD1<6P(Ji%BP7!Kb*>S=j znu-b;CkQ(6fbkC#OvQI1JUBuRJvEAo*XrGtjS8}6<8yTeA1v=jL-fzCgt5~~`IFg` zH)w}i2uPxZ{aurLpitrY{;(6g_2sOyT7K$-TK*L8pwEM1sqqdCbqg!b!S1}m`Ls7{ zIF4g+hh)#45g&EBCUVTjwoC6W+h$M&rdiqH_rPTJ^z&TnJ8>cdS13N-VF?I_x_U?K zh{Roh=wSq&%!6}dt0E0&qu&T~H7pF4ehexC*;!2ZJdcx_wq~X!OW4fVRl>qI%}SvP z;L-L{n7BX zc%{AN7*Wr`^hTP=13jZRm0B&%=93u3a>9@%OM@Ef8JM4<tiKfUUvt?=O&Dt?{VVukC(b%?Kz-h z%WUZHN1vOj315u6gpa#p%u2Zk4lU3qzx+Jqvst)p*&UdZ3sU2>i zQBZl7U&@Y1Xl1*tl%6(3AeV%=pnhTRkw~^Sr+B)!EPtE_k)*O?VvTtjyypyi&@uyc z{FM)BJU`f3rZc9O z4#PQC5wk6(gc4Y>qCO6VME{GXvyO_Y?Hc~j9fEW!Qqn1%3erk94Beg5Et1j=N~tsq zA>B3PAl-~G3@~)(H{Q?t&A(^OTGu+)KD+mCi#xgRR9`-1ItK;!mJRJV*ReT^_J{bJmpwmFnR=#(lM8gVCxxa>6U4Fq)xm*MS zaJG9OjLR5foS7NqePan>?j+T+V9|X3JvZQSo=NiR6HB&-6%qCW8alu@;a-O-h7HFQ zJtEV^IMw_EE0n<6gp~8y@n<^e=SxX$g5S3NY#zBK>b`GDQ&V7?uVH`iVv$25O7!@A zCh=Egiv%-GL5Hc-}8h_s>=&)7yB8Kj6Uc^PZ}Nh zlRK%RNWVB0UL`iObZ`<=0dENQmB^%`DSa;vwC9;ZK3oLy?9loXec)DmyYh`hVmthn ztwA%Wdu#LBl;MVB;8~|uUi0|bNBRk1Y+r2L{#naH(wQtsk|_A)9~7n}yyU-Soh1{L z>b3Og?sD=LP?TR$keChmX*O1HC0u%fG$Iw7`>b*X?UV-ENpJKnl0I^Q8L=kRXdLBV>dAjDfUc+Ry`|IfnQYj63g$fy`Y_dl0z z1(Ly3j|^QLm|T6bq)ygd=U*-^&zDCJKCA6&8+|OPFRHSvBgdh$*okA#rBn}QRf{s@ zyTYOIUnz2qW_Bjq1sVTb(|rY4xQzjo@1!+KZi=kDVmC3x!MARiMS!Fk7@y;iO=S)3# z*XBm3EJ~6kCqvV6Edm5jAN_M)Njz&!Y3U#HEaVQ~{j;Z7Gf|deO+~U zC!xpwK5xeF zq9rHtT;IoIc5ce{^);<7_bv3>vQW$`zw*;Ka;Hx$OjOCFD31j*)55GtVAjlh%ONw? zy0>fWM?UQ7>s$3Q12YRh@>uDpGdJD4p%2@@I*kJ7EO>~+&KoFn+kWMhw;yd#+Bq_8 zpl0J(Ij4R-t^ZNPe&s8nUy7F!!&&~+D-Cbs&LzV*(_9wSEf<1sIaVn{ju7EBuir_- zO7e*e@k_7X!4x_&OW#vMu-9$}Z8)kZ(sk#{RP4+H1m_vG_V|lUYa}-L88_w9;U*kS znvCer4qEEw40twCX2J*RS-Nl?NB1@4!-=YB-eb#dCKnK6e^T$0Y(T9|D6;KYq<@R^ z60Tifd)7bxOpaaob68K6gJUSxj_(Q@s$UoZCIh$JRAw2InAhjoC;5O@kYy^xYLN25tB=@9RqX z`xL^!o8UL@PNg5Bk19wtq-^fh)TmcpC$$GrmdJeF?!6&?!wJ8*%x@F^hQQoAl`2s^ z{gi!9_8=eFPKLr6sm0@coSeyP&d6Y$JPEzIeB4<*+Zb{O6$Yj$8nMlQp{rn~#6b5v zSTX+A`=lf$h7))oG75(Wu0`i>eID{RF=e>$qXj-DXSfxJ#Jd@nia`ARm86!^OEiWR zG%4(_S%MA%=gh!r0_=+ZN}VMLchFENn2EsO58_U5`g2U#ysM}HVBCh>rPTddEt@EqW{#uAT+T&<&41V|+|%?vU#ANBi71jmyS zX}~o3e;+Fb^B2gy|9tEwm(p3P8f^4<_vu&StFOvhQUvTCSXn-lDj*_7s>jGs%ZF4D zyZzM!Ssnj}VyR(Y6HsDY&7z~;t@DqX>C+}F(yOBd1jECE&8hsH2ZDh8H__s(Ps6t! z^0u2ElePzVnt@8D$-^K=j@3H>Mue9^G!8Q&xiz zyq0CEcGB1pzT@`POD(8+L;}ABb(+^Z&3Yoh)s@z|EJTy2Tk!o&5|t!wXdL9-^{y?$ zvPST&>_R{YjKft4;K#)~Kt#6otLlrM*-f}fyVr~M1`iZ8D@+{@K0N648g;^ z!I4?+bPu`NvyYh&OT6VIDNPpDe0~#3H~m;NmaT4#O~N=*oUOd9XGHgZ`%cuPeAk}- zGEY!Ro%H+rm5T7pY@SOLB)P^6Y#xhrc8n?Cd_G%8^>^zIkAsGW4b2cM=8N<~-22b` zqymlel6d!eS!pRU;qK=(0^X2r)m?Bu^F`4R3auc}lIaYt5hrUkc!%kecBI zA^MPlp?x=LLe?N-bxqsT+?RPLJKlbsGiMk{!Alo6Ec>+W4rbT4ZxAXS{xm6=Aqg2U zMZ>d<0Jj;N+Zw~o@tOr0v*wHRp@aKvdXC*;^Wg0|A)n@Dimr!5U6K-Qwy4gWOK&*w z*kToHoUkbPEg=r$eMnjM2+vOT1}Rapi&3vRgwBxbm3xeIzHKh01YJSk&4yc-W=>z^ zM{(=uo^U%P}>j8hM<3uI~#L(9Qzb&>@H&))r0At#M2^f6!>hj}``VCv(j8;vil4)LF zxP~b5SzeL|{YL+E(}KSgkE=NMGe8Qz<#*h~A3Xj5f=zSM{^Wd#KiS+fz@8x#+XIP$ zK#4;M+K_S)jW(n9A^(TN)Hl^hNBLV@ZV<$f&ZtTU{FstFDX#DJtN}Zn!f+9LhY6i5 z7LKLE)w_uME0Rp;4U{+Js%6!@s7<&{=z1;4{f-S8E5*bPcX!KtAh!wBr6tNep8~oU z*0)O#S+0B}Jl`40~f7d_l?Pmjt5Tztx$UA-N42`WP@s3UIh)}otO_UU$O^U?s0 z-mT8Eq(3}h-pjij3pW+LA2kw8c3&^vN&j|DI!e?J$*sgzURRdxwMxN0oZUc}jlmn& z?u4U5gK^6NdA$Cwo&|_9@E)d0P3SonLnQ)cf3N#}2Ab<@?x?7)e-CYXQQF4N6{dk< zDT71~HHADhKh+XR-!9OPs>|x>`7SVFv2K1*$NtrXPmGRAV!yDqyGW)z8hvs{A^{PW z4z}%8|Dgm^C1Nlh0BXxo27K&Ts-{d%u~clE`-u(>S0|UCrvEy)=Okjl`x8N^PP5@4 z)UxV^wGINu5^bMYs!@(zenEpHYsFiE?kmW9Ouhf}jwWy=c@2Edy9MPRL58Bp3|1!G z-}ehso?wYD<;~^s>ehRxxBu;e#*qK-^iw)vZdr`$4V1@nTkmd?Hm@LhiWpLIn97iU zVCiwk)@R?$i6if_KFJ^yjgYL<_V|T$SO0)g)`Io>sIXw112y3?COhB5mAUIR zn_l;afQ};_GqEQZc&t1yH&rg!kWKyQ=yp5m#jqRcpYNq3uCbjPC+oHIh_18iHwW&l zM_8ZV5rK3JXMl(t83Mt{<*G^P+9at!t22sfL)e9<&(BVEqu%i9SEU!FLb(B+h$(eIIj>UqTCQbTdj9$i_s)8b*`fGVgIh4uz$_+{48MB*t9U6cBUyIzrMWlW2 zvzo2k#MO5{L}EQg^@PaOvJqi5*!qkU^<@qLdnM}7G)`2Pq0}Wmm!5NSHH`+#W?o!f z!2Oh(w?V66DeK6wXGFCPSsW6w(N@35R<;*AbG;`=o6%uQIn3+kMTyuFN9}xW zRf>S8XBJmDhcMq*F_ukFv3K^>H`y^(P>Mv7Hx<>A@4>&h7ZmUkNvp`o$VJ(wE-{J= zIjU&(cAl4+IE3_Z6EqsR?#HjvEAqA5-K21?UizXxgf@8+`1qb%20Zm0Etg+(_#n27 zE-%dJ>IZs(hl9QsX+7sNnu6|1hKWKx3yl?e2fygg$y)+8 zA0x2%r9~^XFa%_40CyPKVBTcl#sQFV>e;jBfguyPY29cIguE`O7~?N1Uk!-vl7dKY z|CEsGQffuak(Yu2CJ_^I;J~{L#{2CB_h$>wQ8VdxJ{xXxO(rg$Lv@TY?bm0+#}*uu zx~kTJxGfkqVpluv>dpt~mmdh&U#lQ3S>MspX}7myb*9cDp5DRIeZ1tgow8h% z({ElBGVaMQ#SD}X~3+3nn?H+NEE?k9zuYSGN`i=wsG)tS%Nm^AvXJ$^|8m=SWIOhm%vGFo=0t`*%s zvb*Z)fb-HZi2qL)impg;!ut zi5QoTj7@KON|(ldj|o7Vd&_G5Ls72VK`m9NdOSP+dKvmtienG8(AUdLY<EL1faqN&w8CVO;c~~jkzx3#9f0*wes*-4|R4R83 zIK*m7Rii-%99jKJT!)|M)549F&n5C|SmV`)4!EVruRnBK!UKa$LLxqZxXAq1^7lkl z{n(6nzg-IpNFpgCG|bt-@bUS9B89^aq%5-9Ok`LkCrS-)rNO=ee=9TF0xsQeRd`s&~BHRgq_ueo9h^5%i zMu`}t=EgPo9e?Ih=%L#R?_&udWzKDouU5cbQXo`5E>HIcJ!*D_=8b86X0_RDhGk6S z?%m#nST0F^UNS#ZhAMJ0xRS%oHA?6GLC*E7nEHu$QqKB$)}FV`XZCpJfxib@c?b=( zz~O2>g$+yOtIryKSdJRf{iv8FS5#_pv?*&G6|?Y->zFHL+8(c`4d`ed_uzmzORhWQ zb3yiVU@79diL(%awV{>qR26}f2%isj6^024pEP{S3%DH>m^zw`C|>6gDNc!;V(J># z9;5geqxFHUv!8m3hkEMQ2jXB=4IO=^!SGTy{KIsfz!zDZgKrOuxP_?GE;&%~Do~3p zD)X{oa}q8c7T5H%#5-8qL~gwYaJ*jQPdk2QsoWgY$u|~>=Y0FDCLaz`OK$&;WJ%If zO}qC-MfezH@bt+?7lf7iMuXHmF2|u zK4{;SvvSiDt1hdvx8-2Y+e}Amrm`xNvPi|oUOx6z#I|1LSyj#AfS5`68!4x_J|e^= zEQ$I0l_IE*yqk&~bvL!jGIW;d5S}Kb-(s5C8ke_xANon=S~6zh zTH(i!eTtWhux4);(+VsSr$orK52a){rgUXLy}ZXF;YCsWXJMBvZf@$WlQ6z{RzoE7-x{#lBJM zH%2x#wQAXl&hL6-mu3NoMw$7?GwG)pm-S9MuY8e@Zga-Y>d}*LBW&pdZ5TpeJkG#c z@FzoNKqc4meF^uSKfi^iP_gdrC%a5RoPFYAvkLoUG8sCoyxS?Mo3QgC1#9a@CB=L_ z?|^*~xyi`H9EvEcd>4`kNsfEzbFC;skz~TqOens@b#7R-)6k=rqGEu#hwQYPrjF7O z(-ieZ&-ONL^W+${b$46qrmJ=759UX3iWOG4`Ae-Sqhs?^Umg6L*opD=c5iXoV(4^%|3kx0oRnG+t9gEeIW}iE|%X$S;?f*2Keur`#FMcZ=6A6o_^}{)zSSPw4 zCA*ZEDl5!2!X6D7yI%~kwdp8x+e6)CMGymOfeAhmwHxH#=*i;9y*)EJG6V5>Zuqd3 z&H$b~LI4HtPO%U0XJN6xYsv%zPBI@mN7QdW6%_)f4$S72F<1iXG>-L0zi?jMT>^qK ze*Y5}QviM*pXsIqfEoi~x%lL0c9+v}x>vDzn3nz1J(p|-Ur?2!;x}z`yRZ^qIL29( zg%2B_g2xmjMW-?Nh)qPw&U5E9Riie_kZ4i8eD5_v{`TniwyS(OwQ{53(){$Xw}HO( z=_raD{o#iV$T$A*@Ui|Ho-c5YN^KkF?5dS+0yJl7ykbvQ;~5H3N@epgtk6H=p353e zi^XZeOj@llP+-E#)z6o|R#&*}HTphsAgmbIx}JF1Ciq&=4srouY{y|!z0)$CCW;oU zujt#kDkI>nC5$a^b7D?e27)F8F&nO< zV|*mu4a|4J|FbQ%pp>3Y?o3CKqLbJSiK3Yx*sFixRQ>mDDj4$oE$@_V5nRsXJrxvM z*%<>4CG1^k$_}o#00=O}Gke-p=@&o;MI*yvG`o!;V>y154oe@U-G|_8g|bQ}4Xt4{ zf?Uk)X+O0YW!xjYfY#=uWf2?Ynnr9f>DaUtL=h<|2B!Nda3z~Z|3!M457aZb{i^|2 zeZPa7xcM{xNqJl}O4g(S8A{3s2`a!Vm2A|H)u+IBtVw(QB4;@d zuvgeE5fid79y=P+AV3q!zmESzta>3g?ejnT;v^xdSk7nP-eRNbCWcBActTvi;LQ z6_loZB#8HpjS~>?1nS5vRAdcc84e7?BzW;DH&Gb^uvZj@Pu`;gDghoG4AGx=KreeV zpIUU)MYa?_MFI-OtdU+g^1LN{-S}&Ij+SdO`jQPnRKI~KzOV@sBg6DkohtNmu3qjEOW0Ka+|%zj;bjwJ4{+7 zo>#xItzayRYVW%TmT;r{8I*4h)gpAeX513%t}ZSjxeT*HLP834(S=dR74+iCTs3Gi z5x}-tcZj=vR;V7UNI}NLmV!2#dFzMC2yOtjobvZE{mdHXEf-R^#Y+Uw>kod!WlymD71$4)vvU)BEF9|+>*?8r>D z5j=7EN({Il5g@9O6s3PCwmaR=#n+!f87a>fU^to}0vQxh&Q#0o>2a}#_$S^5um-wT z0cgv5m9gChyYzlDM%l6gu11ee*6Pwc7wX%`Is!Lrx|vqDe!N+b#eQ=!;*j?IUaWK_ zCS5iSPn16P@4Y_tBio=kFj*W|M6qIQb7)hOALgLp*?lm3$tm?u`4o3|8~g#hx67V^ zWEFUP*_+Xju0s;B7-_Rz6s^WaWwaP_D_dan=fuTf(x=^8_N5m*1LO}xMYx?fE;u? zy%q8@2>bF<6bGex-m6+rWHZ4sRD{CZ*x=M(I}3+k8$&PG1O19r=2KHRsoi>$hLqH!#fE->#N9_x&j2 za4yeh*qwi^sK-ki^ElU7F<)77_BijVibc%;+m_@`ZL+|IBRPPrWkLLv$EYgQHE@3Q zJ#pArNEaDoxaHeljgTX47I>lqakmIN(MalqH8DR&jrNfGacN)0gKlF6MIXgoQ|W-U zL6{*SLT)qZ64+v^`-MN1UnVj#e$G1I=91gM!$&wn!6fVDK_z~2{w*)w32 z4+sMd!;@zmclUE$JMHJIO_p;O?+yyMR9WQH?Raixye?kl9Jw)-n5S;!`>x?Ak^*~G z>wP@C@#vNL@w)2StS`6Uosh3mgRS4!bbh;hwM=EIup%{ta?y9+b(Vkh8Eg0Y_g?&r z|JuxH-%=wJ4kK-gh!g9^`~69E`$TbC8zt5kUxWXRwQ=ZGJ8{XDE^jz{WF?lz zfm+;?Ifq@QIhh2zi|nhyBBUUTa%Kc_5@m7sIJNsev+g;WDkEz+t`SNa%9sQ;26sPW z%Q0ixv&{dQe^vbM$L64=7%qL1q3$H1)XDOS+Km52LU2ZY|XU8A;E>G-hiXeqPn ze%svMTiV;=$UIP+wc+hiUC7ilmr9j0oeo9VhsX&)?frSVG(k83bDcO3BJpcaE{P4u zi|#d5PlzWG5eef>yl0yr82+-hU(@9xFE1a%UcJ|j|78)bRKZ>~%B|hjXlMVKVTg1! zoGkGiuFt@M%3b7VG$ZBzKEjGpC8h)%8TzY@NhJ%oA=)4MHni_+m!*A!hFhNQM;xP6 z+9y0x%Ah!j6JJOE=hSjpEDGF9*ME0v1H*F&x7z9cMoF8eVGHadd;C$cc=r_ePA-Jt zo+EZN(aG%z-+q7V9}O9voa>|Lx_;-3HW`^qvPdH13s^GaqD@zk4&1F)4xI&1F#V=> zlNtUf_DZXSJ^A2`Ick3_?G964D0s(PtV$|z%+JGCjQNK}y8lg*l ze|WYU(^QQ5XPMA|vdBkYfTBfL!6K#z`XdyW0hIMH{i>Wb?+X(Ot0m@nXR zJAbMqG^<19D$xu5?rKf6P+eAvK5IQVZyxUe^kQzX1m}biKf*ILOvOgW#EVig>rejs z#z^4=os0Ftmo>RXUP4hLJ(9=)7#fUSVi{of| z&5ZC~Jgwmp1lz>1I3c&j$V|-{W%k? zvcQ;?I~OH|*HqbewS8;jt=!PKH#fyS|9fjilzusac|R2fQ{^ZPo7IIH|Lm8|v%^Kk z?KA>4amOvL5#Pg1BJy<`By7PmXH84|<_VJdbIaUi26}T4B8a4aWQ1Ft};n!FnQr9f{W>!+eO%t$@t!qsa5eUYkV5Zk>qeUd$P$!!0 z;7VOv9VXibF)3dL*g9z{whoo+Rjx2P)*yF)HFPZISaW1KhC{fcF{qyejp2V{p4O`F zX<6)vUMB$B1=dzyiw2Tja?3unZR^?&BGy74BZAI1u`X{u<#YLVup74!V;<0utmq1(l0Zg#g_*iiViLq;=9 zu#5!SH9Uk!e=?Wu;Mgn&4tG8#@GQIDE12mAnY+fT1ZPC4R9fjoXdLe>HI%@BLfw6_ zP{pkO>BYDBZ_)STac`%5&4A9xa%EW#l~J~FUDTp~z^Px)DR@SglW4)PLRXx^s>R9X zqX4uXvR(C#v|_Lof&_2i(1|FW$` zdHtA1uuj$JiPk9G0kXJK%seoL=H*w+zCO~fO2D5q@INf$+8bQH;OVjk7p^tj++8_U zl_I&eZHOIK0iP3yXaM3OI6GvrVaj+qENQ0TZ+!=lagAY$`f6 zyiZnc%vq*icOG_+>q}A-~4oTkBnm>htaYM(aDM#fd)lI+O;t7=YpN4**w+#gmYxGf%`#V*88;dOl{kKam!7dLL^t8T&7L$CmY}^S40H+7RnFoF1VBwR+NRvIIh9OJQHfbqGiZ?EcdI3^RM4nxY+eh^T z@#_s9z#jVX)!NuX$@;A-@wqeILaw>L2OS}ujsj--8UBA0-vWp+H&llPo_yqMub}Go zP26aw=vXKoHOlP=si*Ue2VE8xTasLt1HN5OOjkPxXGahHUkDnSf=h=!nT0HKceR_p zQI>9SCzuNf;04CLQ9MXbY!BL`F{^K876gSHzwzk;F1jSCj_l2ZUr5{6H9yYREH$?p za!K=*5vHRQdL+1;5XlF2(cw>+KOSJ+R5GB1^3rcjQk!c0daD1#k8edOVuCO7&||yK zVBMKxn6FE+>gd9uuMv_;hDWChx$GYNb)E$(?EE-aXQ!?>vNLjTJmHYLA6^TP?85-c zp$;guIg2T;LhSX8=6n#XYMHr}MxfwbkKEZxo`v6MbeC_R2RXYdA<{j3l`5z|>CSrz zE_>;L_v%+aiEz+*EhRYCEH};vI8}eFKzHQWboeW@h&N?e%|$Wqth3ByJMIhx($w3c zha!H!;0Sy61{--Ne`m;!&EP@9a>7!sJ?M8}13}Y!`*+IhXHX)<<~T67@OI3>daDj* zO%*jPwB%t>j+29RfER(5QE1-`$FT2CtXcZgZm`^nPvA|oH0y|_E3(eiN6depIzO&o zq%g@;wwC;8b+G4L_n1*J zw`5$uwA>2#(KwxBdiy0mpm_Zg%*LsyVl87CM8Fy025PvGD{m}toF}NACO>4ymI?rp z=o4`Qv{P6vf7NQwCwy=be2Ofu4|gn8HouJ zf^*sdP0)2iB|wN&d#M}q2= ze-fRszn^UO z>aewxZgViZyO`%P_Al27O-Vz6;c^Lg&N;zGbF?wTEN$5)^iZwKh8Xpp9}gqQr&gO%yrgoFRA%!-{fIs&UWAVIKdYY0t)JhCO_1N$ZnY5*zJqI;uYoNh#~rSm(_OWuK>;PrYCwq~Z5Am@hK88I7#kecK(lAKEC$ zpX_xjA7Ljwk^Z>F1vn+0kZrIM4;r%(dv(&idy+eiCs}k)#oJyU0se>u|k#+*b4n+5Fnr6) z;(<5PB1vc04&X7!zeLHggau%)&J5Qh5D`g#^B3*Y`5&JWJM9nHD=YI@xR5iMnk`T% z#9*oSEnwqW{8G-Yeb)2BtOiz3OW~`<@Yx6Oy5Uvk#G>DRGMSNg`Phw5+j(oEq?AK# zT_N}4sbb-BM7n)$(0-=#x1VZdFvrTQ!Upz}q^Oj{_-2Bo?t#oIUBw|q>R>AqYj!0E z4zXwA#K|PE#~oO#-y2 z;j7mU&4&@Dpc~DEju6<85A0joIg2AAecr6mwX1@eJAIr)-_1c!NOd`c?fsC{OgTf| z%^B0n#H0UmOUGNt+GUq>iuVpRb|7EErSC484+2?MPvKR^to0s=a&mTd{wDd?T}oEw zK3J2WY{L05gHb|n-HyU+uNg9y2fAli9R9A|s<=~iIVcMDeq&@7l9Zn7Sa~H^l|TP_ z&~LwXcE4Z7-F=jPg}%x9B>wW-i~S>qRLM|Gj&on5T$d;WeY?Xrmw&*vN4by}_)iV~ zi+o9)?s7hcM3hz#R{bycwXcVIsjycwe;c)h+)CG%GQh39A60eJ=T-I^0+WP%$PnSr z^{j>zM>&G#7M5&yuHavW3LN=SKi0+uXw3<~W|B3TudINDn~2X_qea!LRd(1AN#)kp zoqSJkwIVgde7OXoOE%uA!2Mvf9!{T2JhJ`_=8q6ymEJJt=&5cMjOD#Eu9 zNlu?s#VkzBK#7^1=0|(O*LmkSx;uJRQ|tlQTW=!FI)N8lYW(Dx^EMIMqjrB#uKV0K zUvj@O#{BzPX`@md`&h1B>){S`-x6We+KNapbJB~+y*#isr6}^isMv4)t8OyKqnf%22Jpf4p64#10(|MH zNmA*|rY~PysW^gP#%UUDUBGCh2_z%bzXATHGGAw9S}C=^Z!!DDCajY3FSq6yiK2Vm z`+9xn=#ew*Q02znhM+x*Ge$}>@OnzYiU(u)au+*KyqpT8%kAr-UaXN)?QhZ@?>&cX zBXM@@bVB19F|4?!sV7a9_8sB&a8ryU2dLd03YV7yH@CIO5E) zX7&pGeM6&;1~V3CcQ=>DJ?}5~`{dAPFG3~KWV7(l=ylZ$408SzLkgtvk8^F~_<0D< zE=%FWK*eSdq4O7bGJor%5#+IO#La`5hRT2;A~QwsFy?p zy{uuQ$!}d&?10f9k|4$T(ilLQD)~5+#Ndj^*K%n*b}n5$NShLhM-_cMjpW^W(|3Yn zd%WHiBJFjI{LPszxFB98Vnr85&-6*E>-=9igc!{+w<6HlxhgCyF)=YJHqv#Zz$TRr zvs_-CDI4T9?1S47ba@*z7y^ed2VBhR$#$kkxUvaG*SAo)`k?1ERZBlmE7@3G*aoK8# z-}3#H}!?$#@10s5O1&5o-KCmxSN( zROfjqPgFX-OGv4Kc+aV73yG^GkY>wEtTX>HLcU4)5y{AsRDIq(8CND!d_eaObsYZ{j?^l;(7A4Z4sDSmyVknmW&&So#v9167;$U7RDzmtI zm&fiVkNM&(B0{)}*Y#?kMirlW>f)EbN*ZNZ4_!!FHxi58DASO4Bi=p5 zT@EZ)8v2ooRfZ=4g+ec{kc=%LWEV6Clp-u_%`VcUs9+g;Tts#2`75#)4?e$aV;DN2 zM+ZcPMu;%Hx*KUDWxQi&%Ad<-OW9R~9NZ(99<&QxZ-M^MwVnIY>LJAQ!843ZvIhxu zsI~L-Nqt~OH>E;ebga>y>5PbtX2X^SuYZnd9yjJx9_*^CH~-wC9(H>dG0=er!}9+0 zlUSF+wo#dvi^-}IH!sce_HU|u7KI=o=3YCh7>2yOTUesp+3`r6M!+x{9rOW2=O*v^ zQU9$Oc-d3i4WUpG8^HrW6Qnm5rBC|x7?F`$tmVIgm?MVxNesuAQW9Nx{JI!{O#&(T z{q3>n#_FD9B7mb6n87i*6G+obK&JwOjI^xoC7p#ULO#)a2LG?-B8-`p$QfsvkeIOi zD{Fgrm~?;du%2Er(|h({YCG=5VNai;p*?NtbbYA|RNZ0+mms|QL`KU1IcS2L@7YRJ z1$C#G;YFuuQXCo5#X97i655EO@^k>cxjk?et32|O+R3E%AwT|FTx^~<%h-qFqY!nJ z@RR(b`=`?(YaJtnQm?cKd4B7u!)CSg(Mp#1OF!5a^d76;C^&{f-`_V3qlIp=ZF};6 zqQS?T%)6jNlgcpIIU?Hwx83v8f%}E>e_GpEv(& zcQ0R|e|iP=Dp8twy_;D>S#*DSGQ>dB`ca)V32&!k6hqgzeY91tp!myGD|^z__1%v> z5j#;GBh>Rm8&RxpVGk}DzPrbLBA9WRN-#f3EcVoP{o+%8i?;y_vZJe98pbhQZCyrE zNuKv8W*k%h*{H)L|nqbPQb)B4YDbAM|amN-s-(JUm_SQ}JSxak~#*95rj({j*yQ2jPc!qmJ(;RtQrE^$M zn5Qhy#xxX2$4Aq|tTvdqbYq2n+wXvOx5G9i>3{mFvc5j@P%yq#2@5e`JHoIti3=co zmsegI^k^l>U9_Y9UE3 z!?;~|A+eDyTyHHa-ouJYF8#9iL3AH6yzyU0+%6wLO@`R~l0cr$KKNyYSCH7I*NaMg z!I4XeFX3wS!f(Dgqs5OGv0)R4;=;~{Zcxr~cK%URqm>vrPU~K!rOG33Uh><>XcUXQ!Hjn7_ zNFo)eG>lP~fQD zMftN&m?A|d+Ua5aei;RAjvX9$6WuPf_n3lgMaa$h`hDZTxM+UrEAq0iOpyPRzPmjJ z_@PvgG*Xw~<(Y7ZX%@*T$$0_ghs0HKRBU%i|H zT~hqSGGsT=wi%1G2+_u{sHC=EpdTMXSmCCEin;A3_OxQ^5|8g31Lg|;$s}Pk3MH2j z8ZF&h#+INv^#y7XX%Tat^%fT%lP;S+4TXb5e4M(MwJ#rDbFQWHX&IG9(914=>r?Hu z5L11q#BS)CR0ars@jAw$Ae@4~)L8mDXHOTbunwUVyE&p&4)QWzdEtdWRv3fQZC(Ub zg3^7~eoyI7wAaqbfK4dRiG5A}PQs7SaNS@OhDyjArZ~j2UO77D0{NdCf{$j8kA6#= z#U1UOLAvcUKC$dw1K>d68F?jEfu_1vAVJlDbMyD-oUCj9j@(ne>9fH%%3;TZv|h_M z80&1T|1&c5n0dl75qu2omv-ZWC8bFtM(Q|jUdP5E zh2xiAaWCE&bl3^sqD=hAKRoz@T6iIz@3C}nz6MX5aSSYco`Q9YamM-pWQi5;$&6wk zz-)3sJKx&nr5BsJy3ePY9^nn4Ukl>(TkE)2hD+kFW04-wPnd6=9ChsZnQqyWPAu!< z6c+6G+iPLk{ukCHg?X=vHP_Zs7TnxK@ruK=Ws3ux_7WmQe6=sy%LQe&yN^ z6qm*8c!#|a7S@O6HpNaU31TOI`5uM}*erqNYMK01JZ8+himygQUKA50xzlxNkp|JC zhkBuZ^(x|7pK|xAoxJxS@|UumIE)#7{g_-3BdZg8Gqn9t@80CyiLF>{GsOx-_!w~w z=#nTI`Om^pVg4GB;bp(K(yl-u1+o_eU{srQSfKT|gfx$B2s^|TG17(CF`^e~e6V-y zwr`tZM>g8xQp~XQLN?XQp8jmK>H-OT|s`|L!u{3a+_(k)%))0sHU93SAj! z2@P+T`zlU40x`*sBt(dkx+>U@{FR`HGX`vtbJm17Sg9IS-hWp{fZts^y)^Wl(FmQ$ zi?hZ^Z`x<1btAW?izPa6mEMsVU@iL`SLx^+YaK3a)G_tijwG;$O2i9{fkHtztVl^T zF_X&hD4UHQCK6A?{J^%IKEcOF*QAKfhB_&A{u}vY14|owP>hsUN z&^^3=*Xr;Jh?5>tnd8ZpD1lhNO;0hFUrkxt?twB~=_v^Fs#96WQMW)PlPe>Zp`Abf zzTN})S%^KuNycK?PW0W{;!Rpk(vXz;EWxmz28O!x>=m8(h<0{#toaNn{pZypYl@7N zZqbO;FFN*z(!qk2j)85?ZXZU&DH`9oJ$xCvS6`?S_w|Z?>a40sM;*7tVNf)+OP#SU zEFo6RIz#R4kn)R;A>ARRF8BUBz5=&og!x?OQ=yR@d2xb;#~$JD#hxjOm=JA!C~RFIDiS~IpWac&N1O8E#8oG=^`bUsSz!*uo-UBxhHd$5)*Ru$y~MP_BBl|!yOKOIO}=jmXrdQ)@-PzF;!p8Muq`unZ7;%z4rwI7^23+A^}35R zGH#&^AIN(F(P1s^pH(6Ty+%W4t#_%o)nJJ~4Y0W9;Lb}m+C^tNUu&slc#`b-m7_AGpCDvS)4mePxl4&XWt^aG4!$%uR zK*~Ue1wMzIF=n6o>U8U zVok=<>ZwHk@M!RTyL)E>&V4?|U{^Z>++ZO{nsI1)Cv3d_;!CkAq_DKiy+I!d(O=XFbt+h}5;NK#CI{)#>QW&7Ql0tLv9$nV1K{{J^yweSH_cY3%1 zclSwNZ)?>W0#)(m;~p(lf9Rpg)TCh*2{2~V?ful+LVk$?8DwyPmD_P9=N2U`& zTbx7ujDL4*8i-%Sz+18W$YL#)1r3!np<5!~1*vmA!LnE5T*xvroxDH3A#G}OoJ*

T!`u=bJUrk!;hqA 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 literal 0 HcmV?d00001 diff --git a/Aircraft/Instruments-3d/kln94/kln94.xml b/Aircraft/Instruments-3d/kln94/kln94.xml new file mode 100644 index 000000000..fe3633546 --- /dev/null +++ b/Aircraft/Instruments-3d/kln94/kln94.xml @@ -0,0 +1,164 @@ + + +kln94.ac + + + + + pick + ent-btn + + false + + nasal + + + + + + + pick + crsr-btn + + false + + nasal + + + + + + + pick + nrst-btn + + false + + nasal + + + + + + + pick + dto-btn + + false + + nasal + + + + + + + pick + obs-btn + + false + + nasal + + + + + + + pick + msg-btn + + false + + nasal + + + + + + + pick + alt-btn + + false + + nasal + + + + + + + pick + clr-btn + + false + + nasal + + + + + + + knob + knob-inner + + + nasal + + + + + + + knob + knob-outer + + + nasal + + + + + + + + knob + knob-brightness + + + property-adjust + /instrumentation/kln94/brightness-norm + 0.05 + 0 + 1 + false + + + + + \ No newline at end of file diff --git a/Aircraft/Instruments-3d/kln94/knob.rgb b/Aircraft/Instruments-3d/kln94/knob.rgb new file mode 100644 index 0000000000000000000000000000000000000000..0b9064871893765b2ecfc8327653deb05441bd4f GIT binary patch literal 1088 zcmeIw%?AQO7{~Ev?3zu)5D^g(5fKs5|5m4N-MV$#TeoiAx^=2siX|cx-QI%9`57MNm)9y(}H zS3?;EWRXGwHtQGcvB45^jL=6HE$Zs1pokpOFmPDE;(#qy@G!vuF4|m?|KCQzz7iIt g*RKut`tKk0JGyy{X(3K8@&3ng&^LRA(ekx<2O428^Z)<= literal 0 HcmV?d00001 diff --git a/Aircraft/Instruments-3d/kln94/navPages.nas b/Aircraft/Instruments-3d/kln94/navPages.nas new file mode 100644 index 000000000..b66114d17 --- /dev/null +++ b/Aircraft/Instruments-3d/kln94/navPages.nas @@ -0,0 +1,80 @@ + + +var Nav1Page = +{ + a:2, + + + new: func() + { + m = {parents: [Nav1Page, KLN94.Page.new(KLN94.PAGE_NAV, 0)]}; + return m; + }, + + hasActiveIdent: func { 1 }, + showsCDI: func { 1 }, + + display: func(gps) + { + if (gps.isDirectToActive()) { + + } else { + # leg mode + gps.setLine(0, sprintf('%6s->%6s', + gps.props.previousIdent.getStringValue(), + gps.props.activeIdent.getStringValue()) + ); + } + + + gps.setLine(3, ' VNV Off'); + + var toFrom = gps.isTo() ? 'To' : 'Fr'; + var eteToWp1 = gps.formatDuration(gps.props.timeToWaypoint.getIntValue()); + gps.setLine(4, sprintf('%03d*%s ', bearingToWp1, toFrom) ~ eteToWp1); + }, + + refresh: func(gps) + { + + } +}; + +var Nav2Page = +{ + new: func() + { + m = {parents: [Nav2Page, KLN94.Page.new(KLN94.PAGE_NAV, 1)]}; + return m; + }, + + display: func(gps) + { + # select refnavaid! + + gps.setLine(0, ' PRESENT POSN'), + gps.setLine(1, ' Ref:%s', gps.refNavaid.id); + + gps.setLine(3, ' ' + gps.formatLatitude(gps.props.indicatedLat.getDoubleValue())); + gps.setLine(4, ' ' + gps.formatLongitude(gps.props.indicatedLon.getDoubleValue())); + } +}; + +var Nav3Page = +{ + new: func() + { + m = {parents: [Nav3Page, KLN94.Page.new(KLN94.PAGE_NAV, 2)]}; + return m; + }, +}; + +var nav1 = Nav1Page.new(); +gps.addPage(nav1); + + +gps.addPage(Nav2Page.new()); +gps.addPage(Nav3Page.new()); + + + diff --git a/Aircraft/Instruments-3d/kln94/settingPages.nas b/Aircraft/Instruments-3d/kln94/settingPages.nas new file mode 100644 index 000000000..e69de29bb diff --git a/Aircraft/Instruments-3d/kln94/waypointPages.nas b/Aircraft/Instruments-3d/kln94/waypointPages.nas new file mode 100644 index 000000000..e69de29bb From 402d75a6023a2349da5baead3a59acebd9b63441 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Mon, 15 Apr 2013 14:00:22 +0300 Subject: [PATCH 13/17] Deeper shadows and fog/snow continuity across terrain tiles for highest quality level terrain shader of Atmospheric Light Scattering --- Shaders/terrain-haze-ultra.frag | 57 ++++++++++++++++++++++++++++----- Shaders/terrain-haze-ultra.vert | 34 ++++++++------------ 2 files changed, 62 insertions(+), 29 deletions(-) diff --git a/Shaders/terrain-haze-ultra.frag b/Shaders/terrain-haze-ultra.frag index 1c583ab69..7fde2d61d 100644 --- a/Shaders/terrain-haze-ultra.frag +++ b/Shaders/terrain-haze-ultra.frag @@ -4,12 +4,11 @@ // Ambient term comes in gl_Color.rgb. varying vec4 diffuse_term; varying vec3 normal; -//varying vec2 nvec; varying vec3 relPos; varying vec2 rawPos; -//varying vec2 worldPos; +varying vec3 worldPos; varying vec3 ecViewdir; -varying vec3 ecNormal; + uniform sampler2D texture; @@ -20,7 +19,7 @@ uniform sampler2D mix_texture; uniform sampler2D grain_texture; uniform sampler2D dot_texture; uniform sampler2D gradient_texture; -//uniform sampler2D foam_texture; + //varying float yprime_alt; @@ -71,6 +70,10 @@ float rand2D(in vec2 co){ return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453); } +float rand3D(in vec3 co){ + return fract(sin(dot(co.xyz ,vec3(12.9898,78.233,144.7272))) * 43758.5453); +} + float cosine_interpolate(in float a, in float b, in float x) { float ft = x * 3.1415927; @@ -103,6 +106,39 @@ float interpolatedNoise2D(in float x, in float y) return simple_interpolate(i1 , i2 , fractional_y); } +float interpolatedNoise3D(in float x, in float y, in float z) +{ + float integer_x = x - fract(x); + float fractional_x = x - integer_x; + + float integer_y = y - fract(y); + float fractional_y = y - integer_y; + + float integer_z = z - fract(z); + float fractional_z = z - integer_z; + + float v1 = rand3D(vec3(integer_x, integer_y, integer_z)); + float v2 = rand3D(vec3(integer_x+1.0, integer_y, integer_z)); + float v3 = rand3D(vec3(integer_x, integer_y+1.0, integer_z)); + float v4 = rand3D(vec3(integer_x+1.0, integer_y +1.0, integer_z)); + + float v5 = rand3D(vec3(integer_x, integer_y, integer_z+1.0)); + float v6 = rand3D(vec3(integer_x+1.0, integer_y, integer_z+1.0)); + float v7 = rand3D(vec3(integer_x, integer_y+1.0, integer_z+1.0)); + float v8 = rand3D(vec3(integer_x+1.0, integer_y +1.0, integer_z+1.0)); + + + float i1 = simple_interpolate(v1,v5, fractional_z); + float i2 = simple_interpolate(v2,v6, fractional_z); + float i3 = simple_interpolate(v3,v7, fractional_z); + float i4 = simple_interpolate(v4,v8, fractional_z); + + float ii1 = simple_interpolate(i1,i2,fractional_x); + float ii2 = simple_interpolate(i3,i4,fractional_x); + + + return simple_interpolate(ii1 , ii2 , fractional_y); +} float Noise2D(in vec2 coord, in float wavelength) @@ -111,6 +147,11 @@ return interpolatedNoise2D(coord.x/wavelength, coord.y/wavelength); } +float Noise3D(in vec3 coord, in float wavelength) +{ +return interpolatedNoise3D(coord.x/wavelength, coord.y/wavelength, coord.z/wavelength); +} + float dotNoise2D(in float x, in float y, in float fractionalMaxDotSize) { float integer_x = x - fract(x); @@ -259,10 +300,10 @@ float noise_25m = Noise2D(rawPos.xy, 25.0); float noise_50m = Noise2D(rawPos.xy, 50.0); -float noise_250m = Noise2D(rawPos.xy,250.0); -float noise_500m = Noise2D(rawPos.xy, 500.0); -float noise_1500m = Noise2D(rawPos.xy, 1500.0); -float noise_2000m = Noise2D(rawPos.xy, 2000.0); +float noise_250m = Noise3D(worldPos.xyz,250.0); +float noise_500m = Noise3D(worldPos.xyz, 500.0); +float noise_1500m = Noise3D(worldPos.xyz, 1500.0); +float noise_2000m = Noise3D(worldPos.xyz, 2000.0); // dot noise diff --git a/Shaders/terrain-haze-ultra.vert b/Shaders/terrain-haze-ultra.vert index d6ab9777f..65369f380 100644 --- a/Shaders/terrain-haze-ultra.vert +++ b/Shaders/terrain-haze-ultra.vert @@ -20,14 +20,12 @@ // bugs with gl_FrontFacing in the fragment shader. varying vec4 diffuse_term; varying vec3 normal; -//varying vec2 nvec; varying vec3 relPos; varying vec2 rawPos; -//varying vec2 worldPos; +varying vec3 worldPos; varying vec3 ecViewdir; -//varying float earthShade; -//varying float yprime_alt; + varying float mie_angle; varying float steepness; varying float grad_dir; @@ -42,15 +40,13 @@ uniform float visibility; uniform float overcast; uniform float ground_scattering; uniform float eye_alt; -//uniform float eye_lat; -//uniform float eye_lon; uniform float moonlight; uniform mat4 osg_ViewMatrixInverse; float earthShade; float yprime_alt; -//float mie_angle; + // This is the value used in the skydome scattering shader - use the same here for consistency? @@ -84,21 +80,12 @@ void main() float vertex_alt; float scattering; - rawPos = gl_Vertex.xy; + rawPos = gl_Vertex.xy; + worldPos = (osg_ViewMatrixInverse *gl_ModelViewMatrix * gl_Vertex).xyz; - // try making a continuous coordinate system - //vec4 worldPos3D = (osg_ViewMatrixInverse *gl_ModelViewMatrix * gl_Vertex); - - //rawPos = worldPos3d.yz; - //float x1 = sin(eye_lon) * worldPos3D.y + cos(eye_lon) * worldPos3D.z; - //float y1 = cos(eye_lon) * worldPos3D.y - sin(eye_lon) * worldPos3D.z; - //y1 = cos(eye_lat) * y1 + sin(eye_lat) * worldPos3D.x; - - //worldPos = vec2 (x1, y1); - - steepness = dot(normalize(gl_Normal), vec3 (0.0, 0.0, 1.0)); - grad_dir = dot(normalize(gl_Normal.xy), vec2 (1.0, 0.0)); + steepness = dot(normalize(gl_Normal), vec3 (0.0, 0.0, 1.0)); + grad_dir = dot(normalize(gl_Normal.xy), vec2 (1.0, 0.0)); // this code is copied from default.vert @@ -277,7 +264,12 @@ else // the faster, full-day version without lightfields light_ambient = light_ambient * ((1.0+steepness)/2.0 * 1.2 + (1.0-steepness)/2.0 * 0.2); -//light_ambient.rgb = 0.1 * light_ambient.rgb; +// deeper shadows when there is lots of direct light + +float shade_depth = 1.0 * smoothstep (0.6,0.95,ground_scattering) * (1.0-smoothstep(0.1,0.5,overcast)) * smoothstep(0.4,1.5,earthShade); + + light_ambient.rgb = light_ambient.rgb * (1.0 - shade_depth); + light_diffuse.rgb = light_diffuse.rgb * (1.0 + 1.2 * shade_depth); // default lighting based on texture and material using the light we have just computed From df35c11af249561d4f2e1609a14acf3c29fca5c1 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Mon, 15 Apr 2013 14:29:04 +0300 Subject: [PATCH 14/17] Packice overlay and water color variations for high quality water shader in Atmospheric Light Scattering --- Effects/water.eff | 38 +++++++++ Environment/environment.xml | 3 + Shaders/water_lightfield.frag | 110 ++++++++++++++++++++++++++- Shaders/water_lightfield.vert | 4 +- gui/dialogs/environment-settings.xml | 82 ++++++++++++++++---- 5 files changed, 218 insertions(+), 19 deletions(-) diff --git a/Effects/water.eff b/Effects/water.eff index 9629e9150..61f9bd7c0 100644 --- a/Effects/water.eff +++ b/Effects/water.eff @@ -45,6 +45,13 @@ repeat normalized + + Textures.high/Terrain/packice-overlay.png + linear-mipmap-linear + repeat + repeat + normalized + 0.0 /rendering/scene/saturation @@ -132,6 +139,9 @@ /sim/rendering/shaders/skydome + + /environment/sea/surface/ice-cover + /environment/sea/color_r @@ -312,6 +322,24 @@ texture[6]/internal-format + + 7 + + texture[10]/image + + + texture[10]/filter + + + texture[10]/wrap-s + + + texture[10]/wrap-t + + + texture[10]/internal-format + + Shaders/water_lightfield.vert @@ -342,6 +370,11 @@ sampler-2d 6 + + ice_texture + sampler-2d + 7 + normalmap_dds @@ -486,6 +519,11 @@ float cloud_self_shading + + ice_cover + float + ice_cover + sea_r diff --git a/Environment/environment.xml b/Environment/environment.xml index 43e8d8524..19290cfdd 100644 --- a/Environment/environment.xml +++ b/Environment/environment.xml @@ -404,6 +404,9 @@ 0.148 0.27 0.3 + + 0.0 + diff --git a/Shaders/water_lightfield.frag b/Shaders/water_lightfield.frag index 58a78e6af..ce729cc5d 100644 --- a/Shaders/water_lightfield.frag +++ b/Shaders/water_lightfield.frag @@ -12,6 +12,7 @@ uniform sampler2D water_normalmap; uniform sampler2D water_dudvmap; uniform sampler2D sea_foam; uniform sampler2D perlin_normalmap; +uniform sampler2D ice_texture; uniform sampler3D Noise; @@ -23,8 +24,8 @@ varying vec4 waterTex2; //moving texcoords varying vec4 waterTex4; //viewts varying vec3 viewerdir; varying vec3 lightdir; -//varying vec3 specular_light; varying vec3 relPos; +varying vec3 rawPos; varying float earthShade; varying float yprime_alt; @@ -49,6 +50,7 @@ uniform float scattering; uniform float ground_scattering; uniform float cloud_self_shading; uniform float eye_alt; +uniform float ice_cover; uniform float sea_r; uniform float sea_g; uniform float sea_b; @@ -68,6 +70,93 @@ vec3 fog_Func(vec3 color, int type); /////// functions ///////// +float rand2D(in vec2 co){ + return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453); +} + +float rand3D(in vec3 co){ + return fract(sin(dot(co.xyz ,vec3(12.9898,78.233,144.7272))) * 43758.5453); +} + +float cosine_interpolate(in float a, in float b, in float x) +{ + float ft = x * 3.1415927; + float f = (1.0 - cos(ft)) * .5; + + return a*(1.0-f) + b*f; +} + +float simple_interpolate(in float a, in float b, in float x) +{ +return a + smoothstep(0.0,1.0,x) * (b-a); +} + +float interpolatedNoise2D(in float x, in float y) +{ + float integer_x = x - fract(x); + float fractional_x = x - integer_x; + + float integer_y = y - fract(y); + float fractional_y = y - integer_y; + + float v1 = rand2D(vec2(integer_x, integer_y)); + float v2 = rand2D(vec2(integer_x+1.0, integer_y)); + float v3 = rand2D(vec2(integer_x, integer_y+1.0)); + float v4 = rand2D(vec2(integer_x+1.0, integer_y +1.0)); + + float i1 = simple_interpolate(v1 , v2 , fractional_x); + float i2 = simple_interpolate(v3 , v4 , fractional_x); + + return simple_interpolate(i1 , i2 , fractional_y); +} + +float interpolatedNoise3D(in float x, in float y, in float z) +{ + float integer_x = x - fract(x); + float fractional_x = x - integer_x; + + float integer_y = y - fract(y); + float fractional_y = y - integer_y; + + float integer_z = z - fract(z); + float fractional_z = z - integer_z; + + float v1 = rand3D(vec3(integer_x, integer_y, integer_z)); + float v2 = rand3D(vec3(integer_x+1.0, integer_y, integer_z)); + float v3 = rand3D(vec3(integer_x, integer_y+1.0, integer_z)); + float v4 = rand3D(vec3(integer_x+1.0, integer_y +1.0, integer_z)); + + float v5 = rand3D(vec3(integer_x, integer_y, integer_z+1.0)); + float v6 = rand3D(vec3(integer_x+1.0, integer_y, integer_z+1.0)); + float v7 = rand3D(vec3(integer_x, integer_y+1.0, integer_z+1.0)); + float v8 = rand3D(vec3(integer_x+1.0, integer_y +1.0, integer_z+1.0)); + + + float i1 = simple_interpolate(v1,v5, fractional_z); + float i2 = simple_interpolate(v2,v6, fractional_z); + float i3 = simple_interpolate(v3,v7, fractional_z); + float i4 = simple_interpolate(v4,v8, fractional_z); + + float ii1 = simple_interpolate(i1,i2,fractional_x); + float ii2 = simple_interpolate(i3,i4,fractional_x); + + + return simple_interpolate(ii1 , ii2 , fractional_y); +} + +float Noise2D(in vec2 coord, in float wavelength) +{ +return interpolatedNoise2D(coord.x/wavelength, coord.y/wavelength); + +} + +float Noise3D(in vec3 coord, in float wavelength) +{ +return interpolatedNoise3D(coord.x/wavelength, coord.y/wavelength, coord.z/wavelength); +} + + + void rotationmatrix(in float angle, out mat4 rotmat) { rotmat = mat4( cos( angle ), -sin( angle ), 0.0, 0.0, @@ -199,6 +288,12 @@ void main(void) const vec4 sca2 = vec4(0.02, 0.02, 0.02, 0.02); const vec4 tscale = vec4(0.25, 0.25, 0.25, 0.25); + float noise_50m = Noise3D(rawPos.xyz, 50.0); + float noise_250m = Noise3D(rawPos.xyz,250.0); + float noise_1500m = Noise3D(rawPos.xyz,1500.0); + float noise_2000m = Noise3D(rawPos.xyz,2000.0); + float noise_2500m = Noise3D(rawPos.xyz, 2500.0); + mat4 RotationMatrix; // compute direction to viewer @@ -332,6 +427,7 @@ void main(void) if (normalmap_dds > 0) {vNorm = -vNorm;} //dds fix + vNorm = vNorm * (0.5 + 0.5 * noise_250m); //load reflection @@ -342,6 +438,7 @@ void main(void) refl.b = sea_b; refl.a = 1.0; + refl.g = refl.g * (0.9 + 0.2* noise_2500m); float intensity; // de-saturate for reduced light @@ -435,7 +532,16 @@ void main(void) - finalColor *= ambient_light; + // add ice + vec4 ice_texel = texture2D(ice_texture, vec2(waterTex2) * 0.2 ); + + float nSum = 0.5 * (noise_250m + noise_50m); + float mix_factor = smoothstep(1.0 - ice_cover, 1.04-ice_cover, nSum); + finalColor = mix(finalColor, ice_texel, mix_factor * ice_texel.a); + finalColor.a = 1.0; + + + finalColor *= ambient_light; diff --git a/Shaders/water_lightfield.vert b/Shaders/water_lightfield.vert index c6803a1dc..f3657a22b 100644 --- a/Shaders/water_lightfield.vert +++ b/Shaders/water_lightfield.vert @@ -11,7 +11,7 @@ varying vec4 waterTex1; varying vec4 waterTex2; varying vec4 waterTex4; varying vec3 relPos; - +varying vec3 rawPos; varying vec3 viewerdir; varying vec3 lightdir; @@ -31,6 +31,7 @@ uniform float visibility; uniform float overcast; uniform float ground_scattering; +uniform mat4 osg_ViewMatrixInverse; vec3 specular_light; @@ -72,6 +73,7 @@ void main(void) vec3 shadedFogColor = vec3(0.65, 0.67, 0.78); + rawPos = (osg_ViewMatrixInverse *gl_ModelViewMatrix * gl_Vertex).xyz; vec4 ecPosition = gl_ModelViewMatrix * gl_Vertex; diff --git a/gui/dialogs/environment-settings.xml b/gui/dialogs/environment-settings.xml index e0c797315..a0481db81 100644 --- a/gui/dialogs/environment-settings.xml +++ b/gui/dialogs/environment-settings.xml @@ -194,13 +194,63 @@ 3 + + + + /sim/rendering/shaders/skydome + + + left + 4 + 0 + + + + + /sim/rendering/shaders/skydome + + + right + 4 + 1 + + + + + /sim/rendering/shaders/skydome + + ice-cover + 4 + 2 + 0.0 + 1.0 + true + /environment/sea/surface/ice-cover + + dialog-apply + ice-cover + + + + + + /sim/rendering/shaders/skydome + + + left + 4 + 3 + + + + /sim/rendering/shaders/skydome left - 4 + 5 0 @@ -210,7 +260,7 @@ right - 4 + 5 1 @@ -219,7 +269,7 @@ /sim/rendering/shaders/skydome dust-level - 4 + 5 2 0.0 0.7 @@ -237,7 +287,7 @@ left - 4 + 5 3 @@ -247,7 +297,7 @@ left - 5 + 6 0 @@ -257,7 +307,7 @@ right - 5 + 6 1 @@ -266,7 +316,7 @@ /sim/rendering/shaders/skydome wetness - 5 + 6 2 0.0 0.7 @@ -284,7 +334,7 @@ left - 5 + 6 3 @@ -295,7 +345,7 @@ left - 6 + 7 0 @@ -305,7 +355,7 @@ right - 6 + 7 1 @@ -314,7 +364,7 @@ /sim/rendering/shaders/skydome lichen-level - 6 + 7 2 0.0 0.7 @@ -332,7 +382,7 @@ left - 6 + 7 3 @@ -343,7 +393,7 @@ left - 7 + 8 0 @@ -353,7 +403,7 @@ right - 7 + 8 1 @@ -362,7 +412,7 @@ /sim/rendering/shaders/skydome season - 7 + 8 2 0.0 2.0 @@ -380,7 +430,7 @@ left - 7 + 8 3 From 4817183507f11aaa72a733bb6bd09fa259132b76 Mon Sep 17 00:00:00 2001 From: Thorsten Renk Date: Tue, 16 Apr 2013 12:48:54 +0300 Subject: [PATCH 15/17] Isotropic lighting for trees in Atmospheric Light Scattering --- Shaders/tree-haze.vert | 33 +++++++++++++++++---------------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/Shaders/tree-haze.vert b/Shaders/tree-haze.vert index df812d1a2..feea2ba53 100644 --- a/Shaders/tree-haze.vert +++ b/Shaders/tree-haze.vert @@ -59,7 +59,7 @@ return e / pow((1.0 + a * exp(-b * (x-c)) ),(1.0/d)); void main() { - vec4 light_diffuse; + //vec4 light_diffuse; vec4 light_ambient; vec3 shadedFogColor = vec3(0.65, 0.67, 0.78); @@ -155,11 +155,11 @@ if (terminator < 1000000.0) // the full, sunrise and sunset computation - light_diffuse.b = light_func(lightArg, 1.330e-05, 0.264, 3.827, 1.08e-05, 1.0); - light_diffuse.g = light_func(lightArg, 3.931e-06, 0.264, 3.827, 7.93e-06, 1.0); - light_diffuse.r = light_func(lightArg, 8.305e-06, 0.161, 3.827, 3.04e-05, 1.0); - light_diffuse.a = 1.0; - light_diffuse = light_diffuse * scattering; + //light_diffuse.b = light_func(lightArg, 1.330e-05, 0.264, 3.827, 1.08e-05, 1.0); + //light_diffuse.g = light_func(lightArg, 3.931e-06, 0.264, 3.827, 7.93e-06, 1.0); + //light_diffuse.r = light_func(lightArg, 8.305e-06, 0.161, 3.827, 3.04e-05, 1.0); + //light_diffuse.a = 1.0; + //light_diffuse = light_diffuse * scattering; light_ambient.r = light_func(lightArg, 0.236, 0.253, 1.073, 0.572, 0.33); light_ambient.g = light_ambient.r * 0.4/0.33; @@ -178,8 +178,8 @@ if (earthShade < 0.5) intensity = length(light_ambient.rgb); light_ambient.rgb = intensity * normalize(mix(light_ambient.rgb, shadedFogColor, 1.0 -smoothstep(0.1, 0.8,earthShade) )); - intensity = length(light_diffuse.rgb); - light_diffuse.rgb = intensity * normalize(mix(light_diffuse.rgb, shadedFogColor, 1.0 -smoothstep(0.1, 0.7,earthShade) )); + //intensity = length(light_diffuse.rgb); + //light_diffuse.rgb = intensity * normalize(mix(light_diffuse.rgb, shadedFogColor, 1.0 -smoothstep(0.1, 0.7,earthShade) )); } @@ -211,16 +211,16 @@ else // the faster, full-day version without lightfields mie_angle = 1.0; if (terminator > 3000000.0) - {light_diffuse = vec4 (1.0, 1.0, 1.0, 1.0); + {//light_diffuse = vec4 (1.0, 1.0, 1.0, 1.0); light_ambient = vec4 (0.33, 0.4, 0.5, 1.0); } else { lightArg = (terminator/100000.0 - 10.0)/20.0; - light_diffuse.b = 0.78 + lightArg * 0.21; - light_diffuse.g = 0.907 + lightArg * 0.091; - light_diffuse.r = 0.904 + lightArg * 0.092; - light_diffuse.a = 1.0; + //light_diffuse.b = 0.78 + lightArg * 0.21; + //light_diffuse.g = 0.907 + lightArg * 0.091; + //light_diffuse.r = 0.904 + lightArg * 0.092; + //light_diffuse.a = 1.0; light_ambient.r = 0.316 + lightArg * 0.016; light_ambient.g = light_ambient.r * 0.4/0.33; @@ -228,16 +228,17 @@ else // the faster, full-day version without lightfields light_ambient.a = 1.0; } - light_diffuse = light_diffuse * scattering; + //light_diffuse = light_diffuse * scattering; yprime_alt = -sqrt(2.0 * EarthRadius * hazeLayerAltitude); } + light_ambient.rgb = light_ambient.rgb * (1.0 + smoothstep(1000000.0, 3000000.0,terminator)); // tree shader lighting - vec3 diffuse = gl_FrontMaterial.diffuse.rgb * max(0.1, n); + //vec3 diffuse = gl_FrontMaterial.diffuse.rgb * max(0.1, n); vec4 ambientColor = gl_FrontLightModelProduct.sceneColor + light_ambient * gl_FrontMaterial.ambient; - gl_FrontColor = ambientColor + light_diffuse * vec4(diffuse, 1.0); + gl_FrontColor = ambientColor;// + light_diffuse * vec4(diffuse, 1.0); gl_FrontColor.a = mie_angle; gl_BackColor.a = mie_angle; //gl_FrontColor.a = 1.0; gl_BackColor.a = 1.0; From 823510f0b4fd6c79a747c895b074e6ffd6f1b9ed Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Tue, 16 Apr 2013 22:09:44 +0100 Subject: [PATCH 16/17] Basic Weather integration with Atmospheric Shader. --- Environment/local-weather-rules.xml | 708 +++++++++++++++++++++++++++- 1 file changed, 707 insertions(+), 1 deletion(-) diff --git a/Environment/local-weather-rules.xml b/Environment/local-weather-rules.xml index 457a730e0..2e9b07e77 100644 --- a/Environment/local-weather-rules.xml +++ b/Environment/local-weather-rules.xml @@ -16,7 +16,7 @@ General Public License for more details. --> @@ -45,4 +45,710 @@ gain 0.30480 + + + + + + EnvironmentInterpolator:AtmosphericShader:ground-visibility-m + gain + + + + /nasal/local_weather/enabled + true + + + + /environment/config/boundary/entry[0]/visibility-m + /environment/ground-visibility-m + + + + + EnvironmentInterpolator:AtmosphericShader:GroundHazeThickness + gain + + + + /nasal/local_weather/enabled + true + + + + + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + 0.3048 + + + 0 + + + + 2000 + + /environment/ground-haze-thickness-m + + + + + EnvironmentInterpolator:AtmosphericShader:GroundScattering:0:Clear + gain + + + + + /nasal/local_weather/enabled + true + + + /environment/clouds/layer[0]/coverage + clear + + + + + + 1 + + /environment/surface/ground-scattering + + + + EnvironmentInterpolator:AtmosphericShader:GroundScattering:0:Few + gain + + + + + /nasal/local_weather/enabled + true + + + /environment/clouds/layer[0]/coverage + few + + + + + + 0.9 + + /environment/surface/ground-scattering + + + + EnvironmentInterpolator:AtmosphericShader:GroundScattering:0:Scattered + gain + + + + + /nasal/local_weather/enabled + true + + + /environment/clouds/layer[0]/coverage + scattered + + + + + + 0.8 + + /environment/surface/ground-scattering + + + + EnvironmentInterpolator:AtmosphericShader:GroundScattering:0:Broken + gain + + + + + /nasal/local_weather/enabled + true + + + /environment/clouds/layer[0]/coverage + broken + + + + + + 0.7 + + /environment/surface/ground-scattering + + + + EnvironmentInterpolator:AtmosphericShader:GroundScattering:0:Overcast + gain + + + + + /nasal/local_weather/enabled + true + + + /environment/clouds/layer[0]/coverage + overcast + + + + + + 0.6 + + /environment/surface/ground-scattering + + + + + + + + EnvironmentInterpolator:AtmosphericShader:Scattering:AircraftAboveLayer + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + + + 1 + + /rendering/scene/scattering + + + + EnvironmentInterpolator:AtmosphericShader:Scattering:AircraftBelowLayer + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + + /environment/surface/ground-scattering + /rendering/scene/scattering + + + + + EnvironmentInterpolator:AtmosphericShader:CloudSelfShading + gain + + + + /nasal/local_weather/enabled + true + + + + + + 1.0 + + /environment/cloud-self-shading + + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:VisFactor + gain + + + + /nasal/local_weather/enabled + true + + + + + + + + /environment/visibility-m + 30000 + + 0.000011111 + + + + 0.0 + 1.0 + /sim/rendering/skydome-vis-factor + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Rayleigh:Low + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + 36000 + + + + + + + + 0.0003 + + /sim/rendering/skydome-vis-factor + 0.0001 + + + + + /sim/rendering/rayleigh-no-polution + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Rayleigh:Medium + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + 36000 + + + /position/altitude-ft + 85000 + + + + + + + + + 0.0003 + + /sim/rendering/skydome-vis-factor + 0.0001 + + + + + /position/altitude-ft + 36000 + + 0.000000002 + + + + + /sim/rendering/rayleigh-no-polution + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Rayleigh:High + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + 85000 + + + + + + + + 0.0002 + + /sim/rendering/skydome-vis-factor + 0.0001 + + + + + /sim/rendering/rayleigh-no-polution + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Rayleight:Polution:Low + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + + + + + /sim/rendering/rayleigh-no-polution + + /environment/air-pollution-norm + 0.0003 + + + /environment/air-pollution-norm + 0.0004 + + 1.0 + +

+ /position/altitude-ft + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + 1.0 + +
+
+ /position/altitude-ft + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + 1.0 + +
+ + + + + + + /sim/rendering/rayleigh + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Rayleight:Polution:High + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + + + + + /sim/rendering/rayleigh-no-polution + + /environment/air-pollution-norm + 0.0003 + + + + + /sim/rendering/rayleigh + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Mie:Low + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + 36000 + + + + + + + + 0.005 + + /sim/rendering/skydome-vis-factor + 0.002 + + + + + /sim/rendering/mie + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Mie:Medium + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + 36000 + + + /position/altitude-ft + 85000 + + + + + + + + + 0.005 + + /sim/rendering/skydome-vis-factor + 0.002 + + + + + /position/altitude-ft + 36000 + + 0.00000004 + + + + + /sim/rendering/mie + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Mie:High + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + 85000 + + + + + + + + 0.003 + + /sim/rendering/skydome-vis-factor + 0.002 + + + + + /sim/rendering/mie + + + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:Density:Low + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + + + + + 0.3 + + /environment/air-pollution-norm + 0.05 + + + /environment/air-pollution-norm + 0.05 + + 1.0 + +
+ /position/altitude-ft + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + 1.0 + +
+
+ /position/altitude-ft + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + 1.0 + +
+
+
+
+
+
+ + /sim/rendering/dome-density +
+ + + EnvironmentInterpolator:AtmosphericShader:Skydome:Density:High + gain + + + + + /nasal/local_weather/enabled + true + + + /position/altitude-ft + + + /environment/clouds/layer[0]/elevation-ft + /environment/clouds/layer[0]/thickness-ft + + + + + + + + + + 0.3 + + /environment/air-pollution-norm + 0.05 + + + + + /sim/rendering/dome-density + + + + + EnvironmentInterpolator:AtmosphericShader:Skydome:MeanElevation + gain + + + + /nasal/local_weather/enabled + true + + + + + + + /environment/metar[0]/station-elevation-ft + 0.3048 + + + + /environment/mean-terrain-elevation-m + + From 5ede8f2bb926ba9a415c26a55153b33e41bd7e85 Mon Sep 17 00:00:00 2001 From: Stuart Buchanan Date: Tue, 16 Apr 2013 22:14:51 +0100 Subject: [PATCH 17/17] Fix manual configuration of basic weather. --- gui/dialogs/weather.xml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/gui/dialogs/weather.xml b/gui/dialogs/weather.xml index aba7c54c9..6683172e0 100644 --- a/gui/dialogs/weather.xml +++ b/gui/dialogs/weather.xml @@ -388,6 +388,12 @@ dialog-apply manual-weather-config
+ + nasal + +