# 13. Climate sensitivity and feedback¶

This notebook is part of The Climate Laboratory by Brian E. J. Rose, University at Albany.

## 1. Radiative forcing¶

### The concept¶

We’ve seen the concept of Radiative Forcing before. It is the short-term change in the TOA energy budget when we add a forcing agent to the climate system, **before the surface has a chance to warm up**.

The standard reference forcing is a **doubling of atmospheric CO\(_2\)**.

The **radiative forcing** is a number in W m\(^{-2}\), defined so that it is **positive if the system is gaining energy**:

\(\Delta R\) is a measure of the rate at which energy begins to accumulate in the climate system after an abrupt increase in greenhouse gases, but *before any change in climate* (i.e. temperature).

### Setting up a single-column Radiative-Convective model¶

Let’s set up a single-column Radiative-Convective model and look carefully at what happens when we add extra CO\(_2\) to the column.

```
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
import xarray as xr
from metpy.plots import SkewT
import climlab
```

```
# This code is used just to create the skew-T plot of global, annual mean air temperature
ncep_url = "http://www.esrl.noaa.gov/psd/thredds/dodsC/Datasets/ncep.reanalysis.derived/"
ncep_air = xr.open_dataset( ncep_url + "pressure/air.mon.1981-2010.ltm.nc", use_cftime=True)
# Take global, annual average
coslat = np.cos(np.deg2rad(ncep_air.lat))
weight = coslat / coslat.mean(dim='lat')
Tglobal = (ncep_air.air * weight).mean(dim=('lat','lon','time'))
# Resuable function to plot the temperature data on a Skew-T chart
def make_skewT():
fig = plt.figure(figsize=(9, 9))
skew = SkewT(fig, rotation=30)
skew.plot(Tglobal.level, Tglobal, color='black', linestyle='-', linewidth=2, label='Observations')
skew.ax.set_ylim(1050, 10)
skew.ax.set_xlim(-90, 45)
# Add the relevant special lines
skew.plot_dry_adiabats(linewidth=0.5)
skew.plot_moist_adiabats(linewidth=0.5)
#skew.plot_mixing_lines()
skew.ax.legend()
skew.ax.set_xlabel('Temperature (degC)', fontsize=14)
skew.ax.set_ylabel('Pressure (hPa)', fontsize=14)
return skew
# and a function to add extra profiles to this chart
def add_profile(skew, model, linestyle='-', color=None):
line = skew.plot(model.lev, model.Tatm - climlab.constants.tempCtoK,
label=model.name, linewidth=2)[0]
skew.plot(1000, model.Ts - climlab.constants.tempCtoK, 'o',
markersize=8, color=line.get_color())
skew.ax.legend()
# Get the water vapor data from CESM output
cesm_data_path = "http://thredds.atmos.albany.edu:8080/thredds/dodsC/CESMA/"
atm_control = xr.open_dataset(cesm_data_path + "cpl_1850_f19/concatenated/cpl_1850_f19.cam.h0.nc")
# Take global, annual average of the specific humidity
weight_factor = atm_control.gw / atm_control.gw.mean(dim='lat')
Qglobal = (atm_control.Q * weight_factor).mean(dim=('lat','lon','time'))
```

```
# Make a model on same vertical domain as the GCM
mystate = climlab.column_state(lev=Qglobal.lev, water_depth=2.5)
# Build the radiation model -- just like we already did
rad = climlab.radiation.RRTMG(name='Radiation',
state=mystate,
specific_humidity=Qglobal.values,
timestep = climlab.constants.seconds_per_day,
albedo = 0.25, # surface albedo, tuned to give reasonable ASR for reference cloud-free model
)
# Now create the convection model
conv = climlab.convection.ConvectiveAdjustment(name='Convection',
state=mystate,
adj_lapse_rate=6.5,
timestep=rad.timestep,
)
# Here is where we build the model by coupling together the two components
rcm = climlab.couple([rad, conv], name='Radiative-Convective Model')
```

```
rcm
```

```
<climlab.process.time_dependent_process.TimeDependentProcess at 0x167e6d370>
```

First let’s take a look at the default CO\(_2\) amount in our reference model:

```
rcm.subprocess['Radiation'].absorber_vmr['CO2']
```

```
0.000348
```

That’s 348 parts per million (ppm). Our atmosphere was at this level around the late 1980s.

Before we can look at the effects of a CO2 perturbation we need to integrate our reference model out to equilibrium:

```
rcm.integrate_years(5)
```

```
Integrating for 1826 steps, 1826.2110000000002 days, or 5 years.
Total elapsed time is 4.999422301147019 years.
```

Are we close to energy balance?

```
rcm.ASR - rcm.OLR
```

```
Field([-3.36228823e-11])
```

### A perturbed CO2 calculation in the RCM¶

```
# Make an exact clone with same temperatures
rcm_2xCO2 = climlab.process_like(rcm)
rcm_2xCO2.name = 'Radiative-Convective Model (2xCO2 initial)'
```

```
# Check to see that we indeed have the same CO2 amount
rcm_2xCO2.subprocess['Radiation'].absorber_vmr['CO2']
```

```
0.000348
```

```
# Now double it!
rcm_2xCO2.subprocess['Radiation'].absorber_vmr['CO2'] *= 2
```

```
# and verify
rcm_2xCO2.subprocess['Radiation'].absorber_vmr['CO2']
```

```
0.000696
```

### Calculate instantaneous radiative forcing¶

The simplest measure of radiative forcing is **the instantaneous change** in the energy budget **before the temperature have a chance to adjust**.

To get this we need to call the `compute_diagnostics`

method, but not any forward timestep.

```
rcm_2xCO2.compute_diagnostics()
```

Now take a look at the changes in the SW and LW budgets:

```
rcm_2xCO2.ASR - rcm.ASR
```

```
Field([0.06274162])
```

```
rcm_2xCO2.OLR - rcm.OLR
```

```
Field([-2.11458541])
```

So what is instantaneous radiative forcing for the doubling of CO2?

```
DeltaR_instant = (rcm_2xCO2.ASR - rcm_2xCO2.OLR) - (rcm.ASR - rcm.OLR)
DeltaR_instant
```

```
Field([2.17732704])
```

The radiative forcing for a doubling of CO2 in this model is 2.18 W m\(^{-2}\).

As we can see above, almost all of the radiative forcing appears in the longwave. We have made the atmosphere **more optically thick** by adding CO\(_2\).

Think about this the same way we increased the absorptivity / emissivity parameter \(\epsilon\) in the simple grey-gas model.

### Statosphere-adjusted radiative forcing¶

The point of measuring radiative forcing is that it should give us some information about how much global warming we should expect from a particular forcing agent.

We will need to use our model to quantify the **eventual** temperature change associated with this forcing.

It turns out, for reasons we won’t get into here, that a more useful measure of the global warming impact of a forcing agent comes from thinking about **changes in radiative flux at the tropopause** rather than the Top of Atmosphere.

The idea here is that we will **let the stratosphere adjust to the extra CO\(_2\)** while **holding the troposphere and surface temperatures fixed**.

In this model levels 0 through 12 are in the statosphere; levels 13 and larger are in the troposphere:

```
rcm.lev[13:]
```

```
array([226.513265, 266.481155, 313.501265, 368.81798 , 433.895225,
510.455255, 600.5242 , 696.79629 , 787.70206 , 867.16076 ,
929.648875, 970.55483 , 992.5561 ])
```

So to compute stratosphere-adjusted forcing, we’ll timestep the model, but continually reset the temperatures to their reference values below 226 hPa:

```
rcm_2xCO2_strat = climlab.process_like(rcm_2xCO2)
rcm_2xCO2_strat.name = 'Radiative-Convective Model (2xCO2 stratosphere-adjusted)'
for n in range(1000):
rcm_2xCO2_strat.step_forward()
# hold tropospheric and surface temperatures fixed
rcm_2xCO2_strat.Tatm[13:] = rcm.Tatm[13:]
rcm_2xCO2_strat.Ts[:] = rcm.Ts[:]
```

Now we can compute the stratosphere-adjusted radiative forcing for the doubling of CO2:

```
DeltaR = (rcm_2xCO2_strat.ASR - rcm_2xCO2_strat.OLR) - (rcm.ASR - rcm.OLR)
DeltaR
```

```
Field([4.28837377])
```

The result is about 4.3 W m\(^{-2}\).

## 2. Equilibrium climate sensitivity (without feedback)¶

We now ask the question: How much warming will we get (eventually) in response to this positive radiative forcing?

### Definition¶

We define the **Equilibrium Climate Sensitivity** (denoted **ECS** or \(\Delta T_{2xCO2}\)):

*The global mean surface warming necessary to balance the planetary energy budget after a doubling of atmospheric CO\(_2\).*

### Climate change in the single-column RCM¶

We can go ahead and calculate ECS in our single-column model:

```
rcm_2xCO2_eq = climlab.process_like(rcm_2xCO2_strat)
rcm_2xCO2_eq.name = 'Radiative-Convective Model (2xCO2 equilibrium)'
rcm_2xCO2_eq.integrate_years(5)
```

```
Integrating for 1826 steps, 1826.2110000000002 days, or 5 years.
Total elapsed time is 12.736753858124827 years.
```

```
# are we close to equilibrium?
rcm_2xCO2_eq.ASR - rcm_2xCO2_eq.OLR
```

```
Field([1.30171429e-11])
```

Let’s follow what we have done before and plot the results on a nice Skew-T:

```
skew = make_skewT()
add_profile(skew, rcm)
add_profile(skew, rcm_2xCO2_strat)
add_profile(skew, rcm_2xCO2_eq)
```

What do you see here? What has changed?

### Calculate the ECS¶

It is just the difference in surface temperature:

```
ECS_nofeedback = rcm_2xCO2_eq.Ts - rcm.Ts
ECS_nofeedback
```

```
Field([1.29984831])
```

Doubling CO\(_2\) in this model causes about 1.3 K of warming at equilibrium.

What about the energy budget?

Remember that we have let the model warm up to its new equilibrium!

If we look at the differences between the two equilibrium states (before and after doubling CO\(_2\)), we find only very small and offsetting changes in SW and LW:

```
rcm_2xCO2_eq.OLR - rcm.OLR
```

```
Field([0.05080282])
```

```
rcm_2xCO2_eq.ASR - rcm.ASR
```

```
Field([0.05080282])
```

The 1.3 K sensitivity we’ve just calculated is the warming that we would have *if there were no other changes (feedbacks) in response to the CO\(_2\) induced warming!*

### The no-feedback response¶

We have just calculated an equilibrium warming \(\Delta T_0\) (in K) resulting from a radiative forcing \(\Delta R\) (in W m\(^{-2}\)) for a model without feedback.

Let’s define the **no-feedback climate response parameter** \(\lambda_0\) as

With the numbers we came up with above,

```
lambda0 = DeltaR / ECS_nofeedback
lambda0
```

```
Field([3.29913401])
```

The no-feedback climate response parameter is \(\lambda_0 = 3.3\) W m\(^{-2}\) K\(^{-1}\).

What are some important processes that our model has neglected?

## 3. The feedback concept¶

A concept borrowed from electrical engineering. You have all heard or used the term before, but we’ll try take a more precise approach today.

A feedback occurs when a portion of the output from the action of a system is added to the input and subsequently alters the output:

The result of a loop system can either be **amplification** or **dampening** of the process, depending on the sign of the gain in the loop, which we will denote \(f\).

We will call amplifying feedbacks **positive** (\(f>0\)) and damping feedbacks **negative** (\(f<0\)).

We can think of the “process” here as the entire climate system, which contains many examples of both positive and negative feedback.

### Example: the water vapor feedback¶

The capacity of the atmosphere to hold water vapor (saturation specific humidity) increases exponentially with temperature. Warming is thus accompanied by moistening (more water vapor), which leads to more warming due to the enhanced water vapor greenhouse effect.

**Positive or negative feedback?**

### Example: the ice-albedo feedback¶

Colder temperatures lead to expansion of the areas covered by ice and snow, which tend to be more reflective than water and vegetation. This causes a reduction in the absorbed solar radiation, which leads to more cooling.

**Positive or negative feedback?**

*Make sure it’s clear that the sign of the feedback is the same whether we are talking about warming or cooling.*

## 4. Climate feedback: some definitions¶

We start with an initial radiative forcing , and get a response $\( \Delta T_0 = \frac{\Delta R}{\lambda_0} \)$

Now consider what happens in the presence of a feedback process. For a concrete example, let’s take the **water vapor feedback**. For every degree of warming, there is an additional increase in the greenhouse effect, and thus additional energy added to the system.

Let’s denote this extra energy as $\( f \lambda_0 \Delta T_0 \)$

where \(f\) is the **feedback amount**, a number that represents what fraction of the output gets added back to the input. \(f\) must be between \(-\infty\) and +1.

For the example of the water vapor feedback, \(f\) is positive (between 0 and +1) – the process adds extra energy to the original radiative forcing.

The amount of energy in the full “input” is now

or

But now we need to consider the next loop. A fraction \(f\) of the additional energy is also added to the input, giving us

and we can go round and round, leading to the infinite series

Question: what happens if \(f=1\)?

It so happens that this infinite series has an exact solution

So the full response including all the effects of the feedback is actually

This is also sometimes written as $\( \Delta T = g \Delta T_0 \)$

where

is called the **system gain** – the ratio of the actual warming (including all feedbacks) to the warming we would have in the absence of feedbacks.

So if the overall feedback is positive, then \(f>0\) and \(g>1\).

And if the overall feedback is negative?

## 5. Water vapor feedback in the radiative-convective model¶

In nature, as in a complex GCM, water vapor tends to increase as the air temperature warms.

The main reason for this is that **the saturation specific humidity** (i.e. how much water vapor the air can hold) **increases strongly with temperature**.

We can **parameterize** this effect in the column model by insisting that the **relative humidity remain fixed** as the column warms.

```
# actual specific humidity
q = rcm.subprocess['Radiation'].specific_humidity
# saturation specific humidity (a function of temperature and pressure)
qsat = climlab.utils.thermo.qsat(rcm.Tatm, rcm.lev)
# Relative humidity
rh = q/qsat
```

```
# Plot relative humidity in percent
fig,ax = plt.subplots()
ax.plot(q*1000, rcm.lev, 'b-')
ax.invert_yaxis()
ax.grid()
ax.set_ylabel('Pressure (hPa)')
ax.set_xlabel('Specific humidity (g/kg)', color='b')
ax.tick_params('x', colors='b')
ax2 = ax.twiny()
ax2.plot(rh*100., rcm.lev, 'r-')
ax2.set_xlabel('Relative humidity (%)', color='r')
ax2.tick_params('x', colors='r')
```

### A radiative-convective model with fixed relative humidity¶

```
rcm_2xCO2_h2o = climlab.process_like(rcm_2xCO2)
rcm_2xCO2_h2o.name = 'Radiative-Convective Model (2xCO2 equilibrium with H2O feedback)'
```

```
for n in range(2000):
# At every timestep
# we calculate the new saturation specific humidity for the new temperature
# and change the water vapor in the radiation model
# so that relative humidity is always the same
qsat = climlab.utils.thermo.qsat(rcm_2xCO2_h2o.Tatm, rcm_2xCO2_h2o.lev)
rcm_2xCO2_h2o.subprocess['Radiation'].specific_humidity[:] = rh * qsat
rcm_2xCO2_h2o.step_forward()
```

```
# Check for energy balance
rcm_2xCO2_h2o.ASR - rcm_2xCO2_h2o.OLR
```

```
Field([-1.7317933e-07])
```

```
skew = make_skewT()
add_profile(skew, rcm)
add_profile(skew, rcm_2xCO2_strat)
add_profile(skew, rcm_2xCO2_eq)
add_profile(skew, rcm_2xCO2_h2o)
```

What is the Equilibrium Climate Sensitivity of this new model?

```
ECS = rcm_2xCO2_h2o.Ts - rcm.Ts
ECS
```

```
Field([2.98902357])
```

With the water vapor feedback, doubling CO\(_2\) causes 3 K of warming at equilibrium, rather than the no-feedback sensitivity of 1.3 K.

A pretty big difference!

The system gain is the ratio

```
g = ECS / ECS_nofeedback
g
```

```
Field([2.29951722])
```

So the moistening of the atmosphere more than doubles the global warming effect.

## 6. Contribution of individual feedback processes to Equilibrium Climate Sensitivity¶

### Adding up the effects of different feedbacks¶

Now what if we have several individual feedback processes occurring simultaneously?

We can think of individual feedback amounts \(f_1, f_2, f_3, ...\), with each representing a physically distinct mechanism, e.g. water vapor, surface snow and ice, cloud changes, lapse rate effects, etc.

Each individual process takes a fraction \(f_i\) of the output and adds to the input. So the feedback amounts are additive,

This gives us a way to compare the importance of individual feedback processes!

The climate sensitivity is now

The climate sensitivity is thus **increased by positive feedback processes**, and **decreased by negative feedback processes**.

### Climate feedback parameters¶

We can also write this in terms of the original radiative forcing as

where

known as **climate feedback parameters**, in units of W m\(^{-2}\) K\(^{-1}\).

With this choice of sign conventions, \(\lambda_i > 0\) for a positive feedback process.

Individual feedback parameters \(\lambda_i\) are then additive, and can be compared to the no-feedback parameter \(\lambda_0\).

We might decompose the net climate feedback into, for example

longwave and shortwave processes

cloud and non-cloud processes

These individual feedback processes may be positive or negative. This is very powerful, because we can **measure the relative importance of different feedback processes** simply by comparing their \(\lambda_i\) values.

### Every climate model has a Planck feedback¶

Our no-feedback response parameter \(\lambda_0\) is often called the **Planck feedback**.

It is not really a feedback at all. It is the most basic and universal climate process, and is present in every climate model. It is simply an expression of the fact that a warm planet radiates more to space than a cold planet.

As we will see, our estimate of \(\lambda_0 = 3.3 ~\text{W} ~\text{m}^{-2} ~\text{K}^{-1} \) is essentially the same as the Planck feedback diagnosed from complex GCMs. Most climate models (and the real climate system) have other radiative feedback processes, such that

### Calculate the feedback parameters in our single-column model¶

We can easily calculate the feedback parameter in our model with water vapor feedback.

This is just the ratio of the radiative forcing \(\Delta R\) to the climate sensitivity:

```
lambda_net = DeltaR / ECS
lambda_net
```

```
Field([1.43470724])
```

The net feedback is \(\lambda = 1.43\) W m\(^{-2}\) K\(^{-1}\).

Because of the additive nature of the feedbacks, this means that the individual contribution of the water vapor feedback is

```
lambda_h2o = lambda0 - lambda_net
lambda_h2o
```

```
Field([1.86442677])
```

So we measure a water vapor feedback of \(\lambda_{h2o} = 1.86\) W m\(^{-2}\) K\(^{-1}\).

This is a **positive number** consistent with the **amplifying effect** of the water vapor feedback.

The physical meaning of this number:

**For every 1 degree of surface warming, the increased water vapor greenhouse effect provides an additional 1.86 W m\(^{-2}\) of radiative forcing.**

## 7. Feedbacks diagnosed from complex climate models¶

### Data from the IPCC AR5¶

This figure is reproduced from the IPCC AR5 report. It shows the feedbacks diagnosed from the various models that contributed to the assessment.

(Later in the term we will discuss how the feedback diagnosis is actually done)

See below for complete citation information.

**Figure 9.43** | (a) Strengths of individual feedbacks for CMIP3 and CMIP5 models (left and right columns of symbols) for Planck (P), water vapour (WV), clouds (C), albedo (A), lapse rate (LR), combination of water vapour and lapse rate (WV+LR) and sum of all feedbacks except Planck (ALL), from Soden and Held (2006) and Vial et al. (2013), following Soden et al. (2008). CMIP5 feedbacks are derived from CMIP5 simulations for abrupt fourfold increases in CO2 concentrations (4 × CO2). (b) ECS obtained using regression techniques by Andrews et al. (2012) against ECS estimated from the ratio of CO2 ERF to the sum of all feedbacks. The CO2 ERF is one-half the 4 × CO2 forcings from Andrews et al. (2012), and the total feedback (ALL + Planck) is from Vial et al. (2013).

*Figure caption reproduced from the AR5 WG1 report*

Legend:

P: Planck feedback

WV: Water vapor feedback

LR: Lapse rate feedback

WV+LR: combined water vapor plus lapse rate feedback

C: cloud feedback

A: surface albedo feedback

ALL: sum of all feedback except Plank, i.e. ALL = WV+LR+C+A

Things to note:

The models all agree strongly on the Planck feedback.

The Planck feedback is about \(-3.3 ~\text{W} ~\text{m}^{-2} ~\text{K}^{-1} \) just like our above estimate of \(\lambda_0\) (but with opposite sign convention – watch carefully for that in the literature)

The water vapor feedback is strongly positive in every model.

The lapse rate feedback is something we will study later. It is slightly negative.

For reasons we will discuss later, the best way to measure the water vapor feedback is to combine it with lapse rate feedback.

Models agree strongly on the combined water vapor plus lapse rate feedback.

The albedo feedback is slightly positive but rather small globally.

By far the largest spread across the models occurs in the cloud feedback.

Global cloud feedback ranges from slighly negative to strongly positive across the models.

Most of the spread in the total feedback is due to the spread in the cloud feedback.

Therefore, most of the spread in the ECS across the models is due to the spread in the cloud feedback.

Look back at the feedback parameters we calculated in our single-column model. How do they compare to the data in this figure?

## Credits¶

This notebook is part of The Climate Laboratory, an open-source textbook developed and maintained by Brian E. J. Rose, University at Albany.

It is licensed for free and open consumption under the Creative Commons Attribution 4.0 International (CC BY 4.0) license.

Development of these notes and the climlab software is partially supported by the National Science Foundation under award AGS-1455071 to Brian Rose. Any opinions, findings, conclusions or recommendations expressed here are mine and do not necessarily reflect the views of the National Science Foundation.