Skip to content

Instantly share code, notes, and snippets.

@r4lv
Last active May 25, 2020 10:14
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save r4lv/904beb65641d0662d598acad9cc7464e to your computer and use it in GitHub Desktop.
Save r4lv/904beb65641d0662d598acad9cc7464e to your computer and use it in GitHub Desktop.
Sheet 3 - Class Demo (empty)
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": 3,
"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(\n",
" np.sqrt(s),\n",
" [Ap_Mass, photon_Mass]\n",
").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": 4,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"{'p_0': <tf.Tensor: shape=(1000000, 4), dtype=float64, numpy=\n",
" array([[-0.20166105, 0.44953769, -0.41993954, 2.10216568],\n",
" [-0.28557604, -0.04906947, -0.57891195, 2.10216568],\n",
" [-0.36529661, -0.50665934, 0.17016235, 2.10216568],\n",
" ...,\n",
" [-0.20418927, -0.35987075, 0.49789588, 2.10216568],\n",
" [-0.61410058, -0.17815279, 0.10120567, 2.10216568],\n",
" [-0.23312916, -0.59497121, 0.10373321, 2.10216568]])>,\n",
" 'p_1': <tf.Tensor: shape=(1000000, 4), dtype=float64, numpy=\n",
" array([[ 0.20166105, -0.44953769, 0.41993954, 0.64737974],\n",
" [ 0.28557604, 0.04906947, 0.57891195, 0.64737974],\n",
" [ 0.36529661, 0.50665934, -0.17016235, 0.64737974],\n",
" ...,\n",
" [ 0.20418927, 0.35987075, -0.49789588, 0.64737974],\n",
" [ 0.61410058, 0.17815279, -0.10120567, 0.64737974],\n",
" [ 0.23312916, 0.59497121, -0.10373321, 0.64737974]])>}"
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"particles"
]
},
{
"cell_type": "code",
"execution_count": 5,
"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": 6,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(1000000, 4)"
]
},
"execution_count": 6,
"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": 7,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[-0.20166105, 0.44953769, -0.41993954, 2.10216568],\n",
" [-0.28557604, -0.04906947, -0.57891195, 2.10216568],\n",
" [-0.36529661, -0.50665934, 0.17016235, 2.10216568],\n",
" ...,\n",
" [-0.20418927, -0.35987075, 0.49789588, 2.10216568],\n",
" [-0.61410058, -0.17815279, 0.10120567, 2.10216568],\n",
" [-0.23312916, -0.59497121, 0.10373321, 2.10216568]])"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"p_Ap"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[ 0.20166105, -0.44953769, 0.41993954, 0.64737974],\n",
" [ 0.28557604, 0.04906947, 0.57891195, 0.64737974],\n",
" [ 0.36529661, 0.50665934, -0.17016235, 0.64737974],\n",
" ...,\n",
" [ 0.20418927, 0.35987075, -0.49789588, 0.64737974],\n",
" [ 0.61410058, 0.17815279, -0.10120567, 0.64737974],\n",
" [ 0.23312916, 0.59497121, -0.10373321, 0.64737974]])"
]
},
"execution_count": 8,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"p_gamma"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### &rarr; 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": 27,
"metadata": {},
"outputs": [],
"source": [
"# 3 momentum\n",
"pvec_Ap = p_Ap[: , :3]"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(1000000, 3)"
]
},
"execution_count": 28,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"pvec_Ap.shape"
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[-0.20166105, 0.44953769, -0.41993954],\n",
" [-0.28557604, -0.04906947, -0.57891195],\n",
" [-0.36529661, -0.50665934, 0.17016235],\n",
" ...,\n",
" [-0.20418927, -0.35987075, 0.49789588],\n",
" [-0.61410058, -0.17815279, 0.10120567],\n",
" [-0.23312916, -0.59497121, 0.10373321]])"
]
},
"execution_count": 29,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"pvec_Ap"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {},
"outputs": [],
"source": [
"E_Ap = p_Ap[: , 2]"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([2.10216568, 2.10216568, 2.10216568, ..., 2.10216568, 2.10216568,\n",
" 2.10216568])"
]
},
"execution_count": 33,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"E_Ap"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### &rarr; How would you compute the momentum magnitude?\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": 34,
"metadata": {},
"outputs": [],
"source": [
"# Compute your momentum magnitude here\n",
"P_Ap = ..."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<br><br><br><br><br><br><br><br><br><br><br><br><br><br>"
]
},
{
"cell_type": "code",
"execution_count": 35,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([0.64737974, 0.64737974, 0.64737974, ..., 0.64737974, 0.64737974,\n",
" 0.64737974])"
]
},
"execution_count": 35,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"P_Ap"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### &rarr; Compute the invariant mass using E_Ap and P_Ap"
]
},
{
"cell_type": "code",
"execution_count": 36,
"metadata": {},
"outputs": [],
"source": [
"# Compute here the invariant mass using E_Ap and P_Ap\n",
"M_Ap = ..."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<br><br><br><br><br><br><br><br><br><br><br><br><br><br>"
]
},
{
"cell_type": "code",
"execution_count": 37,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([2., 2., 2., ..., 2., 2., 2.])"
]
},
"execution_count": 37,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"M_Ap"
]
},
{
"cell_type": "code",
"execution_count": 38,
"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": "markdown",
"metadata": {},
"source": [
"### &rarr; Compute phi using np.arctan() of the relevant momenta\n",
"\n",
"### &rarr; Compute theta using np.arctan"
]
},
{
"cell_type": "code",
"execution_count": 56,
"metadata": {},
"outputs": [],
"source": [
"# Compute phi using np.arctan() of the relevant momenta\n",
"phi_Ap = ..."
]
},
{
"cell_type": "code",
"execution_count": 57,
"metadata": {},
"outputs": [],
"source": [
"# Compute theta using np.arctan\n",
"theta_Ap = ..."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<br><br><br><br><br><br><br><br><br><br><br><br><br><br>"
]
},
{
"cell_type": "code",
"execution_count": 59,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([-0.84278099, 0.453094 , -0.34763959, ..., -0.13313967,\n",
" 0.44634645, 1.17749926])"
]
},
"execution_count": 59,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"phi_Ap"
]
},
{
"cell_type": "code",
"execution_count": 60,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([-1.41185037, -1.28066406, 1.46044395, ..., 1.00415133,\n",
" -0.5524766 , 1.55378453])"
]
},
"execution_count": 60,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"theta_Ap"
]
},
{
"cell_type": "code",
"execution_count": 45,
"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": 46,
"metadata": {},
"outputs": [],
"source": [
"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": 47,
"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 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": 48,
"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": 49,
"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()"
]
},
{
"cell_type": "code",
"execution_count": 50,
"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": 51,
"metadata": {},
"outputs": [],
"source": [
"# Now boost into the lab frame\n",
"pz_Ap_lab = gamma * (pz_Ap - beta *E_Ap)"
]
},
{
"cell_type": "code",
"execution_count": 52,
"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": 53,
"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": 54,
"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": 55,
"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": [
"### &rarr; What is the probability that the particle has a $\\theta_{\\rm}$ within the long baseline detectors acceptance ($0 < \\theta_{\\rm lab} < 15^{\\circ}$)?"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"probab = ..."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<br><br><br><br><br><br><br><br><br><br><br><br><br><br>"
]
},
{
"cell_type": "code",
"execution_count": 62,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.419725"
]
},
"execution_count": 62,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"probab"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Now repeat this for a different mass hypthesis of the $A'$. Try to repeat this calculation for $M_{A'} = 1.4$ and $M_{A'} = 1.2$"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<br><br><br><br><br><br><br><br><br><br><br><br><br><br>"
]
},
{
"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": 63,
"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": 64,
"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": 65,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.418797"
]
},
"execution_count": 65,
"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": 66,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"5.0931424906417035\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": 67,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.6572945842496484\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": 68,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.275273\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": 69,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.6735124654665625\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": 70,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.282065\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": 71,
"metadata": {},
"outputs": [],
"source": [
"taus = np.linspace(0.1, 10, 100)"
]
},
{
"cell_type": "code",
"execution_count": 72,
"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": 73,
"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": [
"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": {
"base_numbering": 1,
"nav_menu": {},
"number_sections": false,
"sideBar": true,
"skip_h1_title": true,
"title_cell": "Table of Contents",
"title_sidebar": "Contents",
"toc_cell": false,
"toc_position": {},
"toc_section_display": true,
"toc_window_display": true
},
"toc-autonumbering": false,
"toc-showcode": false,
"toc-showmarkdowntxt": false,
"toc-showtags": false
},
"nbformat": 4,
"nbformat_minor": 4
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment