Jump to: ecCKD | ARTDECO-PyKdis | RRTMG | RRTMGP | KBIN | PSLACKD | SOCRATES | CMA
A Correlated K-Distribution (CKD) tool generates CKD gas-optics models in a number of steps, some which may require human intervention. One of the most interesting parts of the CKDMIP project will be to understand how differences in how each step is performed feed through to differences in the accuracy of fluxes and heating rates. The page is an attempt to gather the necessary information about the CKD tools participating in CKDMIP, specifically:
Reference(s): Relevant paper(s) describing the method.
Implementation details: What language is the code in, is it (or could it be) suitable for others to use and if so under what license?
Selecting band boundaries: Band boundaries are always chosen manually, but what are the restrictions on band width, e.g. to minimize the number of major gases in each band, or the variation in the Planck function?
Line-by-line model: Which LBL model is used?
Reordering spectrum: Is reordering done separately at each pressure level, or is there a unique mapping from wavenumber to g space?
Choosing number of g points: Is this specified manually, or is an automated procedure used to determine the appropriate number of g points for a particular band and gas?
Partitioning g space for one gas: Is g space partitioned using a fixed formula (e.g. Gaussian Quadrature), or a more adaptive method?
Partitioning g space for multiple gases: How are the g points for the individual active gases in a band combined to produce the total number of g points?
Computing absorption of one gas: How are the LBL spectral absorption values averaged to obtain the absorption by one gas in one g point, e.g. logarithmic averaging? How is the pressure/temperature/concentration dependence of absorption handled in the gas-optics model generated, e.g. parametrically or as a look-up table?
Computing combined absorption of multiple gases: How are the absorptions from multiple gases combined, potentially accounting for non-random spectral overlap?
Computing Planck function for each longwave g point: Is the Planck function first computed for the band and then partitioned amongst the g points, or is account made for exactly where in the band the energy contributing to a particular g point comes from?
Computing incoming solar radiation for each shortwave g point: How is the incoming solar radiation computed for each g point, and using which solar spectrum?
Other relevant information...
ecCKD
Reference: Hogan (JAS 2010), although there have been several improvements since then such as extension to the shortwave.
Implementation details: ecCKD consists of a number of C++ programs called from shell scripts. Permission has been requested to release it to others under the Apache 2.0 open source license, although some tidying would be needed.
Selecting band boundaries: There are no restrictions on the width of a band, and indeed ecCKD can be used to generate full-spectrum correlated-k (FSCK) models.
Line-by-line model: LBLRTM version 12.8; in fact we use only the LBL calculations available from the CKDMIP FTP site.
Reordering spectrum: The spectra for the "median" CKDMIP present-day profile are reordered. Reordering is performed for "major" gases, which are configurable but for the "climate" application are H2O, O3, CO2, CH4, N2O, and in the shortwave only, a composite gas of O2+N2. For the "NWP" application the major gases are H2O, O3 and a composite gas containing all well-mixed gases at present-day concentrations. Each major gas is reordered separately (where a composite gas is treated as a single gas). A unique ordering is produced for each gas that is constant with pressure, i.e. we don't reorder separately at each pressure level. In the longwave, ordering is in terms of the height of the peak cooling rate for an idealized temperature profile that monotonically decreases with height. In the shortwave, ordering is in terms of the height at which the zenith optical depth to top-of-atmosphere is 0.25.
Choosing number of g points: The number of g points required to represent each major gas is computed in turn. The user specifies a heating-rate error tolerance, and the code calculates the number of g points needed to ensure that the RMS heating rate error (compared to the LBL reference) for each g point is less than this tolerance, taking the concentration of the target gas from the "median" CKDMIP profile. The concentrations of all other gases are held at their "minimum" value. This adaptive method to choose the number of g points ensures that fewer g points are used for gases with weak absorption in a particular band, or in a band with little energy.
Partitioning g space for one gas: For each gas, an equipartition algorithm is used to shuffle the boundaries in g space to ensure that each g point contributes roughly equally to the RMS error in heating rate and fluxes, again just considering the "median" CKDMIP profile.
Partitioning g space for multiple gases: If we have M major gases then g space in a band consists of an M-dimensional hypercube. Hogan (2010) described a technique to partition this cube such that the total number of g points required is N = N1+N2+...+NM + 1 - M, where Ni is the number of g points required for gas i. Note that if gas i is declared as major but turns out to have weak absorption in a particular band then it will not lead to unnecessary g points because Ni will be 1 (i.e. a single g point representing the entire band).
Computing absorption of one gas: The CKDMIP "Idealized" dataset is used to construct a look-up table for each gas (major and minor): for a given input temperature, pressure and concentration, the look-up table provides the absorption coefficient of that gas at all N g points. The absorption coefficient in a g point is computed by averaging the spectral absorption coefficients contributing to that g point such that the transmittance of the layer to diffuse radiation is preserved (although other averaging methods are available). For all gases except H2O, the absorption coefficient is assumed to be proportional to concentration (i.e. the look-up table provides the molar absorption coefficient from temperature and pressure, which is then multiplied by the mole fraction of the gas to obtain the absorption coefficient). The look-up table for H2O allows a nonlinear dependence of absorption on concentration. Composite gases represent the sum of those gases whose concentrations can be assumed fixed or a function of pressure alone; in this case the look-up table is a function of temperature and pressure with no dependence on concentration.
Computing combined absorption of multiple gases: Gas optics models produced by ecCKD assume that the total optical depth of a layer in one g point is the sum of the contributions from individual gases, each computed from a look-up table. However, the performance using absorptions directly from the previous step is poor. Therefore, an optimization step is performed: a cost function is defined that consists of the sum of squared errors in fluxes and heating rates, using the 50-profile LBL CKDMIP Evaluation-1 dataset as truth, and sampling a range of greenhouse gas concentration scenarios. The coefficients of the look-up table are adjusted to minimize the cost function. This does, however, mean that an ecCKD-generated gas-optics model is not independent of the Evaluation-1 dataset, so will need to be evaluated with the independent Evaluation-2 dataset.
Computing Planck function for each longwave g point: The Planck function is computed for each g point as a look-up table against temperature with 1 K resolution. Since each g point maps on to the same points of the original spectrum regardless of pressure, this look-up table is created simply by integrating over the spectral Planck function from those spectral points.
Computing incoming solar radiation for each shortwave g point: The incoming solar radiation for a g point is found by integrating over the points of the Coddington et al. (BAMS 2016) reference spectrum used by CKDMIP which contribute to that g point.
ARTDECO-PyKdis
Reference: There is no publication on PyKdis, but the tool is largely based on the method described by Lacis & Oinas (1991) and Edwards & Francis (2000).
Implementation details: The code is written in Python3. Coefficients as computed with the PyKdis tools are distributed with ARTDECO. PyKdis itself is not intended to be shared for now but may be distributed as part of ARTDECO at some point.
Selecting band boundaries: PyKdis can be used to generate correlated-k coefficients for narrow bands ranging over the entire solar and thermal spectral domains. It can also be used to produce coefficients related to instrument spectral response function (e.g. 3MI, METimage, SEVIRI). No specific implementation is available in order to be able to produce full-spectrum correlated-k coefficients, in particular because we use it mostly for solar range under scattering atmosphere (Rayleigh, aerosol, cloud). In the solar range, the solar spectrum is used to weight the spectral absorption coefficients.
Line-by-line model: Either (1) the LBL tool Py4cats, written in Python under the GNU license and integrated into PyKdis, or (2) tabulated LBL spectral absorption. The spectral absorptions must be provided for each gas separately and tabulated for relevant pressures and temperatures. We developed this branch especially in order to be able to use LBL spectral absorptions from LBLRTM and ARAHMIS (the LBL code developed at LOA).
Reordering spectrum: The mapping from wavenumber to g space is done for each temperature and pressure separately considering a given number (depending on the k range) of log10(k) sub-interval. Reordering is performed for each gas separately. As of now, possibility to use a "composite" gas is not implemented.
Choosing number of g points: The number of g points for a given gas depends on its transmission over the band for airmass = 2 computed for a test atmosphere (usually US62). There are two different versions, "full" and "reduced" with the numbers of g points as shown in the table below:
Atmosphere transmission | Ng "full" | Ng "reduced" |
0 < T ≤ 0.05 | 10 | 3 |
0.05 < T ≤ 0.5 | 20 | 5 |
0.5 < T ≤ 0.8 | 15 | 5 |
0.8 < T ≤ 0.9 | 10 | 5 |
0.9 < T ≤ 0.99 | 5 | 5 |
0.99 < T ≤ 0.999 | 3 | 2 |
0.999 < T ≤ 1.0 | 1 | 1 |
Partitioning g space for one gas: For each gas, the partition of g space is obtained by first setting a Gaussian quadrature grid over the log10(k) range for a reference pressure and temperature (most likely corresponding to an altitude where the absorption will be the most important in the atmosphere). This grid is then mapped to the g space and the corresponding g partition is then used for all other pressures and temperatures.
Partitioning g space for multiple gases: Random line position assumption and brute force approach with N g-points being the product of the Ni g-points of individual gases.
Computing absorption of one gas: The g partition being known, we compute the average log10(k) value in each g interval weighting it using the probability density function of log10(k). The coefficients obtained are tabulated in pressure and temperature to produce a look-up table. Molar absorption coefficients are stored. The CKDMIP "Idealized" dataset could then be used to produce such a LUT.
Computing combined absorption of multiple gases: Random line position assumption and brute force approach with N g-points being the product of the Ni g-points of individual gases.
Computing Planck function for each longwave g point: The emission in a particular band and for a particular layer of the atmosphere is computed by considering the average Planck function over the spectral domain covered by the band (DISORT approach). Each g point in a band uses this Planck function in the radiative transfer, and then then a weighted average of the fluxes is computed according to the weight given to each g point. The Planck function is not accounted for in computing the coefficients (i.e. not accounted for in computing g).
Computing incoming solar radiation for each shortwave g point: The incoming solar spectral flux is accounted for in computing g as a weighting function of the spectral absorption coefficients.
Other relevant information: Two versions of the CKD tool are considered. One is based on the spectral reordering scheme described above. The second method uses the Rank Transmutation Strategy described by Andre et al. (2018), in which case the power exponential germ with medium resolution mapping functions (1,000 points) is used.
KBIN
Reference: Doppler et al. (2014)
Implementation details: Code in Python (2-clause BSD license)
Selecting band boundaries: There are no restrictions on the width of a band.
Line-by-line model: LBLRTM version 12.8; in fact we use only the LBL calculations available from the CKDMIP FTP site. In-house version is CGASA (Doppler et al., 2014)
Reordering spectrum: The spectra of the “median” CKDMIP present-day profile are reordered. For the “climate” application we reorder the major gases H2O, O3, CO2, CH4, N2O and a composite gas of 02+N2. The mapping is unique for all pressure levels and done for all gases together. We use uncorrelated k-binning, where the mapping function is found by iteratively optimizing the reordering of a “layer and atmosphere absorption coefficient” (average of total atmosphere and layer absorption coefficient) at each layer by comparing the user-defined error tolerance for total atmosphere and layer transmission. This ensures that the final mapping function is a optimal mapping for total and layer transmission error tolerance.
Choosing number of g points: The number of g points is increased iteratively until either the specified accuracy conditions are met or a specified maximum number of g points is reached.
Partitioning g space for one gas: The partitioning of g space is optimized in our k-binning algorithm in order to satisfy the accuracy conditions.
Partitioning g space for multiple gases: Binning is done for all gases together. Same g points for all gases.
Computing absorption of one gas: The averaging per gas and g point can be specified by the user, default is to average the optical thickness/cross sections.
Computing combined absorption of multiple gases: The optical thicknesses of the individual gases are added according to their relative abundance. Thus the amount of foreign continuum absorption is related to the profile which is used for the k-binning.
Computing Planck function for each longwave g point: We are currently working on solar spectral range only, the longwave part is in revision. The plan is to calculate the Planck function exactly at the high resolution points and then average the radiance in the g space. But this not yet finalized.
Computing incoming solar radiation for each shortwave g point: Can be specified by the user. Default method is to convolve the band with the solar irradiance spectra (Chance and Kurucs, 2010) and normalize after. This is equivalent to a band average over the g point. During the optimization of the number and width of g points the relative solar spectral irradiance is considered (wavenumbers with low intensities do contribute less).
RRTMG
Reference(s): Mlawer et al. (1997). Also Iacono et al. (2008) has some useful information.
Implementation details: The scripts and code are in a combination of bash scripts and FORTRAN (including a Numerical Recipe sorting code). This software is not suitable to be used by others.
Selecting band boundaries: The main consideration is to keep the number of major absorbers to no more than two. The variation in the source function is also considered.
Line-by-line model: LBLRTM. The most recent version of RRTM_LW (3.3) uses LBLRTM_v6.0, an unreleased AER line file for H2O and HITRAN 1996 for other species, and the MT_CKD_2.5 continuum. The most recent version of RRTMG_LW (5.0) uses the same, except it uses CKD_2.4. (An upcoming version (5.1) uses MT_CKD_2.5.) RRTM_SW and RRTMG_SW use LBLRTM_5.21, HITRAN 1996, and CKD_2.1.
Reordering spectrum: Reordering is done separately at each pair of pressure and temperature values.
Choosing number of g points: The number is fixed at 16 initially per band (RRTM) and then reduced manually for RRTMG to differing values in each band such that an integrated and per band clear-sky accuracy of about 1 Wm-2 for flux and 0.1 K/day for heating rate is retained relative to RRTM.
Partitioning g space for one gas: The partitioning is the same in each 16 g-point band. (See Table 2 in Mlawer et al. 1997.) A partitioning into ~10 is chosen by Gaussian quadrature, and then the last segment is partitioned more finely to resolve the ‘elbow’ in k(g) that many bands have.
Partitioning g space for multiple gases: The g-values are the same for single and multiple gases. The major gases (max two) are combined into a single effective gas using the ‘binary species parameter’ and the contributions of minor gases are added to total using a similar mapping.
Computing absorption of one gas: Straight averaging of LBL optical depths is performed to obtain the absorption of one gas in one g point, then divided by column amount (effective column amount in the case of major species). The pressure/temperature/concentration dependence of absorption is handled in the gas-optics model as a look-up table.
Computing combined absorption of multiple gases: Major gases treated as one gas, minor gases added in using consistent mapping.
Computing Planck function for each longwave g point: A mapping consistent with the one that defines the k-distribution is applied to get the fraction of the band’s total Planck associated with each g-point. This is multiplied by the total Planck for the band (for that layer or level).
Computing incoming solar radiation for each shortwave g point: A mapping consistent with the one that defines the k-distribution is applied to get the total solar irradiance associated with each g-point. This mapping is applied at a pressure level where ~10% of the incoming irradiance is absorbed (at surface layer if less than 10% is absorbed in the column. The Kurucz solar spectrum is used in all versions of RRTM_SW and versions of RRTMG_SW earlier than RRTMG_SW_v4.0, and the NRLSSI2 solar function, including the capability to represent solar variability through time-averaged or time-specific values of facular brightening and sunspot dimming, is included in all versions of RRTMG_SW_v4.0 and later.
Other relevant information...
A very minor amount of hand-tuning of k’s was done in one or two bands.
RRTMGP
Reference(s): Pincus et al. (2019). Also, Mlawer et al. (1997) and Iacono et al. (2008) may have some useful information.
Implementation details: A series of bash scripts that execute FORTRAN code. It is potentially suitable for others to use, but is in the process of being fixed up and archived so will be more useable in a few months.
Selecting band boundaries: The band boundaries were mostly inherited from RRTMG, with some minor tweaks. Therefore the criteria were the same as for RRTMG: The main consideration is to keep the number of major absorbers to no more than two. The variation in the source function is also considered.
Line-by-line model: LBLRTM v12.8, line parameter file aer v 3.6 (itself based to a large extent on the HITRAN 2012 line file), and MT CKD 3.2.
Reordering spectrum: Reordering is done separately at each pair of pressure and temperature values.
Choosing number of g points: Fixed at 16 initially per band (RRTM) and then reduced (process underway) to as low as possible until accuracy is considered compromised.
Partitioning g space for one gas: The partitioning is the same in each 16 g-point band. (See Table 2 in Mlawer et al. 1997.) A partitioning into ~10 is chosen by Gaussian quadrature, and then the last segment is partitioned more finely to resolve the ‘elbow’ in k(g) that many bands have.
Partitioning g space for multiple gases: The major gases (max two) are combined into a single effective gas using the ‘binary species parameter’ and the contributions of minor gases are added to total using a similar mapping.
Computing absorption of one gas: Straight averaging of LBL optical depths is performed to obtain the absorption of one gas in one g point, then divided by column amount (effective column amount in the case of major species). The pressure/temperature/concentration dependence of absorption is handled in the gas-optics model as a look-up table.
Computing combined absorption of multiple gases: Major gases treated as one gas, minor gases added in using consistent mapping.
Computing Planck function for each longwave g point: A mapping consistent with the one that defines the k-distribution is applied to get the fraction of the band’s total Planck associated with each g-point. This is multiplied by the total Planck for the band (for that layer or level).
Computing incoming solar radiation for each shortwave g point: A mapping consistent with the one that defines the k-distribution is applied to get the total solar irradiance associated with each g-point. This mapping is applied at a pressure level where ~10% of the incoming irradiance is absorbed (at surface layer if less than 10% is absorbed in the column. The AER high-resolution solar spectrum is used, which has an envelope consistent with the NRLSSI2 medium-resolution solar spectrum, but has incorporated the high-resolution features of the Kurucz solar spectrum (in (roughly) the IR, visible, and UV) and the Toon solar transmittance spectrum (roughly NIR). The code includes the capability to represent solar variability through time-averaged or time-specific values of facular brightening and sunspot dimming.
Other relevant information...
Significant hand-tuning of k’s was done in many bands to increase the code’s accuracy. This is described further by Pincus et al. (2019).
PSLACKD
Implementation details: Fortran, C and IDL
Selecting band boundaries: There is no restriction on band width, except that the maximum band width is limited by the line-by-line code outputs that are used to generate k-distributions.
Reordering spectrum: Reordering is done separately at each pressure level. However, in order to select the same number of g points, determination of the number of g points is done using all pressure levels.
Choosing number of g points: It is automated using a common threshold of transmission for all pressure and temperature, and water vapor concentrations.
Partitioning g space for one gas: Gaussian quadrature is used for the shortwave and longwave.
Partitioning g space for multiple gases: We can handle both random overlap and separating major and minor gases. The submitted files used fixed minor gas concentrations. The concentration of minor gases is fixed in line-by-line computations to generate inputs. Two separate concentrations of the major gas are used so that the absorption cross section is computed by interpolation.
Computing absorption of one gas: Absorption cross sections are averaged in logarithmic space for pressure and concentration, linear for temperature.
Computing combined absorption of multiple gases: Minor gas absorption is included in line-by-line computations. The k-table is built with additional dimension of minor gas concentrations to allow the variation of the minor gas concentration.
Computing Planck function for each longwave g point: The Planck function is first computed for the band and then partitioned amongst the g points.
Computing incoming solar radiation for each shortwave g point: The solar constant for the band is weighted by the gaussian weight. The Coddington Insolation Spectrum is used.
SOCRATES
Reference(s): There is no definitive paper; the code was initially written by Mark Ringer and John Edwards for the simulation of satellite channel radiances (Ringer et al., 2003: http://dx.doi.org/10.1256/qj.02.61), but it was subsequently heavily modified by James Manners for use in the Met Office Global Atmosphere configurations (e.g. Walters et al., 2019: https://gmd.copernicus.org/articles/12/1909/2019/), and with David Amundsen for use in Exoplanet configurations (Amundsen et al., 2014: http://dx.doi.org/10.1051/0004-6361/201323169).
Implementation details: Fortran 2003, 3-clause BSD licence. Free to use/develop.
Selecting band boundaries: Band boundaries are chosen principally to minimize the number of major gases in each band (ideally one). Also, the surface, clouds, aerosols, Rayleigh scattering and the Planck emission all use band-average properties.
Line-by-line model: Line-by-line absorption coefficients are generated internally using HITRAN line-lists or cross-sections as input. It is also possible to use absorption data in an input netCDF file that has been generated externally by, for example, LBLRTM or ExoCross.
Reordering spectrum: An optimal mapping is done using the reordering of effective absorption coefficients from the top-of-atmosphere down to an optical depth of one. This is used for the g-space partitioning and calculation of weights. A new reordering is then done separately for each pressure and temperature in the look-up table to calculate the actual k-terms used for each g-point at a given pressure and temperature (P/T).
Choosing number of g points: Can be specified manually or automated to arrive at the number of g-points that will bring the error in transmission below a given tolerance for each gas and band separately.
Partitioning g space for one gas: g-space is partitioned using the effective absorption coefficients (see ‘re-ordering spectrum’ above). The points are determined to give an equal spacing in the log of the absorption, with extra consideration given to the first point (least absorption) where an assumption is made for the range that can be taken as ‘grey’. Points are combined if there are no data within a given interval. Optionally, this partitioning can be preceded by splitting the absorption coefficients into three groups according to whether their absorption peaks at the top-of-atmosphere, mid-atmosphere or surface (with groups being automatically combined where absorption is very weak). This is a way of overcoming the inaccuracies due to the 'correlated' assumption in the correlated k-distribution method.
Partitioning g space for multiple gases: Not done. Gas k-terms are kept separate in the configuration, but the ‘optimal mapping’ is saved to the spectral file for potential use within the radiative transfer solver for the method of ‘exact-major overlap’.
Computing absorption of one gas: The k-term for a given g partition at a given P/T is found by determining the absorption that would give the smallest error in transmission for a range of path-lengths up to a maximum path-length supplied. Pressure/temperature dependence of absorption is handled in a look-up table. The concentration dependence of the water vapour continuum and collision-induced absorption are handled separately (two methods are available, each assuming only a dependence on concentration and temperature, not pressure).
Computing combined absorption of multiple gases: . Gas overlap is assumed to be random for the method of Equivalent Extinction (see Edwards, 1996: http://dx.doi.org/10.1175/1520-0469(1996)053%3C1921:ECOIFA%3E2.0.CO;2, or more concisely Amundsen et al., 2017: http://dx.doi.org/10.1051/0004-6361/201629322, section 3.3, which also covers the shortwave treatment). A reference method of ‘Exact-major overlap’ is also available that considers the spectral overlap with the major gas exactly using the ‘optimal mapping’ for each gas.
Computing Planck function for each longwave g point: Planck function is computed for the band and applied according to the g-point weights.
Computing incoming solar radiation for each shortwave g point: g-point weights are calculated using a solar spectral weighting (the exact spectrum used depends on configuration – the GA7 configuration uses NRLSSI data meaned over the period 2000-2011). The solar flux per band and the g-point weights can be varied at runtime according to a varying solar spectrum.
CMA
Reference(s): Zhang et al., 2003: An optimal approach to overlapping bands with correlated k distribution method and its application to radiative calculations, J. Geophys. Res., 108(D20), 4641, doi:10.1029/2002JD003358; Zhang et al., 2005: A Comparison Between the Two Line-by-Line Integration Algorithms[J]. Chinese Journal of Atmospheric Sciences, 2005, 29(4): 581-593. doi:10.3878/j.issn.1006-9895.2005.04.09; Zhang et al., 2006: The effects of the choice of the k-interval number on radiative calculations, doi:10.1016/j.jqsrt.2005.05.090.
Implementation details: Coded in Fortran.
Selecting band boundaries: We have different narrow band schemes for various research purpose to balance the accuracy and speed of radiative transfer computations. In general, the number of major gases and the variation in the Planck function in each band are taken into consideration.
Line-by-line model: All the absorption coefficients are calculated by LBLRTM v12.8; They are put into LBLZS2000 (Zhang et al., 2005) radiative transfer model to calculate fluxes and cooling rates in our calculation.
Reordering spectrum: We have a unique mapping from wavenumber to g space. Reordering for the major gas in each band is done at a reference pressure and temperature level, while the absorption coefficients of other levels and other gases are following the reference reordering. See Zhang et al. (2003) for details.
Choosing number of g points: We have an automated procedure to choose g points for every band. See Zhang et al. (2006).
Partitioning g space for one gas: The partitioning of g space is optimized on the basis of Gaussian Quadrature in order to satisfy the accuracy conditions. We make following changes on each Gaussian Quadrature point:
PN(IG)=2*WGT(IG)*XG(IG)
PNUJ(IG)=XG(IG)**2
where XG(IG) and WGT(IG) are the initial abscissa and Gaussian weight respectively, PNUJ(IG) and PN(IG) are the abscissa and Gaussian weight we used.
Partitioning g space for multiple gases: The partitioning of g space is the same for every gas.
Computing absorption of one gas: The absorption coefficients computed from LBLRTM v12.8 are first reordered, and then the effective absorption coefficients are obtained by the above Gaussian Quadrature, i.e., they are averaged with about 100 absorption coefficients at each g point. These effective absorption coefficients are given as a look-up table in 22 pressure and 3 temperature, independent of concentration.
Computing combined absorption of multiple gases: We have three methods for overlapping band based on completely correlated, completely uncorrelated, and partly correlated, which depend on each band. See Zhang et al. (2003).
Computing Planck function for each longwave g point: The Planck function is first computed for the band mean and then partitioned amongst the g points.
Computing incoming solar radiation for each shortwave g point: The band-mean of incoming solar radiation is computed for every shortwave band, and the value for each g point is obtained by Gaussian weights. The solar spectrum is from ‘mean-ssi_nrl2.nc’ in the CKDMIP software.