# An R Exercise
# Let's make a phase space distribution and explore its
# properties upon injection into the g-2 Storage Ring
# Use a uniform distribution in x and momentum, and a Gaussian
# distribution in y
rm(list=ls()) # clear any variables left over from last time...
Npar = 5000
x0 = runif(Npar, -9, 9) # alfa_x x + beta_x x'
Px0 = runif(Npar,-50,50)
y0 = rnorm(Npar,0,15)
Py0 = rnorm(Npar,0,15) # alfa_y y + beta_y y'
# offset the x coordinate by 77 mm (injection)
x0 = x0 + 77
plot(x0,Px0,asp=1,pch=".")
data:image/s3,"s3://crabby-images/d08f1/d08f14dd496bdf9be76b45343d9acb42c9bc2b3a" alt=""
plot(y0,Py0,asp=1,pch=".")
data:image/s3,"s3://crabby-images/5782f/5782f15aa35a694067516365a659fe255a67b4f7" alt=""
# Give each particle a momentum (dp/p)
del = runif(Npar,-0.006,0.006)
hist(del,breaks=25)
data:image/s3,"s3://crabby-images/11094/11094e570394dfed2f8a76bf96986831bdd6af3d" alt=""
# Rotate each particle horizontally about ITS closed orbit, to the kicker:
D = 8100 # dispersion [mm]
x = -Px0 + D*del
Px = -(x0 - D*del)
y = y0
Py = Py0
# Q: why this is the right thing to do?
plot(x,Px,xlim=c(-60,60),asp=1,pch=".")
data:image/s3,"s3://crabby-images/2fed0/2fed0bb67595eacfb27649c1da7ead3ee284fcaa" alt=""
# Kick the distribution onto the central orbit
Ak = 77
phik = 0
Px = Px + Ak*cos(phik)
x = x + Ak*sin(phik)
plot(x,Px,xlim=c(-60,60),asp=1,pch=".")
data:image/s3,"s3://crabby-images/76003/76003c0cf6dd34a12a9d496c93e328ee7918869c" alt=""
# Q: why does it have this shape?
# Make a data frame of our final particle data
df = data.frame(x,Px,y,Py,del)
# Look at the first few lines of the data frame...
head(df)
## x Px y Py del
## 1 -10.481481 -16.218133 -11.9642981 -19.362421 -0.0009076567
## 2 18.228174 -1.330378 0.1119496 9.174353 0.0009274216
## 3 4.230873 -22.741721 -10.8386293 -3.445242 -0.0025593979
## 4 -23.273731 -1.243135 -1.9065723 -8.571396 0.0002269044
## 5 15.724556 49.947384 14.2516737 0.273611 0.0055267592
## 6 -6.509867 31.055719 -4.8381024 4.462012 0.0041444486
# Let's add some color to the momentum
plot(y0,Py0,asp=1,pch=".",col=2+500*(del+0.006))
data:image/s3,"s3://crabby-images/0ccdc/0ccdc47c0d0f9df34fe8fa139e0c2d2a331350e1" alt=""
plot(x0,Px0,asp=1,pch=".",col=2+500*(del+0.006))
data:image/s3,"s3://crabby-images/6257b/6257bb3e020886065781abcc7d0a72b5c83effcd" alt=""
df$color = 2+500*(del+0.006)
plot(df$x,df$Px,xlim=c(-60,60),asp=1,pch=".",col=df$color)
data:image/s3,"s3://crabby-images/d9252/d9252431a920d3d37232d75b7ba36602431e9020" alt=""
# OK, now we can sort/subset this data
# Example: which particles in our distribution are currently
# inside a circular aperture of radius 45 mm?
rAp = 45
df2 = subset(df, subset= x^2 + y^2 < rAp^2 )
plot(df2$x,df2$y,xlim=c(-60,60),asp=1,pch=".",col=df2$color)
data:image/s3,"s3://crabby-images/71d73/71d732d68698aaba0615ecbdfd4dcb39e0d8bdf3" alt=""
plot(df2$x,df2$Px,xlim=c(-60,60),asp=1,pch=".",col=df2$color)
data:image/s3,"s3://crabby-images/97bc3/97bc3a94dde1ed14746f74b9646669cd4eed181c" alt=""
plot(df2$y,df2$Py,xlim=c(-60,60),asp=1,pch=".",col=df2$color)
data:image/s3,"s3://crabby-images/11bdc/11bdcc9030f838cc9cfacbe3700753aa6ed5448c" alt=""
# number of particles in the subset:
length(df2$x)
## [1] 3366
# Example: Suppose have a square aperture; which particles
# stay inside the aperture?
df3 = subset(df, subset =
D*abs(del) + sqrt((x-D*del)^2 + Px^2 ) < rAp &
sqrt(y^2 + Py^2) <rAp )
plot(df3$x,df3$y,xlim=c(-60,60),asp=1,pch=".",col=df3$color)
data:image/s3,"s3://crabby-images/8321c/8321c957770a8f2031dd512f5c2b8f85809afaf3" alt=""
hist(df3$del)
data:image/s3,"s3://crabby-images/4330b/4330bade0572f858cfef3f30b3d6b513837545fd" alt=""
# Q: why is this the correct subset?
# Q: create df4, for the case of a round aperture
# Q: compare the number of particles that survive each df above
# Q: compare the rms momentum spread for each f above
# also, make histograms of each momentum distribution
# Q: change the kicker amplitude (Ak) and phase (phik) and
# look at the resulting momentum distribution for the
# case of a circular aperture