Skip to content

Instantly share code, notes, and snippets.

@r4lv
Last active May 24, 2020 20:59
Show Gist options
  • Save r4lv/9459b2538cd25b5e16e09f8a2a4873ec to your computer and use it in GitHub Desktop.
Save r4lv/9459b2538cd25b5e16e09f8a2a4873ec to your computer and use it in GitHub Desktop.
phasespace==1.1.1
numpy==1.18.4
matplotlib==3.2.1
scipy==1.4.1
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Tutorial 3: Toy simulation of $e^{+} e^{-} \\rightarrow \\gamma A'$ using phase space\n",
"\n",
"The idea of the notebook will be to study a basic phase space simulaton of the process $e^{+}e^{-} \\rightarrow \\gamma A'$. Here we will assume that the electron travels along the $z$ axis with $E_{e^{-}} = 6.3\\,\\text{GeV}$ and the positron travels in the exact opposite direction with $E_{e^{+}} = 0.3$ GeV. You may neglect the mass of electrons and take $\\sqrt{s} = \\sqrt{7.56}$ and $\\beta_{e^{+} e^{-}} = 0.9091$.\n",
"\n",
"\n",
"We will generate the decay in the centre-of-mass (CM) frame and compute the momentums and energies of the photon and the $A'$. We will next study the angular distribution of the $A'$ in the CM frame. Finally we will compute the probability that the particle decays in some hypothetical detector volume. The detector is placed $R=5\\,\\text{m}$ in the the $z$ direction from the collision point such that in spherical coordinates it covers the ranges $5 < r < 45\\,\\text{m}$, $0 < \\theta < 15^{\\circ}$ and $0 < \\phi < 360^{\\circ}$. Below you can see the detector. An inner hermetic detector is tasked at reconstructing the $\\gamma$ and cases in which the $A'$ is short lived. Meanwhile, the long baseline detector gives sensitivity to the scenario in which the $A'$ has a longer lifetime."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<div style=\"text-align: center\">\n",
" <img alt=\"\" style=\"width:100%; max-width: 1000px;\" src=\"\" />\n",
"</div>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## 1. Centre-of-mass frame"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"In order to simulate the decay we will use the `phasespace` package in python. Given we assume the CM frame, we set a starting the mass to $\\sqrt{s}$:"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [],
"source": [
"import phasespace\n",
"import numpy as np\n",
"\n",
"E1 = 6.3\n",
"E2 = 0.3\n",
"beta = (E1-E2)/(E1+E2)\n",
"gamma = 1/np.sqrt(1-beta**2)\n",
"s = (E1+E2)**2 - (E1-E2)**2\n",
"Ap_Mass = 2\n",
"photon_Mass = 0\n",
"\n",
"# here we generate two particles A' with mass Ap_Mass\n",
"# and a photon with mass = 0 \n",
"\n",
"# We generate 1,000,000 events\n",
"Ngen = 1_000_000\n",
"weights, particles = phasespace.nbody_decay(np.sqrt(s),\n",
" [Ap_Mass, photon_Mass]).generate(n_events=Ngen)\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's inspect what we have made. We are returned a dictionary with keys `p_0` for the $A'$ and `p_1` for the $\\gamma$. In the dictionary these keys map to tensorflow tensors, however we will simply convert these to numpy arrays:"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"{'p_0': <tf.Tensor: shape=(1000000, 4), dtype=float64, numpy=\n",
" array([[-0.37532898, 0.22631087, 0.47645784, 2.10216568],\n",
" [-0.30168791, 0.38343113, 0.42551792, 2.10216568],\n",
" [ 0.07943709, 0.12522052, 0.63016672, 2.10216568],\n",
" ...,\n",
" [ 0.09240029, 0.07989894, -0.63575064, 2.10216568],\n",
" [-0.35995081, -0.51702018, -0.14908413, 2.10216568],\n",
" [-0.41131191, 0.10709213, -0.48831784, 2.10216568]])>,\n",
" 'p_1': <tf.Tensor: shape=(1000000, 4), dtype=float64, numpy=\n",
" array([[ 0.37532898, -0.22631087, -0.47645784, 0.64737974],\n",
" [ 0.30168791, -0.38343113, -0.42551792, 0.64737974],\n",
" [-0.07943709, -0.12522052, -0.63016672, 0.64737974],\n",
" ...,\n",
" [-0.09240029, -0.07989894, 0.63575064, 0.64737974],\n",
" [ 0.35995081, 0.51702018, 0.14908413, 0.64737974],\n",
" [ 0.41131191, -0.10709213, 0.48831784, 0.64737974]])>}"
]
},
"execution_count": 5,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"particles"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [],
"source": [
"# here we get the 4-momentum of the A' and the gamma as numpy arrays\n",
"p_Ap = particles['p_0'].numpy()\n",
"p_gamma = particles['p_1'].numpy()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Here we have converted the tensors to numpy arrays that contain the 4-momenta of all generate particles lets inspect a bit further. It is very useful to examine the shape of our data first (e.g p_Ap.shape)"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(1000000, 4)"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"p_Ap.shape"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We see the shape is (100000,4), in fact we have a matrix where the rows represent the particles generated (Ngen= 100000) and the columns are actually the 4-momentum components px, py, pz, E. Hence why the shape is (100000,4). Now lets have a look at the 4-momenta for $A'$ and $gamma$ for our generate events"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[-0.37532898, 0.22631087, 0.47645784, 2.10216568],\n",
" [-0.30168791, 0.38343113, 0.42551792, 2.10216568],\n",
" [ 0.07943709, 0.12522052, 0.63016672, 2.10216568],\n",
" ...,\n",
" [ 0.09240029, 0.07989894, -0.63575064, 2.10216568],\n",
" [-0.35995081, -0.51702018, -0.14908413, 2.10216568],\n",
" [-0.41131191, 0.10709213, -0.48831784, 2.10216568]])"
]
},
"execution_count": 8,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"p_Ap"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[ 0.37532898, -0.22631087, -0.47645784, 0.64737974],\n",
" [ 0.30168791, -0.38343113, -0.42551792, 0.64737974],\n",
" [-0.07943709, -0.12522052, -0.63016672, 0.64737974],\n",
" ...,\n",
" [-0.09240029, -0.07989894, 0.63575064, 0.64737974],\n",
" [ 0.35995081, 0.51702018, 0.14908413, 0.64737974],\n",
" [ 0.41131191, -0.10709213, 0.48831784, 0.64737974]])"
]
},
"execution_count": 9,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"p_gamma"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Why is the 4th component, Energy, always constant for our $\\gamma$ and $A'$?"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Here we can use numpy slicing/indexing syntax to retrieve all generate events but either the momentum of energy components"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [],
"source": [
"# 3 momentum\n",
"pvec_Ap = p_Ap[:,:3]"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(1000000, 3)"
]
},
"execution_count": 11,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"pvec_Ap.shape"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[-0.37532898, 0.22631087, 0.47645784],\n",
" [-0.30168791, 0.38343113, 0.42551792],\n",
" [ 0.07943709, 0.12522052, 0.63016672],\n",
" ...,\n",
" [ 0.09240029, 0.07989894, -0.63575064],\n",
" [-0.35995081, -0.51702018, -0.14908413],\n",
" [-0.41131191, 0.10709213, -0.48831784]])"
]
},
"execution_count": 12,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"pvec_Ap"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {},
"outputs": [],
"source": [
"E_Ap = p_Ap[:,3]"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([2.10216568, 2.10216568, 2.10216568, ..., 2.10216568, 2.10216568,\n",
" 2.10216568])"
]
},
"execution_count": 14,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"E_Ap"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"How would you compute the momentum magnitude? Try in the empty cell below. \n",
"\n",
"*Hint:* you will need to square the momentum components which can be done very simply with one operation.\n",
"\n",
"Then you will need to do to use np.sum(v,axis=1) (a sum over the 3 momentum coordinates)\n",
"\n",
"Finally, you can apply np.sqrt()\n",
"\n",
"Your final result should be constant for each generated particle and the shape is (100000,1) What is your momentum magnitude?"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {},
"outputs": [],
"source": [
"# Compute your momentum magnitude here\n",
"P_Ap = np.sqrt(np.sum(pvec_Ap**2,axis=1))"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([0.64737974, 0.64737974, 0.64737974, ..., 0.64737974, 0.64737974,\n",
" 0.64737974])"
]
},
"execution_count": 16,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"P_Ap"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {},
"outputs": [],
"source": [
"# Compute here the invariant mass np.sqrt() using E_Ap and P_Ap\n",
"# you should get 1.2 as expected\n",
"M_Ap = np.sqrt(E_Ap**2 - P_Ap**2)"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([2., 2., 2., ..., 2., 2., 2.])"
]
},
"execution_count": 18,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"M_Ap"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {},
"outputs": [],
"source": [
"px_Ap = p_Ap[:,0]\n",
"py_Ap = p_Ap[:,1]\n",
"pz_Ap = p_Ap[:,2]\n",
"E_Ap = p_Ap[:,3]"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {},
"outputs": [],
"source": [
"# Compute phi using np.arctan() of the relevant momenta\n",
"phi_Ap = np.arctan(py_Ap/px_Ap)"
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {},
"outputs": [],
"source": [
"# Compute theta using np.arctan\n",
"theta_Ap = np.arctan(np.sqrt(px_Ap**2 + py_Ap**2) / pz_Ap)"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {},
"outputs": [],
"source": [
"# here we do a simple transform for theta so that we are in the interval 0 -> pi\n",
"theta_Ap[theta_Ap < 0 ] = theta_Ap[theta_Ap < 0 ] + np.pi"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [],
"source": [
"# Here \n",
"vals = np.linspace(0,np.pi,100)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's now plot $\\theta$ and $\\phi$ in the CM frame. Given that the decay happens according to phase space e.g isoptopic in $\\theta$ and $\\phi$ you should see $\\sin \\theta$ dependence and a uniform $\\phi$ dependence"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAYMAAAEKCAYAAADw2zkCAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAVAklEQVR4nO3dfYxd9Z3f8fdnzUOjPCwQu4j6Ye0k3lYmah0yAqpkozTZgmG3a9JGrFEVvCla7yqgJt1UDWxWBSVECq2SKEiELCkWZpXF0DwIK0vqeClttH9AGIgDGEKYABG2DPZiAomygpr99o/zm81lMuMZz4zvveN5v6Sre+73PNzfPWPP557fOec3qSokSYvbrw26AZKkwTMMJEmGgSTJMJAkYRhIkjAMJEnACYNuwGwtXbq0Vq9ePehmSNKCsXTpUnbu3LmzqjZMnLdgw2D16tWMjo4OuhmStKAkWTpZ3W4iSZJhIEkyDCRJGAaSJAwDSRKGgSQJw0CShGEgSWIB33QmDdrqK/9qXrbz9Gd/Z162I82FYSBNY75+6UvDzDCQGn/pazEzDKQBmyqE7D5SP3kCWZJkGEiSZtBNlOQfAd8FTm7Lf62qrk6yBtgOvBl4APhQVb2S5GTgVuCdwPPA71fV021bVwGXAa8C/7Gqdrb6BuCLwBLgf1TVZ+f1U0o9Fsq5AbuP1E8zOWfwMvC+qvp5khOBv0nybeBPgC9U1fYkX6b7JX9je36hqt6WZBNwHfD7SdYBm4AzgX8C/HWS32zvcQPwr4G9wP1JdlTVo/P4OaXjxpHCzKDQbE3bTVSdn7eXJ7ZHAe8Dvtbq24CL2vTG9po2//1J0urbq+rlqnoKGAPObo+xqnqyql6hO9rYOOdPJkmasRldTZRkCV1X0NvovsX/GPhpVR1ui+wFlrfp5cAzAFV1OMmLdF1Jy4F7ezbbu84zE+rnTNGOLcAWgFWrVs2k6VrEFkp3kDQMZnQCuaperar1wAq6b/L/7Ji2aup23FRVI1U1smzZskE0QZKOS0d1NVFV/RS4B/iXwClJxo8sVgD72vQ+YCVAm//rdCeS/6E+YZ2p6pKkPpk2DJIsS3JKm34d3Ynex+hC4YNtsc3AnW16R3tNm/+/q6pafVOSk9uVSGuB7wH3A2uTrElyEt1J5h3z8eEkSTMzk3MGZwDb2nmDXwPuqKpvJXkU2J7kWuD7wM1t+ZuBv0gyBhyi++VOVe1JcgfwKHAYuLyqXgVIcgWwk+7S0q1VtWfePqGOe54bkOYu3Zf2hWdkZKRGR0cH3QwNAcNgel5yqnFJHqiqkYl170CWJDlQnRYGv/3PjXczazoeGUiSDANJkmEgScIwkCRhGEiSMAwkSXhpqYaMl5BKg2EYSIuY9x9onN1EkiTDQJJkGEiS8JyBpEl4LmHx8chAkuSRgQbDS0il4eKRgSTJMJAkGQaSJAwDSRKGgSQJrybSMeZVQ9LCYBhImjFvRjt+2U0kSZo+DJKsTHJPkkeT7Eny0Va/Jsm+JLvb48Keda5KMpbk8STn99Q3tNpYkit76muS3Nfqtyc5ab4/qCRpajM5MjgMfLyq1gHnApcnWdfmfaGq1rfHXQBt3ibgTGAD8KUkS5IsAW4ALgDWAZf0bOe6tq23AS8Al83T55MkzcC0YVBV+6vqwTb9M+AxYPkRVtkIbK+ql6vqKWAMOLs9xqrqyap6BdgObEwS4H3A19r624CLZvuBJElH76hOICdZDbwDuA94F3BFkkuBUbqjhxfoguLentX28svweGZC/RzgzcBPq+rwJMtPfP8twBaAVatWHU3TJR1Dnlhe+GZ8AjnJG4CvAx+rqpeAG4G3AuuB/cDnjkkLe1TVTVU1UlUjy5YtO9ZvJ0mLxoyODJKcSBcEX62qbwBU1XM9878CfKu93Aes7Fl9RasxRf154JQkJ7Sjg97ltUB4P4G0sM3kaqIANwOPVdXne+pn9Cz2AeCRNr0D2JTk5CRrgLXA94D7gbXtyqGT6E4y76iqAu4BPtjW3wzcObePJUk6GjM5MngX8CHg4SS7W+1P6a4GWg8U8DTwRwBVtSfJHcCjdFciXV5VrwIkuQLYCSwBtlbVnra9TwDbk1wLfJ8ufCRJfTJtGFTV3wCZZNZdR1jnM8BnJqnfNdl6VfUk3dVGkqQB8A5kSZJhIEkyDCRJOGqpjpKXkErHJ8NA0jHjnckLh91EkiTDQJJkGEiSMAwkSRgGkiQMA0kSXloqaQC85HT4eGQgSfLIQJPzTmNpcfHIQJJkGEiSDANJEoaBJAnDQJKEYSBJwjCQJOF9Boue9xNIAo8MJEl4ZCBpiDhm0eBMe2SQZGWSe5I8mmRPko+2+mlJdiV5oj2f2upJcn2SsSQPJTmrZ1ub2/JPJNncU39nkofbOtcnybH4sJKkyc2km+gw8PGqWgecC1yeZB1wJXB3Va0F7m6vAS4A1rbHFuBG6MIDuBo4BzgbuHo8QNoyf9iz3oa5fzRJ0kxNGwZVtb+qHmzTPwMeA5YDG4FtbbFtwEVteiNwa3XuBU5JcgZwPrCrqg5V1QvALmBDm/emqrq3qgq4tWdbkqQ+OKoTyElWA+8A7gNOr6r9bdazwOltejnwTM9qe1vtSPW9k9Qne/8tSUaTjB48ePBomi5JOoIZh0GSNwBfBz5WVS/1zmvf6Gue2/YrquqmqhqpqpFly5Yd67eTpEVjRmGQ5ES6IPhqVX2jlZ9rXTy05wOtvg9Y2bP6ilY7Un3FJHVJUp/M5GqiADcDj1XV53tm7QDGrwjaDNzZU7+0XVV0LvBi607aCZyX5NR24vg8YGeb91KSc9t7XdqzLUlSH8zkPoN3AR8CHk6yu9X+FPgscEeSy4CfABe3eXcBFwJjwC+ADwNU1aEknwbub8t9qqoOtemPALcArwO+3R6SpD5J192/8IyMjNTo6Oigm7HgORyFFjJvRjt6SR6oqpGJdYejkCQ5HMVi4RGApCPxyECSZBhIkgwDSRKGgSQJw0CShGEgScIwkCThfQbHHe8n0GLin8mcPx4ZSJIMA0mSYSBJwjCQJGEYSJIwDCRJGAaSJAwDSRKGgSQJw0CShGEgScKxiRYsxyCSpnak/x+OWzQ5jwwkSYaBJGkGYZBka5IDSR7pqV2TZF+S3e1xYc+8q5KMJXk8yfk99Q2tNpbkyp76miT3tfrtSU6azw8oSZreTI4MbgE2TFL/QlWtb4+7AJKsAzYBZ7Z1vpRkSZIlwA3ABcA64JK2LMB1bVtvA14ALpvLB5IkHb1pw6CqvgscmuH2NgLbq+rlqnoKGAPObo+xqnqyql4BtgMbkwR4H/C1tv424KKj/AySpDmayzmDK5I81LqRTm215cAzPcvsbbWp6m8GflpVhyfUJ5VkS5LRJKMHDx6cQ9MlSb1mGwY3Am8F1gP7gc/NW4uOoKpuqqqRqhpZtmxZP95SkhaFWd1nUFXPjU8n+QrwrfZyH7CyZ9EVrcYU9eeBU5Kc0I4OepeXJPXJrI4MkpzR8/IDwPiVRjuATUlOTrIGWAt8D7gfWNuuHDqJ7iTzjqoq4B7gg239zcCds2mTJGn2pj0ySHIb8F5gaZK9wNXAe5OsBwp4GvgjgKrak+QO4FHgMHB5Vb3atnMFsBNYAmytqj3tLT4BbE9yLfB94OZ5+3SSpBlJ9+V84RkZGanR0dFBN+OYc9gJaX4t9uEokjxQVSMT645NJGlRmeoL1mIPCYejkCQZBpIkw0CShGEgScIwkCRhGEiSMAwkSRgGkiQMA0kShoEkCYejGAqOPyQN3mIfpsIjA0mSYSBJMgwkSRgGkiQMA0kShoEkCcNAkoRhIEnCMJAkYRhIkjAMJEk4NpEkHdFiGbNo2jBIshX4XeBAVb291U4DbgdWA08DF1fVC0kCfBG4EPgF8AdV9WBbZzPwZ22z11bVtlZ/J3AL8DrgLuCjVVXz9PmGigPSSRpWM+kmugXYMKF2JXB3Va0F7m6vAS4A1rbHFuBG+IfwuBo4BzgbuDrJqW2dG4E/7Flv4ntJko6xacOgqr4LHJpQ3ghsa9PbgIt66rdW517glCRnAOcDu6rqUFW9AOwCNrR5b6qqe9vRwK0925Ik9clsTyCfXlX72/SzwOltejnwTM9ye1vtSPW9k9QnlWRLktEkowcPHpxl0yVJE835aqL2jb4vffxVdVNVjVTVyLJly/rxlpK0KMw2DJ5rXTy05wOtvg9Y2bPcilY7Un3FJHVJUh/NNgx2AJvb9Gbgzp76pemcC7zYupN2AuclObWdOD4P2NnmvZTk3HYl0qU925Ik9clMLi29DXgvsDTJXrqrgj4L3JHkMuAnwMVt8bvoLisdo7u09MMAVXUoyaeB+9tyn6qq8ZPSH+GXl5Z+uz0kSX00bRhU1SVTzHr/JMsWcPkU29kKbJ2kPgq8fbp2SJKOHYejkCQ5HMWx4J3G0vHveBumwiMDSZJhIEkyDCRJGAaSJAwDSRKGgSQJw0CShGEgScIwkCRhGEiSMAwkSRgGkiQcqE6S5tVCHcDOMJgDRyeVdLywm0iSZBhIkgwDSRKGgSQJw0CShGEgScIwkCRhGEiSmGMYJHk6ycNJdicZbbXTkuxK8kR7PrXVk+T6JGNJHkpyVs92Nrfln0iyeW4fSZJ0tObjyOBfVdX6qhppr68E7q6qtcDd7TXABcDa9tgC3AhdeABXA+cAZwNXjweIJKk/jsVwFBuB97bpbcD/AT7R6rdWVQH3JjklyRlt2V1VdQggyS5gA3DbMWjbrDjshKTj3VzDoIDvJCngz6vqJuD0qtrf5j8LnN6mlwPP9Ky7t9Wmqv+KJFvojipYtWrVHJsuSf0z7APYzTUM3l1V+5L8Y2BXkh/2zqyqakExL1rY3AQwMjIyb9uVpMVuTucMqmpfez4AfJOuz/+51v1Dez7QFt8HrOxZfUWrTVWXJPXJrMMgyeuTvHF8GjgPeATYAYxfEbQZuLNN7wAubVcVnQu82LqTdgLnJTm1nTg+r9UkSX0yl26i04FvJhnfzl9W1f9Kcj9wR5LLgJ8AF7fl7wIuBMaAXwAfBqiqQ0k+DdzflvvU+MlkSVJ/zDoMqupJ4F9MUn8eeP8k9QIun2JbW4Gts22LJGluvANZkmQYSJIMA0kShoEkCcNAkoRhIEnCMJAkcWxGLV2wHJ1UUr8NywB2HhlIkgwDSZJhIEnCMJAkYRhIkjAMJEkYBpIkDANJEoaBJAnDQJKEYSBJwjCQJLFIB6pzQDpJw67fA9h5ZCBJMgwkSYaBJIkhCoMkG5I8nmQsyZWDbo8kLSZDEQZJlgA3ABcA64BLkqwbbKskafEYijAAzgbGqurJqnoF2A5sHHCbJGnRGJZLS5cDz/S83gucM3GhJFuALe3lz5M8Psv3Wwr87SzX7SfbOf8WSltt5/xbKG09Yjtz3Zy2PeV2hyUMZqSqbgJumut2koxW1cg8NOmYsp3zb6G01XbOv4XS1kG1c1i6ifYBK3ter2g1SVIfDEsY3A+sTbImyUnAJmDHgNskSYvGUHQTVdXhJFcAO4ElwNaq2nMM33LOXU19Yjvn30Jpq+2cfwulrQNpZ6pqEO8rSRoiw9JNJEkaIMNAkrS4wmBYh7xIsjLJPUkeTbInyUdb/Zok+5Lsbo8LB91WgCRPJ3m4tWm01U5LsivJE+351AG38Z/27LfdSV5K8rFh2adJtiY5kOSRntqk+zCd69u/24eSnDXgdv73JD9sbflmklNafXWSv+vZt18ecDun/Fknuartz8eTnN+vdh6hrbf3tPPpJLtbvX/7tKoWxYPuxPSPgbcAJwE/ANYNul2tbWcAZ7XpNwI/ohuW4xrgPw+6fZO092lg6YTafwOubNNXAtcNup0TfvbPAr8xLPsUeA9wFvDIdPsQuBD4NhDgXOC+AbfzPOCENn1dTztX9y43BPtz0p91+7/1A+BkYE37vbBkkG2dMP9zwH/t9z5dTEcGQzvkRVXtr6oH2/TPgMfo7speSDYC29r0NuCiAbZlovcDP66qnwy6IeOq6rvAoQnlqfbhRuDW6twLnJLkjEG1s6q+U1WH28t76e4LGqgp9udUNgLbq+rlqnoKGKP7/dAXR2prkgAXA7f1qz3jFlMYTDbkxdD9wk2yGngHcF8rXdEOx7cOuuulRwHfSfJAGyIE4PSq2t+mnwVOH0zTJrWJ1/7nGsZ9ClPvw2H+t/sf6I5axq1J8v0k/zfJbw2qUT0m+1kP8/78LeC5qnqip9aXfbqYwmDoJXkD8HXgY1X1EnAj8FZgPbCf7vBxGLy7qs6iG2X28iTv6Z1Z3fHtUFyz3G5i/D3gf7bSsO7T1ximfTiVJJ8EDgNfbaX9wKqqegfwJ8BfJnnToNrHAvlZT3AJr/3i0rd9upjCYKiHvEhyIl0QfLWqvgFQVc9V1atV9ffAV+jjoeyRVNW+9nwA+CZdu54b77pozwcG18LXuAB4sKqeg+Hdp81U+3Do/u0m+QPgd4F/34KL1u3yfJt+gK4v/jcH1cYj/KyHbn8CJDkB+LfA7eO1fu7TxRQGQzvkResnvBl4rKo+31Pv7Rf+APDIxHX7Lcnrk7xxfJruZOIjdPtyc1tsM3DnYFr4K17zTWsY92mPqfbhDuDSdlXRucCLPd1JfZdkA/BfgN+rql/01Jel+9skJHkLsBZ4cjCtPOLPegewKcnJSdbQtfN7/W7fJH4b+GFV7R0v9HWf9usM+jA86K7K+BFdun5y0O3pade76boEHgJ2t8eFwF8AD7f6DuCMIWjrW+iuxPgBsGd8PwJvBu4GngD+GjhtCNr6euB54Nd7akOxT+kCaj/w/+j6rC+bah/SXUV0Q/t3+zAwMuB2jtH1uY//W/1yW/bftX8Tu4EHgX8z4HZO+bMGPtn25+PABYP+2bf6LcAfT1i2b/vU4SgkSYuqm0iSNAXDQJJkGEiSDANJEoaBJAnDQJKEYSDNSpIlSb6Ybsjxh9sNQdKCZRhIs3MV8GRVnQlcD3xkwO2R5uSEQTdAWmjaMBwfqKp3ttJTwO8MsEnSnBkG0tH7bWDl+F+jAk6jGz5CWrDsJpKO3nq6v0S1vqrWA9+hGztGWrA8MpCO3ql0XUPjww6fB3wmyW8A19INPf0C3QiTf0c3KNmJwNuBi6v7S3vSUPHIQDp6P6L7W8QA/wn4q+r+fOLlwKeq6uN0o1HurKo/Bt5TVX9GN0zymYNosDQdw0A6ercBZyUZA/453V+ggm6o6b/vWe6l9nywPb9C90fYpaFjN5F0lKrqBX55ZNDrS8A1SfbTBcHf9rVh0hz49wwkSXYTSZIMA0kShoEkCcNAkoRhIEnCMJAkYRhIkjAMJEkYBpIk4P8Dle/6cnzHvLUAAAAASUVORK5CYII=\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"# here you can plot your theta\n",
"import matplotlib.pyplot as plt\n",
"\n",
"# here we convert radians to degrees\n",
"plt.hist(theta_Ap*180/np.pi, bins=50)\n",
"plt.xlabel(r'$\\theta_{\\rm cm}$');\n",
"#plt.savefig('theta.pdf')\n"
]
},
{
"cell_type": "code",
"execution_count": 25,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"# Here you can plot your phi\n",
"import matplotlib.pyplot as plt\n",
"plt.hist(phi_Ap*180/np.pi, bins=50)\n",
"plt.xlabel(r'$\\phi_{\\rm cm}$');\n",
"#plt.savefig('phi.pdf')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## 2. $e^{+} e^{-} \\rightarrow \\gamma A'$ in the Lab frame \n",
"\n",
"So far we have been studying our phase space simulation in the CM frame. Let us now boost into the CM frame.\n",
"\n",
"Note that we have a boost of $\\beta_{e^{+} e^{-}} = -0.9091$ in the $z$ direction. Also note the equations for how the momentum components change under a boost in the $z$ direction:\n",
"\\begin{align}\n",
" p^{\\rm lab}_{x} &= p^{\\rm cm}_{x} \\\\\n",
" p^{\\rm lab}_{y} &= p^{\\rm cm}_{y} \\\\\n",
" p^{\\rm lab}_{z} &= \\gamma( p^{\\rm cm}_{z} - \\beta E^{\\rm cm}) \\\\\n",
"\\end{align}"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {},
"outputs": [],
"source": [
"import phasespace\n",
"import numpy as np\n",
"\n",
"E1 = 6.3\n",
"E2 = 0.3\n",
"beta= -(E1-E2)/(E1+E2)\n",
"gamma = 1/np.sqrt(1-beta**2)\n",
"s = (E1+E2)**2 - (E1-E2)**2\n",
"Ap_Mass = 1.2\n",
"photon_Mass = 0\n",
"\n",
"# here we generate two particles A' with mass Ap_Mass\n",
"# and a photon with mass = 0 \n",
"\n",
"# We generate 1,000,000 events\n",
"Ngen = 1_000_000\n",
"weights, particles = phasespace.nbody_decay(np.sqrt(s),\n",
" [Ap_Mass, photon_Mass]).generate(n_events=Ngen)\n",
"\n",
"# here we get the 4-momentum of the A' and the gamma as numpy arrays\n",
"p_Ap = particles['p_0'].numpy()\n",
"p_gamma = particles['p_1'].numpy()\n"
]
},
{
"cell_type": "code",
"execution_count": 27,
"metadata": {},
"outputs": [],
"source": [
"# Given that we have Beta and hence gamma compute p^lab_z\n",
"px_Ap = p_Ap[:,0]\n",
"py_Ap = p_Ap[:,1]\n",
"pz_Ap = p_Ap[:,2]\n",
"E_Ap = p_Ap[:,3]"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {},
"outputs": [],
"source": [
"# Now boost into the lab frame\n",
"pz_Ap_lab = gamma * (pz_Ap - beta *E_Ap)"
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {},
"outputs": [],
"source": [
"#Now compute momentum again \n",
"P_Ap = np.sqrt(px_Ap**2 + py_Ap**2 + pz_Ap_lab**2)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Is the momentum still constant?"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"import matplotlib.pyplot as plt\n",
"plt.hist(P_Ap, bins=50)\n",
"plt.xlabel(r'$P_{A}$');"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's also inspect the angular distribution in $\\theta_{\\rm lab}$. Why would $\\phi$ on the other hand be unchanged?"
]
},
{
"cell_type": "code",
"execution_count": 31,
"metadata": {},
"outputs": [],
"source": [
"theta = np.arctan(np.sqrt(px_Ap**2+py_Ap**2)/pz_Ap_lab)\n",
"theta[theta < 0 ] = theta[theta < 0 ] + np.pi"
]
},
{
"cell_type": "code",
"execution_count": 32,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"import matplotlib.pyplot as plt\n",
"plt.hist(theta*180/np.pi, bins=50)\n",
"plt.xlabel(r'$\\theta_{\\rm lab}$');"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"What is the probability that the particle has a $\\theta_{\\rm}$ within the long baseline detectors acceptance ($0 < \\theta_{\\rm lab} < 15^{\\circ}$).\n",
"\n",
"Now repeat this for a different mass hypthesis of the $A'$. Try repeat this calculation for $M_{A'} = 1.4$ and $M_{A'} = 1.2$"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.418931"
]
},
"execution_count": 33,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"#more formally using the MC method we can compute this as\n",
"\n",
"len(theta[theta*180/np.pi < 15]) / len(theta)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## 3. Simulating the decay flight of $A'$\n",
"\n",
"In this third part we will look at simulating the decay flight of the $A'$ to understand if the $A'$ would decay in the detector volume. Let's take the case where $M_{A'} = 1.2$ GeV as you will also perform this calculation for this mass analytically in the homework"
]
},
{
"cell_type": "code",
"execution_count": 34,
"metadata": {},
"outputs": [],
"source": [
"import phasespace\n",
"import numpy as np\n",
"\n",
"E1 = 6.3\n",
"E2 = 0.3\n",
"beta= -(E1-E2)/(E1+E2)\n",
"gamma = 1/np.sqrt(1-beta**2)\n",
"s= (E1+E2)**2 - (E1-E2)**2\n",
"Ap_Mass = 1.2\n",
"photon_Mass = 0\n",
"\n",
"# here we generate two particles A' with mass Ap_Mass\n",
"# and a photon with mass = 0 \n",
"\n",
"# We generate 1,000,000 events\n",
"Ngen = 1_000_000\n",
"weights, particles = phasespace.nbody_decay(np.sqrt(s),\n",
" [Ap_Mass, photon_Mass]).generate(n_events=Ngen)\n",
"\n",
"\n",
"# here we get the 4-momentum of the A' and the gamma as numpy arrays\n",
"p_Ap = particles['p_0'].numpy()\n",
"p_gamma = particles['p_1'].numpy()\n",
"\n",
"# Given that we have Beta and hence gamma compute p^lab_\n",
"px_Ap = p_Ap[:,0]\n",
"py_Ap = p_Ap[:,1]\n",
"pz_Ap = p_Ap[:,2]\n",
"E_Ap = p_Ap[:,3]\n",
"\n",
"# Now boost into the lab frame\n",
"pz_Ap_lab = gamma * (pz_Ap - beta*E_Ap)\n",
"\n",
"#Now compute momentum again \n",
"P_Ap_lab = np.sqrt(px_Ap**2 + py_Ap**2 + pz_Ap_lab**2)\n",
"\n",
"# energy is \n",
"E_Ap_lab = np.sqrt(Ap_Mass**2 + P_Ap_lab**2)\n",
"\n",
"# theta lab\n",
"theta_Ap_lab = np.arctan(np.sqrt(px_Ap**2+py_Ap**2)/pz_Ap_lab)\n",
"theta_Ap_lab[theta_Ap_lab < 0 ] = theta_Ap_lab[theta_Ap_lab < 0 ] + np.pi"
]
},
{
"cell_type": "code",
"execution_count": 35,
"metadata": {},
"outputs": [],
"source": [
"# Given the angular acceptance we will select momentum values where theta iswithin the detecor acceptance\n",
"Psel = P_Ap_lab[theta_Ap_lab*180/np.pi < 15]\n",
"Esel = np.sqrt(Ap_Mass**2 + Psel**2)\n",
"# we compute the correspoding beta and gamma\n",
"beta = Psel / Esel\n",
"gamma = 1/np.sqrt(1-beta**2)"
]
},
{
"cell_type": "code",
"execution_count": 36,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.419796"
]
},
"execution_count": 36,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# We see the probability of this angular acceptance from before\n",
"len(Psel) / len(P_Ap_lab)"
]
},
{
"cell_type": "code",
"execution_count": 37,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"5.095980556481348\n"
]
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"# Lets again plot P_Ap_lab\n",
"import matplotlib.pyplot as plt\n",
"plt.hist(Psel, bins=50)\n",
"plt.xlabel(r'$P_{A}$');\n",
"\n",
"# We can also you compute the average momentum\n",
"print(np.mean(Psel))\n",
"# In the analytical computation of the homework this value will be used of roughly 5.1 GeV/c"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"In the homework you will derive the following formula for the the probability the decay happens between to values of $r$:\n",
"\\begin{equation}\n",
" P(r_{1} < r_{\\rm decay} < r_{2}) = e^{-r_{1} / (\\beta \\gamma c\\tau )} - e^{-r_{2} / (\\beta \\gamma c\\tau )} \n",
"\\end{equation}\n",
"\n",
"where here $\\tau$ is the lifetime. \n",
"\n",
"With this and the accept reject method we can run a small simulation to find the probability that decays end up within the detector volumen $5<r<45$ (remember we have already selection the $P$ values in the required angular range.\n",
"\n",
"We will actually do this for the value of $c \\tau$ that roughly maximises the probability that the decay hapens in the detector volume this can be found by differentiating the expression above and is a question in the homework. The value will be roughly $c\\tau = 4.29\\,\\text{m}$. This is approximate as the homework will assume the average $P^{\\rm lab}_{A'}$ value.\n",
"\n",
"To simulate the decays we compute the probability, $ P(5< r_{\\rm decay} < 45)$, for each generated $A'$ decays in the $5<r<45$ based on the $\\beta$ and $\\gamma$ values and the $r$ interval. Now we generate a random uniform number, $u$, where $0 < u < 1$. When $ u < P(5< r_{\\rm decay} < 45)$ we accept the event."
]
},
{
"cell_type": "code",
"execution_count": 38,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.6579433820236495\n"
]
}
],
"source": [
"ctau = 4.283\n",
"r1 = 5\n",
"r2 = 45\n",
"prob_decay = np.exp(-r1/(beta*gamma*ctau)) - np.exp(-r2/(beta*gamma*ctau))\n",
"u = np.random.uniform(0,1,len(Psel))\n",
"print(len(Psel[u<prob_decay]) / len(Psel))"
]
},
{
"cell_type": "code",
"execution_count": 39,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.276202\n"
]
}
],
"source": [
"# The total efficiency is now found to be:\n",
"print(len(Psel[u<prob_decay]) / len(P_Ap_lab))"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"This is slightly lower than the value in the homework as we don't have a fixed momentum."
]
},
{
"cell_type": "code",
"execution_count": 40,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.6756758044383463\n"
]
}
],
"source": [
"# HW calculaton but using toys\n",
"betahw = 5.1/np.sqrt(5.1**2+1.2**2)\n",
"gammahw = 1/np.sqrt(1-betahw**2)\n",
"\n",
"prob_decay = np.exp(-r1/(betahw*gammahw*ctau)) - np.exp(-r2/(betahw*gammahw*ctau))\n",
"u = np.random.uniform(0, 1, len(Psel))\n",
"print(len(Psel[u<prob_decay]) / len(Psel))"
]
},
{
"cell_type": "code",
"execution_count": 41,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.283646\n"
]
}
],
"source": [
"# The total efficiency is now found to be:\n",
"print(len(Psel[u<prob_decay]) / len(P_Ap_lab))"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We can also use our toy decay simulation approach to get the probability $P(5< r_{\\rm decay} < 45)$ as a function of $c\\tau$"
]
},
{
"cell_type": "code",
"execution_count": 42,
"metadata": {},
"outputs": [],
"source": [
"taus = np.linspace(0.1, 10, 100)"
]
},
{
"cell_type": "code",
"execution_count": 43,
"metadata": {},
"outputs": [],
"source": [
"r1 = 10\n",
"r2 = 40\n",
"\n",
"P = []\n",
"for tau in taus:\n",
" prob_decay = np.exp(-r1/(beta*gamma*tau)) - np.exp(-r2/(beta*gamma*tau))\n",
" k = np.random.uniform(0, 1, len(Psel))\n",
" P.append(len(Psel[k<prob_decay]) / len(Psel))"
]
},
{
"cell_type": "code",
"execution_count": 44,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEGCAYAAABhMDI9AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3deXzddZ3v8dcnW7M0SdMmTdN93+hCS1q2IiAgBQRkBhREBRQYx2FkrqPjLurMdcbxquOC8xAR0RFlEORSoQVlH0FKF0r3jXRJ2qRJmqbZ1/O5f5zATUqXk/Sc8zvJeT8fDx4953dOznkfoOed3/f7+31/5u6IiIi8LSXoACIiklhUDCIi0oeKQURE+lAxiIhIHyoGERHpIy3oAKersLDQJ0+eHHQMEZFBZd26dbXuXnS8xwZ9MUyePJm1a9cGHUNEZFAxs30nekxDSSIi0oeKQURE+lAxiIhIHyoGERHpQ8UgIiJ9qBhERKQPFYOIiPQx6M9jEElUbZ3drN5Tx7bKBmaNyWXxhALys9ODjiVySioGkeOobWpn16EmqhvbONTQRme3k52RSs6wNLpDTmV9K5VH26hv7SQtxUjt+ccAM+Nwcwev7zlMW2eoz+tOHJmN47S0d9PRFaIwdxhjR2QyNj+LSaOymVyYw+RROWSkpdDZHaI75KSmGJnpqQxLS6E4L5P0VO3oS2ypGER6HKhv5U9bqli1uYrX99ZxsmtYmUFxbiYjstMJudMVcrpD/s7PZKWncuOSiVw0q4gF40ewvaqBN/bXs72qkfQUIzMjlYzUFGoa2zl4tJUXd9ZQ09h+yoy5w9JYNqOQi2YVMackj9zMdPIy08gZlkZGagopKRalfxuSzFQMkrQqj7by8s4aVpfVsXpPHQfqWwGYWTycT793BkunjKQ4bxij8zIZlpZCc3s3ze1d4VLo52/u500r5LxphSd9TktHF3trW9hf10xXyElLSSEtxegKOe1d3bR2dLOhvJ4Xd9SwanPVcV8jPdUYnZvJ4kkFlE4qYEbxcFIsXBbDh6UxsziXjDTtccjJ2WC/tGdpaalrrSQ5ldaObnZVN7K9qpFtlQ28uvswOw41AlA4PIMlk0eydMpILphRxPTRwwNOe3Luzs5DTZTXtdDQ1klDayctneGhqbbOEOVHWli39whVDW3v+tmM1BTmjM1jwbh8ZhYPZ/roXKYW5ZCbmUZWeipm2uNIFma2zt1Lj/eY9hhkyDrc1M6z2w6xanMVr+yupbM7/EvQsLQUSicXcP1Zc7hwVhEzRg8fVF+IZsasMbnMGpN7wue4OwfqW9lf1/LOtiPNnWysqGdDeT2Pv3GApvauY14XRuVkcPPZk7j9ginkZmqiPFlpj0GGlK7uEC/trOHhNeU8v72a7pAzYWQWl88dw1mTCpg1JpdJo3JITfKxeHenqqGNXYea2FfXQlNbFy0dXWyrbODZbdWMyE7nlnMn0x1y3qppovxIC2PyMpk+OpeZxcO5aNZoRuZkBP0x5DRoj0GGtFDIeaP8CE9trOKpTQc51NBO4fAMbl82hWvOHMvckrxBtUcQD2ZGSX4WJflZ73psU8VRvvunHfzguV2kphiTRmYzriCL/XUtvLSzhs5uJyMthasXjOVj505iRvHwdybdszM0HDUUaI9BBqVwGdTz1MZKVm2upPJoGxmpKbxnZiHXnzWeS+YU67DO01Td2MaIrIw+k9Wd3SF2VDXy8Jr9/H79AVo6uvv8zOwxudxxwVSuXjhWk9wJ7mR7DCoGGXRWbqrkX57cysFeZXDVghIumVNMnsbF46axrZOVmyo50tIJQGdXiBVvHmRXdRPFecM4Z+oostJTyUxPpSQ/k4UTRjB/XD45wzRQkQhUDDIkdHSF+NdV2/jFK3tZMD6f286frDJIMO7OiztrePCVveypbaats5vWzm4a28IT3SkGs8fksWxGIcumF1I6uYDsDBVFEFQMMujtqW3mHx/ZwPr99dx2/mS+eMUcDVUMIoeb2tlYcZQN5fWs3nOYdfuOvHOU2LgRWUwtyiE/K52D9a2UH2kl1YzPXDaT688ar5P2YkTFIINWeV0LP3p+F4+tP0BmWgrfvn4B718wNuhYcppaOrpYvaeOjeVHKattoqymmYa2TsaNyGJCQTa7a5pYt+8ICyeM4EtXzGZ2SR55mWma2I4iFYMMOkeaO/jBc7t4aPU+zIybz57I3140jdG5mUFHkzhwdx5/4wDfWrmd2qbwUiEZqSmUjMjkvGmjuHjWaM6fXqj5itOgYpBBo6MrxK/+spcfPreLpvYuPrRkAp++ZMZxD6uUoa+hrZMXtldT09hOTVM7e2ubeXX3YRrbu0hPNRZPLOD86YWcP72QRRNGaNipH1QMMigcrG/lk79ex8aKo7xnZhFfvnLOSc/uleTU2R1izd46XtpRwytv1bLlYAPuMGFkFh88awLXl46nJD+LUMhxSPqTGU9ExSAJ7/U9dXzqoXW0dYb4zvULuGJ+SdCRZJCoa+7gpZ3V/G5tBa++dfhdj4/KyXhnSfMr5pVw6ZzRmqtAxSAJ7qHV+7jniS1MHJnNfR8rTfhF7CRx7TvczMpNVbR2dL0zrHSooY29tS3sqm6ktqmDxRNH8Pnlszl76qiA0wZLxSAJKRRyvv30dn76chkXzyriBzct0jkJEjOd3SEeXVfBfzy7k0MN7Uwcmc3UohymFg5n7tg8zp4ykvEFWUmzN6G1kiThtHV284+PvMlTmyr56DmTuOfquaRpCQuJofTUFG5aOpHrFo3jN6v3s37/EcpqmlldVkdrZ3hpjzF5mcwuyWVkdgYFORlMLcph+RljGDV8WMDp40t7DBJ3Ww4e5fOPbWTzgQa+dOVs7rhgatL8liaJJxRydlU38fqew6zeU8f+uhbqmjuoa+6gpaOb1BTj/OmFXLNwLJefUTxkliPXUJIkhLbObn743C5++nIZBdnpfOu6+bzvjDFBxxI5Lndnx6FGVmw4yB82HqS8rpWMtBQumT2ay+YWM3ZEFqNzh1GSn0VWRmrQcftNxSCBq21q56M/f51tlQ1cf9Z4vnLVHEZkaz1/GRzcnQ3l9Tyx4SBPbjxIbVPHO4+lphhLJhdwyexiLp49mmlFOYNiDzhhisHMlgM/AFKB+939307wvL8GHgWWuPtJv/VVDImvurGNm3+2mvIjLfzk5sW8d3Zx0JFEBqyrO8Se2maqG9upbmxj56EmXthezfaq8KVix+Rlct70UZw/rZAlk0cyYWRiTmgnRDGYWSqwE7gMqADWADe5+9ZjnpcLPAVkAHepGAa3Qw1t3PSz16g62sYDty7hnCQ/RFCGrgP1rby4o5pXdx/m1bdq31mOvCh3GKWTCrhgRhHvnT2aMfmJsaxLohyVtBTY7e5lPaEeBq4Fth7zvH8Gvg18Lo7ZJAZqGtu58b7XqG5o45cfX8qSySODjiQSM+NGZHHz2ZO4+exJhELh+Yl1+46wbt8RVpcdZtXmKiB8MaPJo3IYNTyDUcOHcfaUkZw9ZWRCHZUXz2IYB5T3ul8BnN37CWa2GJjg7k+ZmYphEDva2sktD7xO1dE2fn37Us6apFKQ5JGSYswpyWNOSR4fOWcS7s7OQ008v72aV9+q5a2aJl7f28GRlg5+6FCQnc5lc4u5eNZolk4ZGfjhsQlzHoOZpQDfA26N4Ll3AncCTJw4MbbBpN9aO7q5/Zdr2FXdyP23LFEpSNIzM2aNyWXWmFz+9qJp72xv7ejmpZ01PL25kpWbqnhkbQUAs4pzWTghn1lj8pg9Jpf54/PjevJnPOcYzgW+7u6X99z/IoC7/2vP/XzgLaCp50fGAHXANSebZ9AcQ2Lp6g5x53+t44Ud1fzopkW6doJIhDq7Q2w6cJTXyg7zWlkdWw8efefop7QUo3RyARfPGs0ZY/PJykglOyOVvKx0xo0Y2MrDiTL5nEZ48vkS4ADhyecPu/uWEzz/ReCzmnweXL6+YgsPvrqXf/nAPD5yzqSg44gMarVN7WyvbOTVt2p5YUcN2yob+jw+pySPVXdfMKDXTojJZ3fvMrO7gGcIH676gLtvMbNvAmvdfUW8skhs/Oove3nw1b3cccEUlYJIFBQOH8ayGcNYNqOQf1o+m6qjbeyva6Glo4uWjm6y0mNzYp1OcJOoeGlnDR9/cA0XzSzivo+Vag18kQR3sj2GxDk+Sgat7VUN3PXQemaMHs4PblqkUhAZ5FQMcloqj7Zy6wNryB6Wys9vXcJwXYNXZNDT32IZsKOtndz6wBqa2rt45G/OHfDRESKSWLTHIAPS0RXik/+1jrLaJn760bOYOzYv6EgiEiXaY5AB+dbKbfyl7DDf/9BCzp9eGHQcEYki7TFIvz2x4QAPvrqXj58/hesWjQ86johEmYpB+mXnoUa+8NgmSicV8MUrZwcdR0RiQMUgEWtq7+KTv15HzrA07r15MekJtBqkiESP/mZLRNydzz+2kb21zfzopkUU5yXGmvIiEn0qBonIL1/dy1MbK/nc5bM5d5outiMylKkY5JTW7z/C/165jUvnjOZv3jM16DgiEmMqBjmp+pYO7npoPcV5mXz3hjNJ0XIXIkOezmOQk/q3Vds51NjO4586j/zs+F0oRESCoz0GOaF1+47w8JpyPrFsCgvGjwg6jojEiYpBjqurO8RX/u9mxuRlcvclM4KOIyJxpGKQ4/rVX/axrbKBe66eS45WTBVJKioGeZdDDW187087uXBmEcvnjQk6jojEmYpB3uVfntpGR3eIb1xzBmY6Ckkk2agYpI8/76rlD28e5FMXTWNyYU7QcUQkACoGeUd7Vzdfe2Izk0Zl88kLpwUdR0QCollFecd9L5VRVtvMg7ctITM9Neg4IhIQ7TEIAOV1Lfz4hd1cOX8MF80aHXQcEQmQikEA+MYftpCaYnz1/XODjiIiAVMxCM9tO8Sz26q5+5IZlORnBR1HRAKmYkhybZ3dfOMPW5lWlMNt508JOo6IJABNPie5n75Uxv66Fh66/Wwy0vR7gohojyGplde18JMXd3PVghLOn14YdBwRSRAqhiT27ae3k2LGV66aE3QUEUkg/S4GM8sxMx3kPshtPnCUJzdWcvsFUzThLCJ9nLIYzCzFzD5sZk+ZWTWwHag0s61m9h0zmx77mBJt33lmByOy07lDl+oUkWNEssfwAjAN+CIwxt0nuPtoYBnwGvBtM/tIDDNKlL1WdpiXdtbwqYumkZepq7KJSF+RHJV0qbt3HrvR3euAx4DHzEzfLoOEu/PvT29nTF4mHzt3ctBxRCQBnXKP4XilMJDnSGJ4dls16/fXc/elM7QekogcV7/PYzCzZcBSYLO7/zH6kSRW3J0fv7CbSaOyueGs8UHHEZEEFcnk8+u9bt8B/BjIBe4xsy/0583MbLmZ7TCz3cf7WTP7pJltMrMNZvZnM9PCPVG0bt8R3iyv5/ZlU0hL1ZHKInJ8kXw79J4/uBO4zN2/AbwPuDnSN+o5xPVe4ApgLnDTcb74f+Pu8939TODfge9F+vpyavf/zx7ys9L5a+0tiMhJRFIMKWZWYGajAHP3GgB3bwa6+vFeS4Hd7l7m7h3Aw8C1vZ/g7g297uYA3o/Xl5PYd7iZZ7ZW8ZFzJpKdoZVQROTEIvmGyAfWAQa4mZW4e6WZDe/ZFqlxQHmv+xXA2cc+ycz+DvgMkAG8tx+vLyfxi1f2kpZiOhJJRE4pkqOSJrv7VHef0vNnZc9DIeC6aAdy93vdfRrweeArx3uOmd1pZmvNbG1NTU20Iww5R1s6eWRtOdcsHEdxXmbQcUQkwQ1oBtLMfuXuLe6+px8/dgCY0Ov++J5tJ/Iw8IHjPeDu97l7qbuXFhUV9SNCcnro9X20dHTziWVaVltETu2UQ0lmtuLYTcDFZjYCwN2vifC91gAzzGwK4UK4EfjwMe81w9139dy9CtiFnJa2zm5+8cpelk0vZO7YvKDjiMggEMkcw3hgK3A/4clgA0qB7/bnjdy9y8zuAp4BUoEH3H2LmX0TWOvuK4C7zOxSoBM4AtzSn/eQd3v8jQPUNLbz/Q+eGXQUERkkIimGUuBu4MvA59x9g5m1uvtL/X0zd18JrDxm29d63b67v68pJ9Ydcn72chnzxuVx/vRRQccRkUHilMXg7iHg+2b2u54/D0XycxK8P22toqy2mR9/eBFm/TmATESSWcRf8O5eAdxgZlcBDad6vgTL3fnPl8qYNCqbK+aVBB1HRAaRfh+V5O5PufuXYhFGoue1sjreLK/njgumkpqivQURiZwWzBmifvryWxQOz+B6LX8hIv2kYhiCdlQ18uKOGm49b7KW1haRfouoGMws28wWHrNtopmNi00sOR0/+58ystJTufnsSUFHEZFBKNI9hk7g92aW02vb/YBmNRPMoYY2nthwgA+WjqcgJyPoOCIyCEVUDD1XaHsc+CCE9xaAIndfG8NsMgAPvrqX7pDzcS1/ISID1J85hvuB23pufwz4RfTjyOloau/iodf2sXzeGCaNyjn1D4iIHEd/zmPYbmEzCa9zdEHsYslAPLKmnIa2Lu64YGrQUURkEOvvUUk/J7znsMndj8QgjwxQKOQ8+OpeSicVsGhiQdBxRGQQ628xPAIsJFwQkkBe3lXD/roWPnbe5KCjiMgg1681j9y9hfAV3STBPLR6P6NyMlh+xpigo4jIIKcT3IaAg/WtPLftEB9cMoGMNP0nFZHTo2+RIeDh1/fjwIeXTgw6iogMAQO+tKeZXRHtMNJ/nd0hHl5TzoUzi5gwMjvoOCIyBAx0j+F2oMjMHjazu485I1ri6Nmth6hubOcjWv5CRKJkoMUwCphK+LoMVegopcA8tHo/Y/MzuXj26KCjiMgQMdArsX0WuNfdywDMrDx6kSRSFUda+PPuWv7h0hm65oKIRM1Ai+F3wGfMLBvA3T8evUgSqcfWHQDgrxfrmgsiEj2nM8dQD3wd2BO1NBKxUMh5dH05500bpUlnEYmqgRbDISATCAHF0YsjkXp9bx3lda3cUKq9BRGJroEOJT0EdAD/BDwbvTgSqUfXVTB8WBrLz9AlMUQkuga6xzDC3Xe7+6cJH5UkcdTc3sXKTZW8f0EJWRm6dKeIRNdAi+G6XreviUYQidzKTZW0dHRz/VkaRhKR6BvoUFKxmU0DHBgbxTwSgUfXVTClMIezJml5bRGJvoEWw1eAv+u5fU+UskgEyutaWL2njs++byZmOndBRKLvdIaSRrr75wlf5lPi5PE3wucuXKdzF0QkRgZaDNOAt892zo1SFjkFd+fxNw5wztSRjBuRFXQcERmiBloMDmSZ2Tw0xxA3b5TXs6e2mb/S3oKIxNBAi+G7gAEfBb4UvThyMr9fX0FmegpXzNNV2kQkdgY0+ezu+4EvRDmLnER7VzdPbqzkfXPHkJuZHnQcERnC+l0MZvY7IAfIALoA3H15lHPJMV7YXkN9Syd/tXhc0FFEZIjr91CSu98ArAUuB64A/hTtUPJuj79RQVHuMJZNLww6iogMcQOdY5gJjAPGEL5gj8TQ0dZOnt9ezbULx5KWqst0i0hsRfQtY2YpZtZ7kvke4NPAZ4AfRfpmZrbczHaY2W4ze9cchZl9xsy2mtlGM3vOzHS9SsKX7+zsdt6/UAeAiUjsRVQM7h4C3t/r/g53/6y7f87dt0fyGmaWCtxLePhpLnCTmc095mlvAKXuvgB4FPj3SF57qFu1uZKx+ZksHJ8fdBQRSQL9GZfYaGb3mNlAxzKWArvdvczdO4CHgWt7P8HdX3D3lp67rwFJf8B+Y1snL++s5Yr5JVoCQ0Tioj9f8iOBG4GDZvaEmf2zmd3Qj58fx/8/WxqgomfbiXwCWHW8B8zsTjNba2Zra2pq+hFh8Hl+ezUd3SGunK9zF0QkPiI+XNXdPwhgZsOAM4D5hPcCfhftUGb2EaAUuPAEWe4D7gMoLS31aL9/Ilm1qYrivGEsmqCVVEUkPvp9HoO7twPre/7pjwPAhF73x/ds68PMLgW+DFzY815Jq7m9ixd2VHPT0omkpGgYSUTiI57HPq4BZpjZFDPLIDwstaL3E8xsEfBT4Bp3r45jtoT04o4a2rtCLNcSGCISR5EerpptZguP2TbRzCI+Ddfdu4C7gGeAbcAj7r7FzL5pZm9fBe47wHDgd2a2wcxWnODlksLKzZUUDs9gyeSRQUcRkSQS6VBSJ/B7M1vg7s092+4nvIDeu4aDTsTdVwIrj9n2tV63L430tYa61o5uXthezXWLxpGqYSQRiaNIz2PoBB4H3p6AnggUufvaGGZLai/uqKalo5sr55cEHUVEkkx/5hjuB27ruf0x4BfRjyNve3JTeBjp7CkaRhKR+OrP4arbLWwm4YnjC2IXK7m1dHTx/LZqrj9rvNZGEpG46++3zs8J7zlscvcjMcgjhE9qa+3s5qoFGkYSkfjrbzE8AiwkXBASI0++Wcno3GE6GklEAtGvE9x61jHSSm4x1NTrpDYdjSQiQdAAdoJ5btsh2rtCGkYSkcCoGBLMkxsrGZOXyVkTtTaSiARDxZBAGto6eWlHDVfOL9HaSCISmH4vomdmywivqrrZ3f8Y/UjJ6/lt4SW2NYwkIkE65R6Dmb3e6/YdwI+BXOCe412eUwbu6c1vL7E9IugoIpLEIhlKSu91+07gMnf/BvA+4OaYpEpCLR1dvLizmsvPGKNhJBEJVCRDSSlmVkC4RMzdawDcvdnMumKaLom8tKOGtk4tsS0iwYukGPKBdYABbmYl7l5pZsN7tkkUrNpcRUF2Okt1UpuIBCySYpjq7qHjbA8B1wGYmbn7kL7EZiy1d3Xz/PZqrppforWRRCRwkXwLPW9mf9+z1HZvXcAUM/slcEv0oyWPV3bX0tTexfL5GkYSkeBFssewHPg48FszmwocATKBVOCPwH+4+xuxizj0rdpURe6wNM6bNiroKCIipy4Gd28DfgL8xMzSgUKg1d3rYx0uGXR1h/jTtkNcMmc0w9JSg44jIhLReQy3mFmtmdURXnK7SaUQPav31FHf0qmjkUQkYUQyx/BV4DJgNrAf+FZMEyWZZ7ZUkZmewoUzRwcdRUQEiGyOoaHXHMJXzWx1LAMlk1DIeWZLFRfOLCIrQ8NIIpIYIimGEjO7E9gObKPvmdByGt6sqOdQQzuXn6FhJBFJHJEUwz3AfMLLX8wHhpvZSuBNYKO7/zaG+Ya0p7dUkZZiXDK7OOgoIiLviOSopPt63zez8YQLYgFwJaBiGAB3549bDnHutFHkZ2snTEQSR7+X3Xb3CqACWBX9OMljV3UTe2qb+cSyKUFHERHpQ+svBOTpzVWYwfvmahhJRBKLiiEgz2ypYvHEAkbnZQYdRUSkDxVDAMrrWthysIHLz9DegogkHhVDAJ7eXAWgw1RFJCGpGALw5KZK5o/LZ9KonKCjiIi8i4ohzsrrWnizvJ4r55cEHUVE5LhUDHG2anMlAFepGEQkQakY4uypjeFhpImjsoOOIiJyXCqGOCqva+HNiqNctUB7CyKSuOJaDGa23Mx2mNluM/vCcR5/j5mtN7MuM7s+ntniYeUmDSOJSOKLWzGYWSpwL3AFMBe4yczmHvO0/cCtwG/ilSueVm6qZMH4fCaM1DCSiCSueO4xLAV2u3uZu3cADwPX9n6Cu+91941AKI654uKdYSTtLYhIgotnMYwDynvdr+jZ1m9mdqeZrTWztTU1NVEJF2tvH42kw1RFJNENyslnd7/P3UvdvbSoqCjoOBF5enMV88blaRhJRBJePIvhADCh1/3xPduGvKqjbazfX89yLYEhIoNAPIthDTDDzKaYWQZwI7Aiju8fmD9uDa+NtHyeikFEEl/cisHdu4C7gGcIXzv6EXffYmbfNLNrAMxsiZlVADcAPzWzLfHKF0tPb65i+ujhTB+dG3QUEZFT6vcV3E6Hu68EVh6z7Wu9bq8hPMQ0ZNQ1d7B6Tx1/e+G0oKOIiERkUE4+DybPbjtEd8g1jCQig4aKIcae3lzFuBFZnDE2L+goIiIRUTHEUGNbJ3/eVcvyeWMws6DjiIhERMUQQy/sqKGjO6RhJBEZVFQMMfSHNw8yOncYiycWBB1FRCRiKoYYOdrSyYs7qrl64VhSUzSMJCKDh4ohRp7eUklnt3PtmWODjiIi0i8qhhh5YsNBphTmMH9cftBRRET6RcUQA4ca2vhL2WGuXjhWRyOJyKCjYoiBJzdW4g7XLNQwkogMPiqGGFix4QDzxuUxffTwoKOIiPSbiiHK9tQ282bFUe0tiMigpWKIsic2HMAMrlYxiMggpWKIolDI+d3aCs6bNoqS/Kyg44iIDIiKIYr+vLuWA/Wt3LhkYtBRREQGTMUQRf+9ppyC7HTed0Zx0FFERAZMxRAlh5va+ePWKv5q8XiGpaUGHUdEZMBUDFHy+BsH6Ox2PrRkQtBRREROi4ohCtyd376+n8UTRzCzWNd1FpHBTcUQBev2HeGtmmZNOovIkKBiiIKHVu8nJyOVqxaUBB1FROS0qRhOU+XRVv7w5kFuKJ1AzrC0oOOIiJw2FcNpevDVvYTc+cSyKUFHERGJChXDaWhq7+I3q/dzxbwSJozMDjqOiEhUqBhOwyNrymls6+L2C7S3ICJDh4phgLq6Qzzwyh5KJxWwaGJB0HFERKJGxTBAz2w5RMWRVm6/YGrQUUREokrFMADtXd18/9mdTB6VzWVztS6SiAwtOr5yAO594S12Vzfx4G1LSE3RNZ1FZGjRHkM/7ahq5D9f3M11i8Zx0azRQccREYk6FUM/dIeczz+2kdzMdL76/rlBxxERiQkVQz/84pU9bCiv556r5zIyJyPoOCIiMaFiiNCKNw/yrZXbuHROMdfoes4iMoSpGCKwalMl/+u/N1A6eSQ/vOlMzDThLCJDV1yLwcyWm9kOM9ttZl84zuPDzOy/ex5fbWaT45nvWKGQ88SGA/z9b9/gzAkjeODWJWRn6EAuERna4vYtZ2apwL3AZUAFsMbMVrj71l5P+wRwxN2nm9mNwLeBD8UrI4QvulPf0skTGw7wq9f2UVbTzJkTRvDgbUsYrtVTRSQJxPObbimw293LAMzsYeBaoHcxXAt8vef2o8CPzczc3aMdpiT1HSIAAAVcSURBVKm9iw/c+wpvv7QDjW1d1Ld00Nkd3nbmhBF8/0MLuXJ+ia7jLCJJI57FMA4o73W/Ajj7RM9x9y4zOwqMAmp7P8nM7gTuBJg4cWBXTUs1Y9bbl+HsmTLIy0yjIDuDguwMlk4ZycIJIwb02iIig9mgHBtx9/uA+wBKS0sHtDeRlZHKvTcvjmouEZGhIJ6TzweACb3uj+/ZdtznmFkakA8cjks6EREB4lsMa4AZZjbFzDKAG4EVxzxnBXBLz+3rgedjMb8gIiInFrehpJ45g7uAZ4BU4AF332Jm3wTWuvsK4OfAf5nZbqCOcHmIiEgcxXWOwd1XAiuP2fa1XrfbgBvimUlERPrSmc8iItKHikFERPpQMYiISB8qBhER6cMG+9GgZlYD7OvnjxVyzNnUSSAZPzMk5+dOxs8Myfm5T+czT3L3ouM9MOiLYSDMbK27lwadI56S8TNDcn7uZPzMkJyfO1afWUNJIiLSh4pBRET6SNZiuC/oAAFIxs8Myfm5k/EzQ3J+7ph85qScYxARkRNL1j0GERE5ARWDiIj0kVTFYGbLzWyHme02sy8EnScezGyCmb1gZlvNbIuZ3R10pngxs1Qze8PMngw6S7yY2Qgze9TMtpvZNjM7N+hMsWZm/6vn/+3NZvZbM8sMOlMsmNkDZlZtZpt7bRtpZn8ys109fxZE472SphjMLBW4F7gCmAvcZGZzg00VF13AP7r7XOAc4O+S5HMD3A1sCzpEnP0AeNrdZwMLGeKf38zGAZ8GSt19HuEl/Yfqcv0PAsuP2fYF4Dl3nwE813P/tCVNMQBLgd3uXubuHcDDwLUBZ4o5d6909/U9txsJf1GMCzZV7JnZeOAq4P6gs8SLmeUD7yF8XRPcvcPd64NNFRdpQFbPVR+zgYMB54kJd3+Z8HVqersW+GXP7V8CH4jGeyVTMYwDynvdryAJviB7M7PJwCJgdbBJ4uI/gH8CQkEHiaMpQA3wi54htPvNLCfoULHk7geA/wPsByqBo+7+x2BTxVWxu1f23K4CiqPxoslUDEnNzIYDjwH/4O4NQeeJJTN7P1Dt7uuCzhJnacBi4D/dfRHQTJSGFhJVz5j6tYRLcSyQY2YfCTZVMHougxyV8w+SqRgOABN63R/fs23IM7N0wqXwkLv/Pug8cXA+cI2Z7SU8ZPheM/t1sJHiogKocPe39wgfJVwUQ9mlwB53r3H3TuD3wHkBZ4qnQ2ZWAtDzZ3U0XjSZimENMMPMpphZBuEJqhUBZ4o5MzPCY87b3P17QeeJB3f/oruPd/fJhP87P+/uQ/63SHevAsrNbFbPpkuArQFGiof9wDlmlt3z//olDPEJ92OsAG7puX0L8EQ0XjSu13wOkrt3mdldwDOEj1x4wN23BBwrHs4HPgpsMrMNPdu+1HP9bRl6/h54qOeXnzLgtoDzxJS7rzazR4H1hI/Ae4MhujSGmf0WuAgoNLMK4B7g34BHzOwThC8/8MGovJeWxBARkd6SaShJREQioGIQEZE+VAwiItKHikFERPpQMYiISB8qBhER6UPFICIifagYRKLEzMaa2WM9C9htN7P39NzeYmYtZrbBzF4zM/29k4SmE9xEoqBnyed1wJfd/UkzywZS3b3RzJb2bB/yy7zL0JA0S2KIxNgHCK9H9SSAu7f0emwekAzLr8gQoV1akeg4E3jtBI/NBTaf4DGRhKNiEImOKuCMt++YWVGvx8b2PC4yKKgYRKLjQaC4Z6J5A3Bur8eeAX5uZhcGkkyknzT5LCIifWiPQURE+lAxiIhIHyoGERHpQ8UgIiJ9qBhERKQPFYOIiPShYhARkT7+Hyc3mB1Z4FIvAAAAAElFTkSuQmCC\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"plt.plot(taus,P)\n",
"plt.ylabel(r'$P(5< r_{\\rm decay} < 45)$')\n",
"plt.xlabel(r'$c \\tau$');"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "3.7.6 (Framework)",
"language": "python",
"name": "3.7.6-framework"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.7.6"
},
"toc-autonumbering": false,
"toc-showcode": false,
"toc-showmarkdowntxt": false,
"toc-showtags": false
},
"nbformat": 4,
"nbformat_minor": 4
}
@r4lv
Copy link
Author

r4lv commented May 24, 2020

Binder

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment