[4773] | 1 | { |
---|
| 2 | "cells": [ |
---|
| 3 | { |
---|
| 4 | "cell_type": "markdown", |
---|
| 5 | "metadata": {}, |
---|
| 6 | "source": [ |
---|
| 7 | "# Modelling atmospheric radiative transfer\n", |
---|
| 8 | "\n", |
---|
| 9 | "<span style=\"color:darkgray\">**Robin J Hogan and Shannon L Mason**</span>\n", |
---|
| 10 | "\n", |
---|
| 11 | "## 1. Introduction\n", |
---|
| 12 | "\n", |
---|
| 13 | "In this practical, the offline version of ECMWF’s atmospheric radiation scheme *ecRad* [(Hogan and Bozzo, 2018)](https://agupubs.onlinelibrary.wiley.com/doi/pdfdirect/10.1029/2018MS001364)\n", |
---|
| 14 | "will be used to gain an understanding of how radiative transfer is modelled, and how both radiative fluxes and atmospheric heating rates are sensitive to gas concentrations, clouds and aerosols. \n", |
---|
| 15 | "\n", |
---|
| 16 | "The input data consist of a slice through the atmosphere from the North Pole to the South Pole at a longitude of 5$^{\\circ}$E at 12 UTC on 11 July 2019, as represented by ECMWF’s ERA5 reanalysis system. \n", |
---|
| 17 | "The data are stored at 137 levels from the surface to the middle mesosphere (a pressure of 1 Pa), and have been extracted at every 0.5$^{\\circ}$ interval in latitude. \n", |
---|
| 18 | "This slice includes a range of atmospheric and surface conditions, from marine stratocumulus to deep convection, sea ice to a hot desert surface, and pristine marine air over the Southern Ocean to the dust-laden Saharan boundary layer.\n", |
---|
| 19 | "\n", |
---|
| 20 | "<span style=\"color:red\">**Visualise the input data along the slice by running the `plot_input` script.**</span>\n", |
---|
| 21 | "\n", |
---|
| 22 | "***Note: we run the plotting scripts as Python modules, but they can also be run in the command-line if you wish.***" |
---|
| 23 | ] |
---|
| 24 | }, |
---|
| 25 | { |
---|
| 26 | "cell_type": "code", |
---|
| 27 | "execution_count": null, |
---|
| 28 | "metadata": {}, |
---|
| 29 | "outputs": [], |
---|
| 30 | "source": [ |
---|
| 31 | "#First we import all of our plotting scripts\n", |
---|
| 32 | "import plot_input, plot_input_profile, plot_output, plot_output_profile, plot_output_scalar, compare_output, compare_output_profile, compare_output_scalar" |
---|
| 33 | ] |
---|
| 34 | }, |
---|
| 35 | { |
---|
| 36 | "cell_type": "code", |
---|
| 37 | "execution_count": null, |
---|
| 38 | "metadata": {}, |
---|
| 39 | "outputs": [], |
---|
| 40 | "source": [ |
---|
| 41 | "plot_input.main(\"era5slice.nc\")" |
---|
| 42 | ] |
---|
| 43 | }, |
---|
| 44 | { |
---|
| 45 | "cell_type": "markdown", |
---|
| 46 | "metadata": {}, |
---|
| 47 | "source": [ |
---|
| 48 | "Profiles of input data at a given latitude can be plotted using \n", |
---|
| 49 | "\n", |
---|
| 50 | " plot_input_profile.main(10, \"era5slice.nc\")\n", |
---|
| 51 | "\n", |
---|
| 52 | "<span style=\"color:red\">**Try plotting profiles of the input data at a few different latitudes by copying and changing the lines below:**</span>" |
---|
| 53 | ] |
---|
| 54 | }, |
---|
| 55 | { |
---|
| 56 | "cell_type": "code", |
---|
| 57 | "execution_count": null, |
---|
| 58 | "metadata": {}, |
---|
| 59 | "outputs": [], |
---|
| 60 | "source": [] |
---|
| 61 | }, |
---|
| 62 | { |
---|
| 63 | "cell_type": "markdown", |
---|
| 64 | "metadata": {}, |
---|
| 65 | "source": [ |
---|
| 66 | "## 2. The Control experiment\n", |
---|
| 67 | "\n", |
---|
| 68 | "The contents of this directory will include the following files:\n", |
---|
| 69 | "\n", |
---|
| 70 | "- **`radiation_practical.ipynb`** \n", |
---|
| 71 | "This notebook.\n", |
---|
| 72 | "\n", |
---|
| 73 | "- **`ecrad_1.3.1/`**\n", |
---|
| 74 | "The ecrad source code.\n", |
---|
| 75 | "\n", |
---|
| 76 | "- **`ecrad`** \n", |
---|
| 77 | "A symbolic link to the *ecRad* executable.\n", |
---|
| 78 | "\n", |
---|
| 79 | "- **`data/`** \n", |
---|
| 80 | "A symbolic link to the *ecRad* data directory.\n", |
---|
| 81 | "\n", |
---|
| 82 | "- **`config.nam`** \n", |
---|
| 83 | "A Fortran namelist file for configuring *ecRad* in its control configuration.\n", |
---|
| 84 | "\n", |
---|
| 85 | "- **`era5slice.nc`** \n", |
---|
| 86 | "A netCDF file containing the input data; some of its contents are shown in Section 1 above.\n", |
---|
| 87 | "\n", |
---|
| 88 | "- **`*.py`** \n", |
---|
| 89 | "Python scripts for plotting the data; see Section 6 for a description of all the scripts.\n", |
---|
| 90 | "\n", |
---|
| 91 | "- **`ecradplot/`** \n", |
---|
| 92 | "A directory containing the Python library for plotting *ecRad* data.\n", |
---|
| 93 | "\n", |
---|
| 94 | "- **`clean.sh`**\n", |
---|
| 95 | "A little script for cleaning up changes to the working directory, including reverting this Notebook back to a clean state (any changes you've made in the Notebook be coped with a timestamp)." |
---|
| 96 | ] |
---|
| 97 | }, |
---|
| 98 | { |
---|
| 99 | "cell_type": "markdown", |
---|
| 100 | "metadata": {}, |
---|
| 101 | "source": [ |
---|
| 102 | "### 2.1 Running *ecRad*\n", |
---|
| 103 | "\n", |
---|
| 104 | "Now the following runs *ecRad* on the input data using the configuration specified in `config.nam`, and writes the output to a NetCDF file `control.nc`:\n", |
---|
| 105 | "\n", |
---|
| 106 | " ./ecrad config.nam era5slice.nc control.nc\n", |
---|
| 107 | " \n", |
---|
| 108 | "***NOTE: This can be run from a terminal within Jupyter Lab (select \"terminal\" from the \"new launcher\" button), or within a cell in this Notebook by putting the \"!\" character at the front of the line.***" |
---|
| 109 | ] |
---|
| 110 | }, |
---|
| 111 | { |
---|
| 112 | "cell_type": "code", |
---|
| 113 | "execution_count": null, |
---|
| 114 | "metadata": { |
---|
| 115 | "scrolled": true |
---|
| 116 | }, |
---|
| 117 | "outputs": [], |
---|
| 118 | "source": [] |
---|
| 119 | }, |
---|
| 120 | { |
---|
| 121 | "cell_type": "markdown", |
---|
| 122 | "metadata": {}, |
---|
| 123 | "source": [ |
---|
| 124 | "### 2.2 Visualising *ecRad* outputs\n", |
---|
| 125 | "\n", |
---|
| 126 | "#### 2.2.1 Plotting 2D fields\n", |
---|
| 127 | "\n", |
---|
| 128 | "<span style=\"color:red\">**To visualise some key fields from the output file `control.nc`, run the `plot_output.py` script with:**</span>\n", |
---|
| 129 | " \n", |
---|
| 130 | " plot_output.main(\"era5slice.nc\", \"control.nc\")" |
---|
| 131 | ] |
---|
| 132 | }, |
---|
| 133 | { |
---|
| 134 | "cell_type": "code", |
---|
| 135 | "execution_count": null, |
---|
| 136 | "metadata": {}, |
---|
| 137 | "outputs": [], |
---|
| 138 | "source": [] |
---|
| 139 | }, |
---|
| 140 | { |
---|
| 141 | "cell_type": "markdown", |
---|
| 142 | "metadata": {}, |
---|
| 143 | "source": [ |
---|
| 144 | "#### 2.2.2 Plotting profiles\n", |
---|
| 145 | "\n", |
---|
| 146 | "<span style=\"color:red\">**Plot profiles of *ecRad* output at a specific latitude (e.g. 10N) by running `plot_output_profile.py`**</span>\n", |
---|
| 147 | "\n", |
---|
| 148 | " plot_output_profile.main(10, \"era5slice.nc\", [\"control.nc\"])\n", |
---|
| 149 | "\n", |
---|
| 150 | "where `latitude` is a number in the range [-90,90]; e.g. 10, producing a file `era5slice_control_profile_10N.png`. " |
---|
| 151 | ] |
---|
| 152 | }, |
---|
| 153 | { |
---|
| 154 | "cell_type": "code", |
---|
| 155 | "execution_count": null, |
---|
| 156 | "metadata": {}, |
---|
| 157 | "outputs": [], |
---|
| 158 | "source": [] |
---|
| 159 | }, |
---|
| 160 | { |
---|
| 161 | "cell_type": "markdown", |
---|
| 162 | "metadata": {}, |
---|
| 163 | "source": [ |
---|
| 164 | "<span style=\"color:red\">**Try plotting a few different radiation profiles at the same locations you looked at above.**</span>" |
---|
| 165 | ] |
---|
| 166 | }, |
---|
| 167 | { |
---|
| 168 | "cell_type": "code", |
---|
| 169 | "execution_count": null, |
---|
| 170 | "metadata": {}, |
---|
| 171 | "outputs": [], |
---|
| 172 | "source": [] |
---|
| 173 | }, |
---|
| 174 | { |
---|
| 175 | "cell_type": "markdown", |
---|
| 176 | "metadata": {}, |
---|
| 177 | "source": [ |
---|
| 178 | "#### 2.2.3 Plotting 1D fields\n", |
---|
| 179 | "\n", |
---|
| 180 | "<span style=\"color:red\">**Run `plot_output_scalar` to plots the surface and top-of-atmosphere fluxes along the slice:**</span>\n", |
---|
| 181 | "\n", |
---|
| 182 | " plot_output_scalar.main(\"era5slice.nc\", [\"control.nc\"])\n", |
---|
| 183 | "\n", |
---|
| 184 | "producing the file `era5slice_control_surface_and_TOA.png`" |
---|
| 185 | ] |
---|
| 186 | }, |
---|
| 187 | { |
---|
| 188 | "cell_type": "code", |
---|
| 189 | "execution_count": null, |
---|
| 190 | "metadata": {}, |
---|
| 191 | "outputs": [], |
---|
| 192 | "source": [] |
---|
| 193 | }, |
---|
| 194 | { |
---|
| 195 | "cell_type": "markdown", |
---|
| 196 | "metadata": {}, |
---|
| 197 | "source": [ |
---|
| 198 | "***NOTE: if additional ecRad output files from other experiments (see later sections) are provided as arguments to `plot_output_scalar`, they will be overplotted in different colours.***" |
---|
| 199 | ] |
---|
| 200 | }, |
---|
| 201 | { |
---|
| 202 | "cell_type": "markdown", |
---|
| 203 | "metadata": {}, |
---|
| 204 | "source": [ |
---|
| 205 | "Have a look at the figures that have been created. There are three types of variable:\n", |
---|
| 206 | "\n", |
---|
| 207 | "- Upwelling and downwelling shortwave (solar) and longwave (thermal-infrared) irradiances, i.e. the radiativepower passing through a horizontal surface at a particular height in the atmosphere, with units of W m$^{−2}$. \n", |
---|
| 208 | "The labels of the plots use the more common term \"flux\" instead of irradiance, and we will use the same for the remainder of this document. \n", |
---|
| 209 | "The net flux is defined as the downwelling minus the upwelling flux.\n", |
---|
| 210 | "\n", |
---|
| 211 | "- Shortwave and longwave atmospheric heating rates (HR) computed from the vertical divergence of the netflux in pressure coordinates: $$\\mathrm{HR} = −\\dfrac{g_0}{C_p} \\dfrac{\\mathrm{d} F_n}{\\mathrm{d}p},$$ where $F_n$ is the net flux (shortwave or longwave), $p$ is pressure, $g_0$ is the acceleration due to gravity (standard gravity) and $C_p$ is the specific heat of dry air. \n", |
---|
| 212 | "The plots use units of Kelvin per day (K d$^{−1}$).\n", |
---|
| 213 | "\n", |
---|
| 214 | "- Cloud radiative effect, which is a flux minus the equivalent flux computed without clouds present in the profile, and is commonly used to quantify the warming or cooling effect of clouds on the climate system. *ecRad* output files contain both all-sky and clear-sky fluxes." |
---|
| 215 | ] |
---|
| 216 | }, |
---|
| 217 | { |
---|
| 218 | "cell_type": "markdown", |
---|
| 219 | "metadata": {}, |
---|
| 220 | "source": [ |
---|
| 221 | "### <span style=\"color:red\">2.3 Questions</span>\n", |
---|
| 222 | "\n", |
---|
| 223 | "#### <span style=\"color:red\">1. As anyone who has flown in an aeroplane knows, clouds (especially low-level clouds) are turbulent. Explain why, with reference to the radiation fields. Thick low-level clouds are present at 71$^\\circ$N and 15$^\\circ$S.</span>" |
---|
| 224 | ] |
---|
| 225 | }, |
---|
| 226 | { |
---|
| 227 | "cell_type": "code", |
---|
| 228 | "execution_count": null, |
---|
| 229 | "metadata": {}, |
---|
| 230 | "outputs": [], |
---|
| 231 | "source": [] |
---|
| 232 | }, |
---|
| 233 | { |
---|
| 234 | "cell_type": "markdown", |
---|
| 235 | "metadata": {}, |
---|
| 236 | "source": [ |
---|
| 237 | "#### <span style=\"color:red\">2. The net (shortwave plus longwave) heating rate at the stratopause (around 1 hPa) in the Tropics is around +10 K d$^{−1}$. Explain why you would not expect the temperature here a week later to be much warmer.</span>" |
---|
| 238 | ] |
---|
| 239 | }, |
---|
| 240 | { |
---|
| 241 | "cell_type": "code", |
---|
| 242 | "execution_count": null, |
---|
| 243 | "metadata": {}, |
---|
| 244 | "outputs": [], |
---|
| 245 | "source": [] |
---|
| 246 | }, |
---|
| 247 | { |
---|
| 248 | "cell_type": "markdown", |
---|
| 249 | "metadata": {}, |
---|
| 250 | "source": [ |
---|
| 251 | "#### <span style=\"color:red\">3. Explain why the shortwave cloud radiative effect drops sharply polewards of around 80$^\\circ$N, yet optically thick clouds are present all the way to the North Pole.</span>" |
---|
| 252 | ] |
---|
| 253 | }, |
---|
| 254 | { |
---|
| 255 | "cell_type": "code", |
---|
| 256 | "execution_count": null, |
---|
| 257 | "metadata": {}, |
---|
| 258 | "outputs": [], |
---|
| 259 | "source": [] |
---|
| 260 | }, |
---|
| 261 | { |
---|
| 262 | "cell_type": "markdown", |
---|
| 263 | "metadata": {}, |
---|
| 264 | "source": [ |
---|
| 265 | "## 3. Greenhouse gases\n", |
---|
| 266 | "\n", |
---|
| 267 | "The remainder of the practical consists of running *ecRad* with different configurations, plotting the change to fluxes and heating rates, and trying to understand the differences. This section is concerned with investigating the effect of changing the concentration of absorbing gases, but the general procedure for performing an experiment is the same in the following two sections which concern perturbing clouds and aerosols.\n", |
---|
| 268 | "\n", |
---|
| 269 | "### 3.1 Doubled-CO2 experiment\n", |
---|
| 270 | "\n", |
---|
| 271 | "Let’s investigate the radiative impact of doubling the concentration of carbon dioxide. Usually in the context of climate change research, a doubled-CO2 experiment is with respect to preindustrial concentrations (surface volume mixing ratio of around 280 ppmv), but since our control experiment is from 2019 (surface volume mixing ratio ofaround 412 ppmv) we will double the 2019 value. \n", |
---|
| 272 | "\n", |
---|
| 273 | "<span style=\"color:red\">**Make a new copy of the configuration file with for this experiment (`config_co2x2.name`) using the Jupyter file browser, or in the command-line, e.g.**</span>\n", |
---|
| 274 | "\n", |
---|
| 275 | "``cp config.nam config_co2x2.nam``\n", |
---|
| 276 | "\n", |
---|
| 277 | "<span style=\"color:red\">**and edit the new configuration file with the Jupyter editor to change these lines:**</span>\n", |
---|
| 278 | "\n", |
---|
| 279 | " !co2_scaling = 1.0,\n", |
---|
| 280 | " experiment_name = \"Control\",\n", |
---|
| 281 | "\n", |
---|
| 282 | "<span style=\"color:red\">**to these:**</span>\n", |
---|
| 283 | "\n", |
---|
| 284 | " co2_scaling = 2.0,\n", |
---|
| 285 | " experiment_name = \"2x CO2\",\n", |
---|
| 286 | "\n", |
---|
| 287 | "<span style=\"color:red\">**Then run *ecRad* on it, giving `co2x2.nc` as the filename for the output:**</span>\n", |
---|
| 288 | "\n", |
---|
| 289 | "``./ecrad config_co2x2.nam era5slice.nc co2x2.nc``" |
---|
| 290 | ] |
---|
| 291 | }, |
---|
| 292 | { |
---|
| 293 | "cell_type": "code", |
---|
| 294 | "execution_count": null, |
---|
| 295 | "metadata": {}, |
---|
| 296 | "outputs": [], |
---|
| 297 | "source": [] |
---|
| 298 | }, |
---|
| 299 | { |
---|
| 300 | "cell_type": "markdown", |
---|
| 301 | "metadata": {}, |
---|
| 302 | "source": [ |
---|
| 303 | "For a full list of available namelist parameters, see the User Guide at the [*ecRad* web site](https://confluence.ecmwf.int/display/ECRAD). \n", |
---|
| 304 | "In the namelist, lines starting with the `!` character are ignored.\n", |
---|
| 305 | "\n", |
---|
| 306 | "You can compare this experiment with the control as follows:\n", |
---|
| 307 | "\n", |
---|
| 308 | " compare_output.main(\"era5slice.nc\", \"control.nc\", \"co2x2.nc\")" |
---|
| 309 | ] |
---|
| 310 | }, |
---|
| 311 | { |
---|
| 312 | "cell_type": "code", |
---|
| 313 | "execution_count": null, |
---|
| 314 | "metadata": {}, |
---|
| 315 | "outputs": [], |
---|
| 316 | "source": [] |
---|
| 317 | }, |
---|
| 318 | { |
---|
| 319 | "cell_type": "markdown", |
---|
| 320 | "metadata": {}, |
---|
| 321 | "source": [ |
---|
| 322 | "and plot selected profiles at a latitude of 17$^{\\circ}$S with\n", |
---|
| 323 | "\n", |
---|
| 324 | " compare_output_profile.main(-17, \"era5slice.nc\", \"control.nc\", [\"co2x2.nc\"])\n", |
---|
| 325 | "\n", |
---|
| 326 | "***Note that if multiple output files are provided as arguments then they will be overplotted, each using the same control.*** " |
---|
| 327 | ] |
---|
| 328 | }, |
---|
| 329 | { |
---|
| 330 | "cell_type": "code", |
---|
| 331 | "execution_count": null, |
---|
| 332 | "metadata": {}, |
---|
| 333 | "outputs": [], |
---|
| 334 | "source": [] |
---|
| 335 | }, |
---|
| 336 | { |
---|
| 337 | "cell_type": "markdown", |
---|
| 338 | "metadata": {}, |
---|
| 339 | "source": [ |
---|
| 340 | "To compare the fluxes and cloud radiative effect at the surface and top-of-atmosphere at all latitudes, use\n", |
---|
| 341 | "\n", |
---|
| 342 | " compare_output_scalar.main(\"era5slice.nc\", \"control.nc\", [\"co2x2.nc\"])\n", |
---|
| 343 | "\n", |
---|
| 344 | "where multiple output files can be provided as arguments." |
---|
| 345 | ] |
---|
| 346 | }, |
---|
| 347 | { |
---|
| 348 | "cell_type": "code", |
---|
| 349 | "execution_count": null, |
---|
| 350 | "metadata": {}, |
---|
| 351 | "outputs": [], |
---|
| 352 | "source": [] |
---|
| 353 | }, |
---|
| 354 | { |
---|
| 355 | "cell_type": "markdown", |
---|
| 356 | "metadata": {}, |
---|
| 357 | "source": [ |
---|
| 358 | "### <span style=\"color:red\">3.2 Questions and exercises </span>\n", |
---|
| 359 | "\n", |
---|
| 360 | "#### <span style=\"color:red\">1. Will the stratosphere warm or cool in response to increasing CO2 and why?</span>" |
---|
| 361 | ] |
---|
| 362 | }, |
---|
| 363 | { |
---|
| 364 | "cell_type": "code", |
---|
| 365 | "execution_count": null, |
---|
| 366 | "metadata": {}, |
---|
| 367 | "outputs": [], |
---|
| 368 | "source": [] |
---|
| 369 | }, |
---|
| 370 | { |
---|
| 371 | "cell_type": "markdown", |
---|
| 372 | "metadata": {}, |
---|
| 373 | "source": [ |
---|
| 374 | "#### <span style=\"color:red\">2. By perturbing ozone concentrations (e.g. setting the namelist variable `o3_scaling` to `0.7`), explain the mechanisms by which stratospheric ozone depletion leads to a cooling of the Earth system in the shortwave and the longwave.</span>" |
---|
| 375 | ] |
---|
| 376 | }, |
---|
| 377 | { |
---|
| 378 | "cell_type": "code", |
---|
| 379 | "execution_count": null, |
---|
| 380 | "metadata": {}, |
---|
| 381 | "outputs": [], |
---|
| 382 | "source": [] |
---|
| 383 | }, |
---|
| 384 | { |
---|
| 385 | "cell_type": "markdown", |
---|
| 386 | "metadata": {}, |
---|
| 387 | "source": [ |
---|
| 388 | "#### <span style=\"color:red\">3. By perturbing methane concentrations (e.g. setting the namelist variable `ch4_scaling` to `2.0`), estimate how many times stronger a greenhouse gas methane is than carbon dioxide, per molecule, in terms of instantaneous longwave radiative forcing at top-of-atmosphere. You need to know that the 2019 concentration of methane is around 1.905 ppmv, and that the number of molecules of an ideal gas is proportional its volume mixing ratio with no dependence on the molecular mass. The 5th IPCC report stated that methane has a global warming potential 28 times that of carbon dioxide over a 100-year time period. Why might this be different from your number?</span>" |
---|
| 389 | ] |
---|
| 390 | }, |
---|
| 391 | { |
---|
| 392 | "cell_type": "code", |
---|
| 393 | "execution_count": null, |
---|
| 394 | "metadata": {}, |
---|
| 395 | "outputs": [], |
---|
| 396 | "source": [] |
---|
| 397 | }, |
---|
| 398 | { |
---|
| 399 | "cell_type": "markdown", |
---|
| 400 | "metadata": {}, |
---|
| 401 | "source": [ |
---|
| 402 | "## 4. Clouds \n", |
---|
| 403 | "\n", |
---|
| 404 | "Some of the following involve changing the algorithm used to perform the radiative transfer. The impact on computational cost (important for the configuration of a radiation scheme in a weather or climate model) can be estimated by prefixing the ``./ecrad`` command with `time` and looking at the `user` time reported after *ecRad* has finished." |
---|
| 405 | ] |
---|
| 406 | }, |
---|
| 407 | { |
---|
| 408 | "cell_type": "markdown", |
---|
| 409 | "metadata": {}, |
---|
| 410 | "source": [ |
---|
| 411 | "### <span style=\"color:red\">4.1 Questions and exercises</span>\n", |
---|
| 412 | " \n", |
---|
| 413 | "#### <span style=\"color:red\">1. Many models neglect scattering of longwave radiation by clouds for computational expediency. What is the change to longwave cloud radiative effect when longwave scattering is turned off (set `do_lw_cloud_scattering` to `false`)? Why is it of this sign?</span>" |
---|
| 414 | ] |
---|
| 415 | }, |
---|
| 416 | { |
---|
| 417 | "cell_type": "code", |
---|
| 418 | "execution_count": null, |
---|
| 419 | "metadata": {}, |
---|
| 420 | "outputs": [], |
---|
| 421 | "source": [] |
---|
| 422 | }, |
---|
| 423 | { |
---|
| 424 | "cell_type": "markdown", |
---|
| 425 | "metadata": {}, |
---|
| 426 | "source": [ |
---|
| 427 | "#### <span style=\"color:red\">2. The control simulation assumes sub-grid fluctuations in cloud water content such that the fractional standard deviation (the standard deviation divided by the mean) is one. What is the impact on shortwave and longwave cloud radiative effect when clouds are homogeneous (set `fractional_std` to `0.0`) and why?</span>" |
---|
| 428 | ] |
---|
| 429 | }, |
---|
| 430 | { |
---|
| 431 | "cell_type": "code", |
---|
| 432 | "execution_count": null, |
---|
| 433 | "metadata": {}, |
---|
| 434 | "outputs": [], |
---|
| 435 | "source": [] |
---|
| 436 | }, |
---|
| 437 | { |
---|
| 438 | "cell_type": "markdown", |
---|
| 439 | "metadata": {}, |
---|
| 440 | "source": [ |
---|
| 441 | "#### <span style=\"color:red\">3. The control simulation makes the assumption of exponential-random vertical overlap of clouds, which means that vertically separated clouds are randomly overlapped with respect to each other, while vertically contiguous cloud layers decorrelate with separation distance according to an overlap decorrelation length that varies with latitude. What is the impact of making the clouds in all layers overlap randomly (set `overlap_decorr_length_scaling` to `0.0`) and why?</span>" |
---|
| 442 | ] |
---|
| 443 | }, |
---|
| 444 | { |
---|
| 445 | "cell_type": "code", |
---|
| 446 | "execution_count": null, |
---|
| 447 | "metadata": {}, |
---|
| 448 | "outputs": [], |
---|
| 449 | "source": [] |
---|
| 450 | }, |
---|
| 451 | { |
---|
| 452 | "cell_type": "markdown", |
---|
| 453 | "metadata": {}, |
---|
| 454 | "source": [ |
---|
| 455 | "#### <span style=\"color:red\">4. The control simulation uses the *Tripleclouds* solver [(Shonk and Hogan, 2008)](https://git.ecmwf.int/projects/ECRAD/repos/ecrad/raw/practical/ecrad_practical.pdf?at=refs%2Fheads%2Fgithub#cite.Shonk+2008) for performing radiative transfer calculations in the presence of clouds, including the effect of sub-grid fluctuations incloud water content. The operational ECMWF model uses the *McICA* solver [(Pincus et al., 2003)](https://git.ecmwf.int/projects/ECRAD/repos/ecrad/raw/practical/ecrad_practical.pdf?t=refs%2Fheads%2Fgithub#cite.Pincus+2003), which uses a stochastic model to generate sub-grid cloud distributions and can be selected by changing `sw_solver_name` and `lw_solver_name` both to `McICA`. Looking at the atmospheric heating rates (e.g.using `plot_output_profile` at 7$^{\\circ}$N), and the overall computational cost, explain the pros and cons of using *McICA* versus *Tripleclouds* in an operational context.</span>" |
---|
| 456 | ] |
---|
| 457 | }, |
---|
| 458 | { |
---|
| 459 | "cell_type": "code", |
---|
| 460 | "execution_count": null, |
---|
| 461 | "metadata": {}, |
---|
| 462 | "outputs": [], |
---|
| 463 | "source": [] |
---|
| 464 | }, |
---|
| 465 | { |
---|
| 466 | "cell_type": "markdown", |
---|
| 467 | "metadata": {}, |
---|
| 468 | "source": [ |
---|
| 469 | "#### <span style=\"color:red\">5. Ice optical properties are an uncertain part of a radiative transfer scheme. Investigate the size of this uncertainty by switching from the default Fu ice optics model to that of [Yi et al. (2013)](https://git.ecmwf.int/projects/ECRAD/repos/ecrad/raw/practical/ecrad_practical.pdf?at=refs%2Fheads%2Fgithub#cite.Yi+2013) (set `ice_model_name` to `Yi`). Is the main impact in the longwave or shortwave?</span>" |
---|
| 470 | ] |
---|
| 471 | }, |
---|
| 472 | { |
---|
| 473 | "cell_type": "code", |
---|
| 474 | "execution_count": null, |
---|
| 475 | "metadata": {}, |
---|
| 476 | "outputs": [], |
---|
| 477 | "source": [] |
---|
| 478 | }, |
---|
| 479 | { |
---|
| 480 | "cell_type": "markdown", |
---|
| 481 | "metadata": {}, |
---|
| 482 | "source": [ |
---|
| 483 | "#### <span style=\"color:red\">6. A unique property of *ecRad* is the availability of the *SPARTACUS* solver [(Hogan et al., 2016)](https://git.ecmwf.int/projects/ECRAD/repos/ecrad/raw/practical/ecrad_practical.pdf?at=refs%2Fheads%2Fgithub#cite.Hogan+2016) for approximately representing the 3D radiative effects of clouds, available by changing `sw_solver_name` and `lw_solver_name` both to `SPARTACUS`. What is the effect on both the radiation fields and the computational cost?</span>" |
---|
| 484 | ] |
---|
| 485 | }, |
---|
| 486 | { |
---|
| 487 | "cell_type": "code", |
---|
| 488 | "execution_count": null, |
---|
| 489 | "metadata": {}, |
---|
| 490 | "outputs": [], |
---|
| 491 | "source": [] |
---|
| 492 | }, |
---|
| 493 | { |
---|
| 494 | "cell_type": "markdown", |
---|
| 495 | "metadata": {}, |
---|
| 496 | "source": [ |
---|
| 497 | "## 5. Aerosols\n", |
---|
| 498 | "\n", |
---|
| 499 | "### <span style=\"color:red\">5.1 Questions and exercises</span>\n", |
---|
| 500 | "\n", |
---|
| 501 | "#### <span style=\"color:red\">1. Turn off the interaction of radiation with aerosols by setting the namelist parameter `use_aerosols` to `false`. With reference to the surface fluxes, what do you think the impact of Saharan aerosols is on both daytime and nighttime surface temperature?</span>" |
---|
| 502 | ] |
---|
| 503 | }, |
---|
| 504 | { |
---|
| 505 | "cell_type": "code", |
---|
| 506 | "execution_count": null, |
---|
| 507 | "metadata": {}, |
---|
| 508 | "outputs": [], |
---|
| 509 | "source": [] |
---|
| 510 | }, |
---|
| 511 | { |
---|
| 512 | "cell_type": "markdown", |
---|
| 513 | "metadata": {}, |
---|
| 514 | "source": [ |
---|
| 515 | "#### <span style=\"color:red\">2. The direct downwelling solar radiation is that part of the solar radiation field that has not yet been scattered, and to a first approximation its value at a particular point in the atmosphere is proportional to $\\exp(−\\tau)$, where $\\tau$ is the optical depth of the atmosphere above that point along a path towards the sun. Use a clear-sky profile of direct downwelling solar radiation over Africa to estimate the optical depth of the atmosphere with and without aerosols.</span>" |
---|
| 516 | ] |
---|
| 517 | }, |
---|
| 518 | { |
---|
| 519 | "cell_type": "code", |
---|
| 520 | "execution_count": null, |
---|
| 521 | "metadata": {}, |
---|
| 522 | "outputs": [], |
---|
| 523 | "source": [] |
---|
| 524 | }, |
---|
| 525 | { |
---|
| 526 | "cell_type": "markdown", |
---|
| 527 | "metadata": {}, |
---|
| 528 | "source": [ |
---|
| 529 | "#### <span style=\"color:red\">3. Concentrating solar power installations focus the direct solar beam to generate energy, whereas photovoltaic power installations can use all downwelling solar radiation. Which of these installations is most sensitive to dust storms?</span>" |
---|
| 530 | ] |
---|
| 531 | }, |
---|
| 532 | { |
---|
| 533 | "cell_type": "code", |
---|
| 534 | "execution_count": null, |
---|
| 535 | "metadata": {}, |
---|
| 536 | "outputs": [], |
---|
| 537 | "source": [] |
---|
| 538 | }, |
---|
| 539 | { |
---|
| 540 | "cell_type": "markdown", |
---|
| 541 | "metadata": {}, |
---|
| 542 | "source": [ |
---|
| 543 | "#### <span style=\"color:red\">4. From the effect of aerosols on shortwave radiation at the top-of-atmosphere, do aerosols have a warming or cooling effect on climate? What would the effect on climate be if you turned all the aerosols into black carbon (set each of the elements of `i_aerosol_type_map` to `11` and check the output of *ecRad*)? Why?</span>" |
---|
| 544 | ] |
---|
| 545 | }, |
---|
| 546 | { |
---|
| 547 | "cell_type": "code", |
---|
| 548 | "execution_count": null, |
---|
| 549 | "metadata": {}, |
---|
| 550 | "outputs": [], |
---|
| 551 | "source": [] |
---|
| 552 | }, |
---|
| 553 | { |
---|
| 554 | "cell_type": "markdown", |
---|
| 555 | "metadata": {}, |
---|
| 556 | "source": [ |
---|
| 557 | "## 6. Quick guide to Python plotting scripts\n", |
---|
| 558 | "\n", |
---|
| 559 | "**``plot_input.main(<in.nc>)``** \n", |
---|
| 560 | "Plot the main fields in the input file (`era5slice.nc` in this practical) to the image file `<in>.png`. \n", |
---|
| 561 | "\n", |
---|
| 562 | "**``plot_input_profile.main(<lat>,<in.nc>)``** \n", |
---|
| 563 | "Plot profiles of a selection of properties in the input file at the specified latitude (in degrees north) to `<in>_profile_<lat>.png`. \n", |
---|
| 564 | "\n", |
---|
| 565 | "**``plot_output.main(<in.nc>,<out.nc>)``**\n", |
---|
| 566 | "Plot the fluxes and heating rates from the specified output file versus latitude and pressure, with the input file providing the temperature and latitude information, and save the result in `<in>_<out>.png`.\n", |
---|
| 567 | "\n", |
---|
| 568 | "**``plot_output_profile.main(<lat>,<in.nc>,[<out1.nc>,<out2.nc>, ...])``**\n", |
---|
| 569 | "Plot profiles of variables from one or more output files at the specified latitude, saving the result in `<in>_<out1>[_<out2>...]_profile_<lat>.png`. \n", |
---|
| 570 | "\n", |
---|
| 571 | "**``plot_output_scalar.main(<in.nc>,[<out1.nc>,<out2.nc>...])``**\n", |
---|
| 572 | "Line plots versus latitude of upwelling fluxes at top-of-atmosphere, downwelling fluxes at the surface, top-of-atmosphere cloud radiative effect, cloud cover and surface direct shortwave flux, for one or more output files. The result is saved in `<in>_<out1>[_<out2>...]_surface_and_TOA.png`. \n", |
---|
| 573 | "\n", |
---|
| 574 | "**``compare_output.main(<in.nc>,<control.nc>,<out2.nc>)``**\n", |
---|
| 575 | "Plot the difference between the fluxes and heating rates in second output file (the experiment) and the first (the control), saving the result in `<in>_<out2>_vs_<control>.png.` \n", |
---|
| 576 | "\n", |
---|
| 577 | "**``compare_output_profile.main(<lat>,<in.nc>,<control.nc>, [<out2.nc>,<out3.nc>...])``** \n", |
---|
| 578 | "Compare profiles at the specified latitude of the fluxes and heating rates in several output files, where the first is treated as the control, and write the output to `<in>_<out2>[_<out3>...]_vs_<control>_profile_<lat>.png`. \n", |
---|
| 579 | "\n", |
---|
| 580 | "**``compare_output_scalar.main(<in.nc>,<control.nc>,[<out2.nc>,<out3.nc>...])``**\n", |
---|
| 581 | "Compare net fluxes at top-of-atmosphere and the surface, as well as the cloud cover and surface direct shortwave flux, from several output files, where the first is treated as the control. The result is saved in `<in>_<out2>[_<out3>...]_vs_<control>_scalar.png`. " |
---|
| 582 | ] |
---|
| 583 | }, |
---|
| 584 | { |
---|
| 585 | "cell_type": "markdown", |
---|
| 586 | "metadata": {}, |
---|
| 587 | "source": [ |
---|
| 588 | "# References\n", |
---|
| 589 | "\n", |
---|
| 590 | "Hogan, R. J., and A. Bozzo, 2018: A flexible radiation scheme for the ECMWF model. *J. Adv. Model. Earth Syst.*, **10**, [doi:10.1029/2018MS001364](doi:10.1029/2018MS001364).\n", |
---|
| 591 | "\n", |
---|
| 592 | "Hogan, R. J., S. A. K. Schäfer, C. Klinger, J.-C. Chiu and B. Mayer, 2016: Representing 3D cloud-radiation effects in two-stream schemes: 2. Matrix formulation and broadband evaluation. *J. Geophys. Res.*, **121**, 8583–8599.\n", |
---|
| 593 | "\n", |
---|
| 594 | "Pincus, R., H. W. Barker, and J.-J. Morcrette, 2003: A fast, flexible, approximate technique for computing radiative transfer in inhomogeneous clouds. *J. Geophys. Res. Atmos.*, **108**, 4376, [doi:10.1029/2002JD003322](doi:10.1029/2002JD003322).\n", |
---|
| 595 | "\n", |
---|
| 596 | "Shonk, J. K. P., and R. J. Hogan, 2008: Tripleclouds: an efficient method for representing horizontal cloud inho-mogeneity in 1D radiation schemes by using three regions at each height. *J. Climate*, **21**, 2352–2370.\n", |
---|
| 597 | "\n", |
---|
| 598 | "Yi, B., P. Yang, B. A. Baum, T. L’Ecuyer, L. Oreopoulos, E. J. Mlawer, A. J. Heymsfield and K.-K. Liou, 2013: Influence of ice particle surface roughening on the global cloud radiative effect. *J. Atmos. Sci.*, **70**, 2794–2807." |
---|
| 599 | ] |
---|
| 600 | }, |
---|
| 601 | { |
---|
| 602 | "cell_type": "code", |
---|
| 603 | "execution_count": null, |
---|
| 604 | "metadata": {}, |
---|
| 605 | "outputs": [], |
---|
| 606 | "source": [] |
---|
| 607 | } |
---|
| 608 | ], |
---|
| 609 | "metadata": { |
---|
| 610 | "kernelspec": { |
---|
| 611 | "display_name": "Python 3", |
---|
| 612 | "language": "python", |
---|
| 613 | "name": "python3" |
---|
| 614 | }, |
---|
| 615 | "language_info": { |
---|
| 616 | "codemirror_mode": { |
---|
| 617 | "name": "ipython", |
---|
| 618 | "version": 3 |
---|
| 619 | }, |
---|
| 620 | "file_extension": ".py", |
---|
| 621 | "mimetype": "text/x-python", |
---|
| 622 | "name": "python", |
---|
| 623 | "nbconvert_exporter": "python", |
---|
| 624 | "pygments_lexer": "ipython3", |
---|
| 625 | "version": "3.6.10" |
---|
| 626 | } |
---|
| 627 | }, |
---|
| 628 | "nbformat": 4, |
---|
| 629 | "nbformat_minor": 4 |
---|
| 630 | } |
---|