Skip to content
Snippets Groups Projects
Commit e5d98ee0 authored by Watanyu Foosang's avatar Watanyu Foosang Committed by Gamelin Alexis
Browse files

Improvements on plot_phasespacedata function

- total_size and save_every input parameters have been removed.
- only_alive option function has been changed
- Some small corrections on scaling of delta, bunch_charge, bunch_current
parent e7580d69
No related branches found
No related tags found
No related merge requests found
...@@ -336,8 +336,8 @@ class Bunch: ...@@ -336,8 +336,8 @@ class Bunch:
Can be modified to "sc" for a scatter plot. Can be modified to "sc" for a scatter plot.
""" """
label_dict = {"x":"x (mm)", "xp":"x' (mrad)", "y":"y (mm)", "yp":"y' (mrad)", label_dict = {"x":"x (mm)", "xp":"x' (mrad)", "y":"y (mm)",
"tau":"$\\tau$ (ps)", "delta":"$\\delta$"} "yp":"y' (mrad)","tau":"$\\tau$ (ps)", "delta":"$\\delta$"}
scale = {"x": 1e3, "xp":1e3, "y":1e3, "yp":1e3, "tau":1e12, "delta":1} scale = {"x": 1e3, "xp":1e3, "y":1e3, "yp":1e3, "tau":1e12, "delta":1}
if plot_type == "sc": if plot_type == "sc":
...@@ -346,11 +346,13 @@ class Bunch: ...@@ -346,11 +346,13 @@ class Bunch:
plt.xlabel(label_dict[x_var]) plt.xlabel(label_dict[x_var])
plt.ylabel(label_dict[y_var]) plt.ylabel(label_dict[y_var])
else: elif plot_type == "j":
sns.jointplot(self.particles[x_var]*scale[x_var], sns.jointplot(self.particles[x_var]*scale[x_var],
self.particles[y_var]*scale[y_var],kind="kde") self.particles[y_var]*scale[y_var],kind="kde")
plt.xlabel(label_dict[x_var]) plt.xlabel(label_dict[x_var])
plt.ylabel(label_dict[y_var]) plt.ylabel(label_dict[y_var])
else: raise ValueError("Plot type not recognised")
class Beam: class Beam:
""" """
...@@ -614,11 +616,14 @@ class Beam: ...@@ -614,11 +616,14 @@ class Beam:
Parameters Parameters
---------- ----------
var : str {"bunch_currebt", "bunch_charge", "bunch_particle", "bunch_mean", "bunch_std", "bunch_emit"} var : str {"bunch_currebt", "bunch_charge", "bunch_particle",
"bunch_mean", "bunch_std", "bunch_emit"}
Variable to be plotted. Variable to be plotted.
option : str, optional option : str, optional
If var is "bunch_mean", "bunch_std", or "bunch_emit, option needs tobe specified. If var is "bunch_mean", "bunch_std", or "bunch_emit, option needs
For "bunch_mean" and "bunch_std", option = {"x","xp","y","yp","tau","delta"}. to be specified.
For "bunch_mean" and "bunch_std",
option = {"x","xp","y","yp","tau","delta"}.
For "bunch_emit", option = {"x","y","s"}. For "bunch_emit", option = {"x","y","s"}.
The default is None. The default is None.
...@@ -633,12 +638,12 @@ class Beam: ...@@ -633,12 +638,12 @@ class Beam:
if var == "bunch_mean" or var == "bunch_std": if var == "bunch_mean" or var == "bunch_std":
value_dict = {"x":0, "xp":1, "y":2, "yp":3, "tau":4, "delta":5} value_dict = {"x":0, "xp":1, "y":2, "yp":3, "tau":4, "delta":5}
scale = [1e6, 1e6, 1e6, 1e6, 1e12, 1e6] scale = [1e6, 1e6, 1e6, 1e6, 1e12, 1]
label_mean = ["x (um)", "x' ($\\mu$rad)", "y (um)", "y' ($\\mu$rad)", label_mean = ["x (um)", "x' ($\\mu$rad)", "y (um)", "y' ($\\mu$rad)",
"$\\tau$ (ps)", "$\\delta(\\times 10^{-6})$"] "$\\tau$ (ps)", "$\\delta$"]
label_std = ["std x (um)", "std x' ($\\mu$rad)", "std y (um)", label_std = ["std x (um)", "std x' ($\\mu$rad)", "std y (um)",
"std y' ($\\mu$rad)", "std $\\tau$ (ps)", "std y' ($\\mu$rad)", "std $\\tau$ (ps)",
"std $\\delta(\\times 10^{-6})$"] "std $\\delta$"]
y_axis = var_dict[var][value_dict[option]] y_axis = var_dict[var][value_dict[option]]
...@@ -674,12 +679,16 @@ class Beam: ...@@ -674,12 +679,16 @@ class Beam:
plt.xlabel('bunch number') plt.xlabel('bunch number')
plt.ylabel(label_y) plt.ylabel(label_y)
elif var == "bunch_current" or var == "bunch_charge" or var =="bunch_particle": elif var=="bunch_current" or var=="bunch_charge" or var=="bunch_particle":
plt.plot(np.arange(len(self.filling_pattern)), var_dict[var]) scale = {"bunch_current":1e3, "bunch_charge":1e9,
"bunch_particle":1}
plt.plot(np.arange(len(self.filling_pattern)), var_dict[var]*
scale[var])
plt.xlabel('bunch number') plt.xlabel('bunch number')
if var == "bunch_current": label_y = "bunch current (A)" if var == "bunch_current": label_y = "bunch current (mA)"
elif var == "bunch_charge": label_y = "bunch chagre (C)" elif var == "bunch_charge": label_y = "bunch chagre (nC)"
else: label_y = "number of particles" else: label_y = "number of particles"
plt.ylabel(label_y) plt.ylabel(label_y)
......
...@@ -68,9 +68,9 @@ def plot_bunchdata(filename, bunch_number, dataset, option=None, x_var="time"): ...@@ -68,9 +68,9 @@ def plot_bunchdata(filename, bunch_number, dataset, option=None, x_var="time"):
# delta -> 5 # delta -> 5
var_dict = {"x":0, "xp":1, "y":2, "yp":3, "tau":4, "delta":5} var_dict = {"x":0, "xp":1, "y":2, "yp":3, "tau":4, "delta":5}
scale = [1e6, 1e6, 1e6, 1e6, 1e12, 1e6] scale = [1e6, 1e6, 1e6, 1e6, 1e12, 1]
label_list = ["x (um)", "x' ($\\mu$rad)", "y (um)", "y' ($\\mu$rad)", label_list = ["x (um)", "x' ($\\mu$rad)", "y (um)", "y' ($\\mu$rad)",
"$\\tau$ (ps)", "$\\delta(\\times 10^{-6})$"] "$\\tau$ (ps)", "$\\delta$"]
y_var = file[group][dataset][var_dict[option]]*scale[var_dict[option]] y_var = file[group][dataset][var_dict[option]]*scale[var_dict[option]]
label = label_list[var_dict[option]] label = label_list[var_dict[option]]
...@@ -82,8 +82,8 @@ def plot_bunchdata(filename, bunch_number, dataset, option=None, x_var="time"): ...@@ -82,8 +82,8 @@ def plot_bunchdata(filename, bunch_number, dataset, option=None, x_var="time"):
file.close() file.close()
def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset, def plot_phasespacedata(filename, bunch_number, dataset, x_var=None,
x_var=None, y_var=None, turn=None, only_alive=False): y_var=None, turn=None, only_alive=True):
""" """
Plot data from PhaseSpaceData_0 group of the HDF5 file. Plot data from PhaseSpaceData_0 group of the HDF5 file.
...@@ -94,10 +94,6 @@ def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset, ...@@ -94,10 +94,6 @@ def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset,
bunch_number : int bunch_number : int
Number of the bunch whose data has been saved in the HDF5 file. Number of the bunch whose data has been saved in the HDF5 file.
This has to be identical to 'bunch_number' parameter in 'PhaseSpaceMonitor' object. This has to be identical to 'bunch_number' parameter in 'PhaseSpaceMonitor' object.
total_size : int
Total size of the save regarding to 'PhaseSpaceMonitor' object.
save_every : int
Frequency of the save regarding to 'PhaseSpaceMonitor' object.
dataset : str {'alive', 'partcicles'} dataset : str {'alive', 'partcicles'}
HDF5 file's dataset to be plotted. HDF5 file's dataset to be plotted.
x_var, y_var : str {"x", "xp", "y", "yp", "tau", "delta"}, optional x_var, y_var : str {"x", "xp", "y", "yp", "tau", "delta"}, optional
...@@ -114,15 +110,12 @@ def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset, ...@@ -114,15 +110,12 @@ def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset,
group = "PhaseSpaceData_{0}".format(bunch_number) group = "PhaseSpaceData_{0}".format(bunch_number)
data_points = int(total_size/save_every)
timelist = file[group]["time"][0:data_points] # example output: [0,10,20,30,40]
if dataset == "alive": if dataset == "alive":
alive_at_a_time = [] alive_at_a_time = []
for i in range (data_points): for i in range (len(file[group]["time"])):
alive_at_a_time.append(np.sum(file[group][dataset][:,i])) alive_at_a_time.append(np.sum(file[group][dataset][:,i]))
plt.plot(timelist,alive_at_a_time) plt.plot(file[group]["time"],alive_at_a_time)
plt.xlabel("number of turns") plt.xlabel("number of turns")
plt.ylabel("number of alive particles") plt.ylabel("number of alive particles")
...@@ -136,36 +129,38 @@ def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset, ...@@ -136,36 +129,38 @@ def plot_phasespacedata(filename, bunch_number, total_size, save_every, dataset,
# delta -> 5 # delta -> 5
var_dict = {"x":0, "xp":1, "y":2, "yp":3, "tau":4, "delta":5} var_dict = {"x":0, "xp":1, "y":2, "yp":3, "tau":4, "delta":5}
scale = [1e3,1e3,1e3,1e3,1e12,1e3] scale = [1e3,1e3,1e3,1e3,1e12,1]
label = ["x (mm)","x' (mrad)","y (mm)","y' (mrad)","$\\tau$ (ps)","$\\delta \\times 10^{-3}$"] label = ["x (mm)","x' (mrad)","y (mm)","y' (mrad)","$\\tau$ (ps)",
"$\\delta$"]
# find the index of "turn" in timelist # find the index of "turn" in time array
index_in_timelist = np.where(timelist==turn) turn_index = np.where(file["PhaseSpaceData_0"]["time"][:]==turn)
if len(turn_index[0]) == 0:
raise ValueError("Turn {0} is not found. Enter turn from {1}.".
format(turn, file[group]["time"][:]))
else : pass
path = file[group][dataset] path = file[group][dataset]
if only_alive == False: if only_alive is False:
# format : sns.jointplot(x_axis, yaxis, kind) # format : sns.jointplot(x_axis, yaxis, kind)
x_axis = path[:,var_dict[x_var],index_in_timelist] x_axis = path[:,var_dict[x_var],turn_index[0][0]]
y_axis = path[:,var_dict[y_var],index_in_timelist] y_axis = path[:,var_dict[y_var],turn_index[0][0]]
elif only_alive is True:
alive_index = np.where(file[group]["alive"][:,turn_index])
elif only_alive == True: x_axis = path[alive_index[0],var_dict[x_var],turn_index[0][0]]
x_alive = [] y_axis = path[alive_index[0],var_dict[y_var],turn_index[0][0]]
y_alive = []
for i in path[:,var_dict[x_var],index_in_timelist]:
if bool(i) == True:
x_alive.append(i)
else: pass
for i in path[:,var_dict[y_var],index_in_timelist]:
if bool(i) == True:
y_alive.append(i)
else: pass
x_axis = np.array(x_alive)
y_axis = np.array(y_alive)
sns.jointplot(x_axis*scale[var_dict[x_var]], y_axis*scale[var_dict[y_var]], sns.jointplot(x_axis*scale[var_dict[x_var]],
kind="kde") y_axis*scale[var_dict[y_var]], kind="kde")
plt.xlabel(label[var_dict[x_var]]) plt.xlabel(label[var_dict[x_var]])
plt.ylabel(label[var_dict[y_var]]) plt.ylabel(label[var_dict[y_var]])
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment