Plotting the solar cycle index

How to plot the current and possible next solar cycle.

import datetime
import matplotlib.pyplot as plt

import sunpy.timeseries as ts

For this example we will use the SunPy sample data. This code snippet grabs the most current NOAA solar cycle data as a TimeSeries.

noaa = ts.TimeSeries(NOAAINDICES_TIMESERIES, source='noaaindices')
noaa_predict = ts.TimeSeries(NOAAPREDICT_TIMESERIES, source='noaapredictindices')

Next, we grab a new copy of the data and shift it forward 11.5 years to simulate the next solar cycle. We will also truncate the data to ensure that we only plot what is necessary.

noaa2 = ts.TimeSeries(NOAAINDICES_TIMESERIES, source='noaaindices') =, freq=datetime.timedelta(days=365 * 11.5))
noaa2 = noaa2.truncate('2020/04/01', '2026/01/01')

Finally, we plot both noaa and noaa2 together, with an arbitrary range for the strength of the next solar cycle.

plt.plot(,['sunspot RI'], label='Sunspot Number')
         color='grey', label='Near-term Prediction')
plt.fill_between(,['sunspot low'],
       ['sunspot high'], alpha=0.3, color='grey')
plt.fill_between(,['sunspot RI smooth']*0.8,
       ['sunspot RI smooth']*1.2, alpha=0.3, color='grey',
                 label='Next Cycle Predict')
plt.plot(,['sunspot RI smooth'], color='grey')
plt.text('2011-01-01', 120, 'Cycle 24')
plt.text('2024-01-01', 120, 'Cycle 25')
plt.ylabel('Sunspot Number')

Total running time of the script: ( 0 minutes 0.000 seconds)

Gallery generated by Sphinx-Gallery