Homework solutions
Contents
2.4.2. Homework solutions#
The BZ reaction can be modelled by the following equations, where \(X_i\) and \(Y_i\) are the concentrations of the two reactants X (red) and Y (colourless) at timestep \(i\). At each timestep, the concentrations of the two reactants change according to the difference equations below. Each timestep has a duration of one second.
Model the evolution of the chemical reaction for \(300\) seconds, assuming the initial concentrations are zero, and using the parameter values \(k_1=0.2,k_2 = 0.4, k_3 = 0.1\mathrm{~and~}k_4 = 0.3\).
Experiment with different values of \(k_1\). For what range of values of \(k_1\) does the reaction exhibit oscillations?
2.4.2.1. Modelling#
First, to model the equations we can follow the same structure we used in the tutorial. To see how the reactants interact we can model both concentrations on the same graph.
# import necessary libraries
import numpy as np
import matplotlib.pyplot as plt
# set up variables and arrays
n = 300
k1 = 0.2
k2 = 0.4
k3 = 0.1
k4 = 0.3
X = np.zeros(n)
Y = np.zeros(n)
# initialise variables (not strictly necessary here!)
X[0] = 0
Y[0] = 0
# implement equations
for i in range(n - 1):
X[i+1] = X[i] + k1 - k2*X[i] + k3*(X[i]**2)*Y[i]
Y[i+1] = Y[i] + k4*X[i] - k3*(X[i]**2)*Y[i]
# plot so we can see what happens
plt.figure(figsize=(5,5))
plt.plot(X, Y)
plt.xlabel("X concentration")
plt.ylabel("Y concentration")
plt.figure(figsize=(5,5))
plt.plot(X)
plt.plot(Y)
plt.xlabel("Time (seconds)")
plt.ylabel("Concentrations")
Text(0, 0.5, 'Concentrations')
data:image/s3,"s3://crabby-images/9f2c0/9f2c0b94f7042196b4ee38ad73593e5b4785bc85" alt="../_images/rate_equations_homework_answers_2_1.png"
data:image/s3,"s3://crabby-images/52590/525904e0fc849b3af513f46f54861eaf2286267a" alt="../_images/rate_equations_homework_answers_2_2.png"
2.4.2.2. Experiment with \(k_1\)#
We can use np.linspace
to test a few different values for \(k_1\). Let’s try the interval \([0, 0.3]\).
for k1 in np.linspace(0, 0.3, 20):
X = np.zeros(n)
X[0] = 0
Y = np.zeros(n)
Y[0] = 0
for i in range(n - 1):
X[i+1] = X[i] + k1 - k2*X[i] + k3*X[i]**2*Y[i]
Y[i+1] = Y[i] + k4*X[i] - k3*X[i]**2*Y[i]
plt.figure(figsize=(5,5))
plt.plot(X, Y)
plt.xlabel("X concentration")
plt.ylabel("Y concentration")
plt.title(k1) # add title to each figure so we can see what the value is
plt.figure(figsize=(5,5))
plt.plot(X)
plt.plot(Y)
plt.xlabel("Time (seconds)")
plt.ylabel("Concentrations")
plt.title(k1) # add title to each figure so we can see what the value is
c:\users\natsciteaching\appdata\local\programs\python\python37\lib\site-packages\ipykernel_launcher.py:9: RuntimeWarning: overflow encountered in double_scalars
if __name__ == "__main__":
c:\users\natsciteaching\appdata\local\programs\python\python37\lib\site-packages\ipykernel_launcher.py:10: RuntimeWarning: overflow encountered in double_scalars
# Remove the CWD from sys.path while we load stuff.
c:\users\natsciteaching\appdata\local\programs\python\python37\lib\site-packages\ipykernel_launcher.py:9: RuntimeWarning: invalid value encountered in double_scalars
if __name__ == "__main__":
c:\users\natsciteaching\appdata\local\programs\python\python37\lib\site-packages\ipykernel_launcher.py:10: RuntimeWarning: invalid value encountered in double_scalars
# Remove the CWD from sys.path while we load stuff.
c:\users\natsciteaching\appdata\local\programs\python\python37\lib\site-packages\ipykernel_launcher.py:12: RuntimeWarning: More than 20 figures have been opened. Figures created through the pyplot interface (`matplotlib.pyplot.figure`) are retained until explicitly closed and may consume too much memory. (To control this warning, see the rcParam `figure.max_open_warning`).
if sys.path[0] == "":
data:image/s3,"s3://crabby-images/f8ef6/f8ef6cde53fbae65e5eae2fecb955439f617787d" alt="../_images/rate_equations_homework_answers_5_1.png"
data:image/s3,"s3://crabby-images/11d97/11d9720c59dc3a9ed7d1b87697bafe7a2d149ff0" alt="../_images/rate_equations_homework_answers_5_2.png"
data:image/s3,"s3://crabby-images/d26b2/d26b269a22700a4e8592322a6a6efde312feceda" alt="../_images/rate_equations_homework_answers_5_3.png"
data:image/s3,"s3://crabby-images/0798c/0798cf60b71abdcf5d34aa84d2858943f8a03e63" alt="../_images/rate_equations_homework_answers_5_4.png"
data:image/s3,"s3://crabby-images/6d595/6d595fa299a9adb8a643144cb6c3fe4b569357a6" alt="../_images/rate_equations_homework_answers_5_5.png"
data:image/s3,"s3://crabby-images/d9a16/d9a16a815387e16ff1dfcb8deb02d676d6da380d" alt="../_images/rate_equations_homework_answers_5_6.png"
data:image/s3,"s3://crabby-images/c7d4f/c7d4f4f1e9951737af93782d57c0552ca2852e69" alt="../_images/rate_equations_homework_answers_5_7.png"
data:image/s3,"s3://crabby-images/62065/62065353b7d80cbf1c352c87a80a95f10890e45a" alt="../_images/rate_equations_homework_answers_5_8.png"
data:image/s3,"s3://crabby-images/adf1f/adf1fe539e6b56b3efd7a54ad8c74840cb05259c" alt="../_images/rate_equations_homework_answers_5_9.png"
data:image/s3,"s3://crabby-images/2dc01/2dc018da4fd7a7df88550a2c84e92c113993f77f" alt="../_images/rate_equations_homework_answers_5_10.png"
data:image/s3,"s3://crabby-images/e2129/e21295a24c2c0f9a3eb4fd2540531f4665a5f5fc" alt="../_images/rate_equations_homework_answers_5_11.png"
data:image/s3,"s3://crabby-images/2d3fe/2d3fe02fd7dfef1918b3aae3ac494a5ee9deff94" alt="../_images/rate_equations_homework_answers_5_12.png"
data:image/s3,"s3://crabby-images/48300/483003e40c040d0dde6e1bade17df6831d1372fb" alt="../_images/rate_equations_homework_answers_5_13.png"
data:image/s3,"s3://crabby-images/0d99f/0d99f320a1ba6238c5658d31defcfb0ac9142b9e" alt="../_images/rate_equations_homework_answers_5_14.png"
data:image/s3,"s3://crabby-images/e0d37/e0d37776ce1aa40866e4ae2a12ca74c4e690557c" alt="../_images/rate_equations_homework_answers_5_15.png"
data:image/s3,"s3://crabby-images/f37fd/f37fd1c8717ef3f95e6a207ce13ca3da2bb53698" alt="../_images/rate_equations_homework_answers_5_16.png"
data:image/s3,"s3://crabby-images/53bd7/53bd7c79abfcdf650067b65aab5ae32185890275" alt="../_images/rate_equations_homework_answers_5_17.png"
data:image/s3,"s3://crabby-images/a245e/a245e09530faf6d54b5cccba40a735a657f86622" alt="../_images/rate_equations_homework_answers_5_18.png"
data:image/s3,"s3://crabby-images/40b7a/40b7a64933a55f589cab8badb948b97b15b355b4" alt="../_images/rate_equations_homework_answers_5_19.png"
data:image/s3,"s3://crabby-images/8954b/8954b434a01f745c4b451baca328758ca2c3c298" alt="../_images/rate_equations_homework_answers_5_20.png"
data:image/s3,"s3://crabby-images/b2b61/b2b6198721b3423fd897a4945908a4970e10891b" alt="../_images/rate_equations_homework_answers_5_21.png"
data:image/s3,"s3://crabby-images/3857a/3857a177ee94f04a8d7c4d5174cd60509c4beb32" alt="../_images/rate_equations_homework_answers_5_22.png"
data:image/s3,"s3://crabby-images/c7dda/c7dda7972927ca8946f0f6b51cbc30decb2a67ed" alt="../_images/rate_equations_homework_answers_5_23.png"
data:image/s3,"s3://crabby-images/fa0f4/fa0f4168b59936582a9d3e0d41577c7f2748b924" alt="../_images/rate_equations_homework_answers_5_24.png"
data:image/s3,"s3://crabby-images/17273/1727376c8066c18b8abcf8aec9e7e7df021a7bb2" alt="../_images/rate_equations_homework_answers_5_25.png"
data:image/s3,"s3://crabby-images/5709e/5709e15586df2aaad35c80fec2885bdee7375e34" alt="../_images/rate_equations_homework_answers_5_26.png"
data:image/s3,"s3://crabby-images/cf8f1/cf8f1d7c006b79c2faca10f0e5fdf2d9aa5a29b7" alt="../_images/rate_equations_homework_answers_5_27.png"
data:image/s3,"s3://crabby-images/641bd/641bdb06ef9e7507a606142f8ddcff56aca74715" alt="../_images/rate_equations_homework_answers_5_28.png"
data:image/s3,"s3://crabby-images/ae996/ae996be8bce2e3b26eb48b297730ad7f0cef1691" alt="../_images/rate_equations_homework_answers_5_29.png"
data:image/s3,"s3://crabby-images/46fff/46fff2d5954927e05bfb8205207fefac2184a83d" alt="../_images/rate_equations_homework_answers_5_30.png"
data:image/s3,"s3://crabby-images/50e9d/50e9d3851a3b3ff4cfa0b242ce954fdd122fc8f9" alt="../_images/rate_equations_homework_answers_5_31.png"
data:image/s3,"s3://crabby-images/9c1be/9c1beac506d894f478a9c40ff25a4836b301ad81" alt="../_images/rate_equations_homework_answers_5_32.png"
data:image/s3,"s3://crabby-images/e2636/e2636c660912b48103025bfb88875a7844e1baf5" alt="../_images/rate_equations_homework_answers_5_33.png"
data:image/s3,"s3://crabby-images/9dcf9/9dcf9c5f9beb9a3da4930470425a1812761cd1d0" alt="../_images/rate_equations_homework_answers_5_34.png"
data:image/s3,"s3://crabby-images/7e71d/7e71de159875372aaaeb8f47771acda4db3d0319" alt="../_images/rate_equations_homework_answers_5_35.png"
data:image/s3,"s3://crabby-images/3e037/3e0373ee632ad43e667b79e01f9802dc868a7a27" alt="../_images/rate_equations_homework_answers_5_36.png"
data:image/s3,"s3://crabby-images/04579/045792c8960f8985acd0777989117be3b6ca1646" alt="../_images/rate_equations_homework_answers_5_37.png"
data:image/s3,"s3://crabby-images/89a49/89a49b76e6cb39133d3e8d1f45e11f2c935b193a" alt="../_images/rate_equations_homework_answers_5_38.png"
data:image/s3,"s3://crabby-images/4eceb/4eceb2d55346dc835a139dff19d61eff8145e077" alt="../_images/rate_equations_homework_answers_5_39.png"
data:image/s3,"s3://crabby-images/58aab/58aabdc29b9b44045ceac73efd40f93d2b828451" alt="../_images/rate_equations_homework_answers_5_40.png"
We see oscillations first appear when \(k_1 \approx 0.079\), these continue until \(k_1 \approx 0.25\) when \(X\) stops oscillating.