Corrected how the effective trap depth is calculated, minor changes to code for plotting of the potentials.

This commit is contained in:
Karthik 2023-03-02 10:08:30 +01:00
parent 69ba21b1e6
commit 4714556ab4

View File

@ -407,10 +407,13 @@ def computeTrapPotential(w_x, w_z, Power, Polarizability, options):
TrappingPotential = IdealTrappingPotential TrappingPotential = IdealTrappingPotential
if not crossed: if not crossed:
infls = np.where(np.diff(np.sign(np.gradient(np.gradient(TrappingPotential[axis].value)))))[0]
if TrappingPotential[axis][0] > TrappingPotential[axis][-1]: if TrappingPotential[axis][0] > TrappingPotential[axis][-1]:
EffectiveTrapDepthInKelvin = TrappingPotential[axis][-1] - min(TrappingPotential[axis]) EffectiveTrapDepthInKelvin = max(TrappingPotential[axis][infls[1]:-1]) - min(TrappingPotential[axis][infls[0]:infls[1]])
elif TrappingPotential[axis][0] < TrappingPotential[axis][-1]: elif TrappingPotential[axis][0] < TrappingPotential[axis][-1]:
EffectiveTrapDepthInKelvin = TrappingPotential[axis][0] - min(TrappingPotential[axis]) EffectiveTrapDepthInKelvin = max(TrappingPotential[axis][0:infls[0]]) - min(TrappingPotential[axis][infls[0]:infls[1]])
else: else:
EffectiveTrapDepthInKelvin = IdealTrapDepthInKelvin EffectiveTrapDepthInKelvin = IdealTrapDepthInKelvin
@ -422,11 +425,24 @@ def computeTrapPotential(w_x, w_z, Power, Polarizability, options):
CalculatedTrapFrequencies = [v_x, v_y, v_z] CalculatedTrapFrequencies = [v_x, v_y, v_z]
v, dv, popt, pcov = extractTrapFrequency(Positions, IdealTrappingPotential, axis) v, dv, popt, pcov = extractTrapFrequency(Positions, IdealTrappingPotential, axis)
IdealTrapFrequency = [v, dv] if np.isinf(v):
v, dv, popt, pcov = extractTrapFrequency(Positions, TrappingPotential, axis) v = np.nan
TrapFrequency = [v, dv] if np.isinf(dv):
ExtractedTrapFrequencies = [IdealTrapFrequency, TrapFrequency] dv = np.nan
IdealTrapFrequency = [v, dv]
if options['extract_trap_frequencies']:
v, dv, popt, pcov = extractTrapFrequency(Positions, TrappingPotential, axis)
if np.isinf(v):
v = np.nan
if np.isinf(dv):
dv = np.nan
TrapFrequency = [v, dv]
ExtractedTrapFrequencies = [IdealTrapFrequency, TrapFrequency]
else:
ExtractedTrapFrequencies = [IdealTrapFrequency]
return Positions, IdealTrappingPotential, TrappingPotential, TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies return Positions, IdealTrappingPotential, TrappingPotential, TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies
else: else:
@ -582,7 +598,9 @@ def plotGaussianFit(Positions, TrappingPotential, popt, pcov):
plt.tight_layout() plt.tight_layout()
plt.show() plt.show()
def plotPotential(Positions, ComputedPotentials, axis, Params = [], listToIterateOver = [], save = False): def plotPotential(Positions, ComputedPotentials, options, Params = [], listToIterateOver = [], save = False):
axis = options['axis']
plt.figure(figsize=(9, 7)) plt.figure(figsize=(9, 7))
for i in range(np.size(ComputedPotentials, 0)): for i in range(np.size(ComputedPotentials, 0)):
@ -598,8 +616,12 @@ def plotPotential(Positions, ComputedPotentials, axis, Params = [], listToIterat
idealv = Params[j][2][0][0] idealv = Params[j][2][0][0]
idealdv = Params[j][2][0][1] idealdv = Params[j][2][0][1]
v = Params[j][2][1][0] if options['extract_trap_frequencies']:
dv = Params[j][2][1][1] v = Params[j][2][1][0]
dv = Params[j][2][1][1]
else:
v = np.nan
dv = np.nan
if listToIterateOver: if listToIterateOver:
if np.size(ComputedPotentials, 0) == len(listToIterateOver): if np.size(ComputedPotentials, 0) == len(listToIterateOver):
@ -608,7 +630,7 @@ def plotPotential(Positions, ComputedPotentials, axis, Params = [], listToIterat
if i % 2 == 0: if i % 2 == 0:
plt.plot(Positions[axis], ComputedPotentials[i][axis], '--', label = 'Trap Depth = ' + str(round(IdealTrapDepthInKelvin.value, 2)) + ' ' + str(IdealTrapDepthInKelvin.unit) + '; ' + generate_label(idealv, idealdv)) plt.plot(Positions[axis], ComputedPotentials[i][axis], '--', label = 'Trap Depth = ' + str(round(IdealTrapDepthInKelvin.value, 2)) + ' ' + str(IdealTrapDepthInKelvin.unit) + '; ' + generate_label(idealv, idealdv))
elif i % 2 != 0: elif i % 2 != 0:
plt.plot(Positions[axis], ComputedPotentials[i][axis], label = 'Effective Trap Depth = ' + str(round(EffectiveTrapDepthInKelvin.value, 2)) + ' ' + str(EffectiveTrapDepthInKelvin.unit) + '; ' + generate_label(v, dv)) plt.plot(Positions[axis], ComputedPotentials[i][axis], label = 'Effective Trap Depth = ' + str(round(EffectiveTrapDepthInKelvin.value, 2)) + ' ' + str(EffectiveTrapDepthInKelvin.unit) + '; ' + generate_label(v, dv))
else: else:
if i % 2 == 0: if i % 2 == 0:
plt.plot(Positions[axis], ComputedPotentials[i][axis], '--', label = 'Trap Depth = ' + str(round(IdealTrapDepthInKelvin.value, 2)) + ' ' + str(IdealTrapDepthInKelvin.unit) + '; ' + generate_label(idealv, idealdv)) plt.plot(Positions[axis], ComputedPotentials[i][axis], '--', label = 'Trap Depth = ' + str(round(IdealTrapDepthInKelvin.value, 2)) + ' ' + str(IdealTrapDepthInKelvin.unit) + '; ' + generate_label(idealv, idealdv))
@ -874,41 +896,43 @@ def plotCollisionRatesAndPSD(Gamma_elastic, PSD, modulation_depth, new_aspect_ra
if __name__ == '__main__': if __name__ == '__main__':
# Power = 40*u.W Power = 0.420*u.W
# Polarizability = 184.4 # in a.u, most precise measured value of Dy polarizability Polarizability = 184.4 # in a.u, most precise measured value of Dy polarizability
# Wavelength = 1.064*u.um Wavelength = 1.064*u.um
# w_x, w_z = 27.5*u.um, 33.8*u.um # Beam Waists in the x and y directions w_x, w_z = 30*u.um, 30*u.um # Beam Waists in the x and y directions
# Power = 11*u.W # Power = 11*u.W
# Polarizability = 184.4 # in a.u, most precise measured value of Dy polarizability # Polarizability = 184.4 # in a.u, most precise measured value of Dy polarizability
# w_x, w_z = 54.0*u.um, 54.0*u.um # Beam Waists in the x and y directions # w_x, w_z = 54.0*u.um, 54.0*u.um # Beam Waists in the x and y directions
"""
options = { options = {
'axis': 2, # axis referenced to the beam along which you want the dipole trap potential 'axis': 1, # axis referenced to the beam along which you want the dipole trap potential
'extent': 3e2, # range of spatial coordinates in one direction to calculate trap potential over 'extent': 1e4, # range of spatial coordinates in one direction to calculate trap potential over
'crossed': False, 'crossed': False,
'theta': 0, 'delta': 70, # angle between arms in degrees
'modulation': True, 'modulation': False,
'aspect_ratio': 1, 'aspect_ratio': 4, # required aspect ratio of modulated arm
'gravity': True, 'gravity': True,
'tilt_gravity': True, 'tilt_gravity': True,
'theta': 0.5, # in degrees 'theta': 0.1, # gravity tilt angle in degrees
'tilt_axis': [1, 0, 0], # lab space coordinates are rotated about x-axis in reference frame of beam 'tilt_axis': [1, 0, 0], # lab space coordinates are rotated about x-axis in reference frame of beam
'astigmatism': True, 'astigmatism': False,
'disp_foci': 0.9 * z_R(w_0 = np.asarray([30]), lamb = 1.064)[0]*u.um # difference in position of the foci along the propagation direction (Astigmatism) 'disp_foci': 0.9 * z_R(w_0 = np.asarray([30]), lamb = 1.064)[0]*u.um, # difference in position of the foci along the propagation direction (Astigmatism)
'extract_trap_frequencies': True
} }
"""
"""Plot ideal trap potential resulting for given parameters only""" # """Plot ideal trap potential resulting for given parameters only"""
# ComputedPotentials = []
# Params = [] ComputedPotentials = []
Params = []
# Positions, IdealTrappingPotential, TrappingPotential, TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies = computeTrapPotential(w_x, w_z, Power, Polarizability, options) Positions, IdealTrappingPotential, TrappingPotential, TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies = computeTrapPotential(w_x, w_z, Power, Polarizability, options)
# ComputedPotentials.append(IdealTrappingPotential) ComputedPotentials.append(IdealTrappingPotential)
# ComputedPotentials.append(TrappingPotential) ComputedPotentials.append(TrappingPotential)
# Params.append([TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies]) Params.append([TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies])
# ComputedPotentials = np.asarray(ComputedPotentials) ComputedPotentials = np.asarray(ComputedPotentials)
# plotPotential(Positions, ComputedPotentials, options['axis'], Params) plotPotential(Positions, ComputedPotentials, options, Params)
"""Plot harmonic fit for trap potential resulting for given parameters only""" """Plot harmonic fit for trap potential resulting for given parameters only"""
# v, dv, popt, pcov = extractTrapFrequency(Positions, TrappingPotential, options['axis']) # v, dv, popt, pcov = extractTrapFrequency(Positions, TrappingPotential, options['axis'])
@ -925,7 +949,7 @@ if __name__ == '__main__':
# Params.append([TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies]) # Params.append([TrapDepthsInKelvin, CalculatedTrapFrequencies, ExtractedTrapFrequencies])
# ComputedPotentials = np.asarray(ComputedPotentials) # ComputedPotentials = np.asarray(ComputedPotentials)
# plotPotential(Positions, ComputedPotentials, options['axis'], Params) # plotPotential(Positions, ComputedPotentials, options, Params)
"""Plot transverse intensity profile and trap potential resulting for given parameters only""" """Plot transverse intensity profile and trap potential resulting for given parameters only"""
# options = { # options = {
@ -1058,85 +1082,85 @@ if __name__ == '__main__':
# plt.show() # plt.show()
""" Investigate deviation in alpha""" """ Investigate deviation in alpha"""
Power = 40*u.W
Polarizability = 184.4 # in a.u, most precise measured value of Dy polarizability
Wavelength = 1.064*u.um
w_x, w_z = 27.5*u.um, 33.8*u.um
options = {
'axis': 0, # axis referenced to the beam along which you want the dipole trap potential
'extent': 3e2, # range of spatial coordinates in one direction to calculate trap potential over
'crossed': False,
'theta': 0,
'modulation': False,
'gravity': True,
'tilt_gravity': True,
'theta': 10, # in degrees
'tilt_axis': [1, 0, 0], # lab space coordinates are rotated about x-axis in reference frame of beam
'astigmatism': True,
'disp_foci': 0.9 * z_R(w_0 = np.asarray([30]), lamb = 1.064)[0]*u.um # difference in position of the foci along the propagation direction (Astigmatism)
}
modulation_depth = np.arange(0, 1.1, 0.1) # Power = 40*u.W
Alphas, fin_mod_dep, meas_alpha_x, meas_alpha_z, dalpha_x, dalpha_z = convert_modulation_depth_to_alpha(modulation_depth) # Polarizability = 184.4 # in a.u, most precise measured value of Dy polarizability
meas_alpha_deviation = [(g - h) for g, h in zip(meas_alpha_x, meas_alpha_z)] # Wavelength = 1.064*u.um
sorted_fin_mod_dep, sorted_meas_alpha_deviation = zip(*sorted(zip(fin_mod_dep, meas_alpha_deviation))) # w_x, w_z = 27.5*u.um, 33.8*u.um
avg_alpha = [(g + h) / 2 for g, h in zip(meas_alpha_x, meas_alpha_z)]
sorted_fin_mod_dep, new_aspect_ratio = zip(*sorted(zip(fin_mod_dep, (w_x * avg_alpha) / w_z)))
current_ar = w_x/w_z # options = {
aspect_ratio = np.arange(current_ar, 10*current_ar, 0.8) # 'axis': 0, # axis referenced to the beam along which you want the dipole trap potential
w_x = w_x * (aspect_ratio / current_ar) # 'extent': 3e2, # range of spatial coordinates in one direction to calculate trap potential over
# 'crossed': False,
# 'theta': 0,
# 'modulation': False,
# 'gravity': True,
# 'tilt_gravity': True,
# 'theta': 10, # in degrees
# 'tilt_axis': [1, 0, 0], # lab space coordinates are rotated about x-axis in reference frame of beam
# 'astigmatism': True,
# 'disp_foci': 0.9 * z_R(w_0 = np.asarray([30]), lamb = 1.064)[0]*u.um # difference in position of the foci along the propagation direction (Astigmatism)
# }
# modulation_depth = np.arange(0, 1.1, 0.1)
# Alphas, fin_mod_dep, meas_alpha_x, meas_alpha_z, dalpha_x, dalpha_z = convert_modulation_depth_to_alpha(modulation_depth)
# meas_alpha_deviation = [(g - h) for g, h in zip(meas_alpha_x, meas_alpha_z)]
# sorted_fin_mod_dep, sorted_meas_alpha_deviation = zip(*sorted(zip(fin_mod_dep, meas_alpha_deviation)))
# avg_alpha = [(g + h) / 2 for g, h in zip(meas_alpha_x, meas_alpha_z)]
# sorted_fin_mod_dep, new_aspect_ratio = zip(*sorted(zip(fin_mod_dep, (w_x * avg_alpha) / w_z)))
v_x = np.zeros(len(w_x)) # current_ar = w_x/w_z
#v_y = np.zeros(len(w_x)) # aspect_ratio = np.arange(current_ar, 10*current_ar, 0.8)
v_z = np.zeros(len(w_x)) # w_x = w_x * (aspect_ratio / current_ar)
for i in range(len(w_x)): # v_x = np.zeros(len(w_x))
options['axis'] = 0 # #v_y = np.zeros(len(w_x))
ExtractedTrapFrequencies = computeTrapPotential(w_x[i], w_z, Power, Polarizability, options)[5] # v_z = np.zeros(len(w_x))
tmp = ExtractedTrapFrequencies[1][0]
v_x[i] = tmp if not np.isinf(tmp) else np.nan
#options['axis'] = 1
#ExtractedTrapFrequencies = computeTrapPotential(w_x[i], w_z, Power, Polarizability, options)[5]
#tmp = ExtractedTrapFrequencies[1][0]
#v_y[i] = tmp if not np.isinf(tmp) else np.nan
options['axis'] = 2
ExtractedTrapFrequencies = computeTrapPotential(w_x[i], w_z, Power, Polarizability, options)[5]
tmp = ExtractedTrapFrequencies[1][0]
v_z[i] = tmp if not np.isinf(tmp) else np.nan
#v_x[i] = calculateTrapFrequency(w_x[i], w_z, Power, Polarizability, dir = 'x').value # for i in range(len(w_x)):
#v_y[i] = calculateTrapFrequency(w_x[i], w_z, Power, Polarizability, dir = 'y').value # options['axis'] = 0
#v_z[i] = calculateTrapFrequency(w_x[i], w_z, Power, Polarizability, dir = 'z').value # ExtractedTrapFrequencies = computeTrapPotential(w_x[i], w_z, Power, Polarizability, options)[5]
# tmp = ExtractedTrapFrequencies[1][0]
# v_x[i] = tmp if not np.isinf(tmp) else np.nan
# #options['axis'] = 1
# #ExtractedTrapFrequencies = computeTrapPotential(w_x[i], w_z, Power, Polarizability, options)[5]
# #tmp = ExtractedTrapFrequencies[1][0]
# #v_y[i] = tmp if not np.isinf(tmp) else np.nan
# options['axis'] = 2
# ExtractedTrapFrequencies = computeTrapPotential(w_x[i], w_z, Power, Polarizability, options)[5]
# tmp = ExtractedTrapFrequencies[1][0]
# v_z[i] = tmp if not np.isinf(tmp) else np.nan
alpha_x = [(v_x[0]/v)**(2/3) for v in v_x] # #v_x[i] = calculateTrapFrequency(w_x[i], w_z, Power, Polarizability, dir = 'x').value
alpha_z = [(v_z[0]/v)**2 for v in v_z] # #v_y[i] = calculateTrapFrequency(w_x[i], w_z, Power, Polarizability, dir = 'y').value
# #v_z[i] = calculateTrapFrequency(w_x[i], w_z, Power, Polarizability, dir = 'z').value
calc_alpha_deviation = [(g - h) for g, h in zip(alpha_x, alpha_z)] # alpha_x = [(v_x[0]/v)**(2/3) for v in v_x]
# alpha_z = [(v_z[0]/v)**2 for v in v_z]
plt.figure() # calc_alpha_deviation = [(g - h) for g, h in zip(alpha_x, alpha_z)]
plt.plot(aspect_ratio, alpha_x, '-o', label = 'From horz TF')
plt.plot(aspect_ratio, alpha_z, '-^', label = 'From vert TF')
plt.xlabel('Aspect Ratio', fontsize= 12, fontweight='bold')
plt.ylabel('$\\alpha$', fontsize= 12, fontweight='bold')
plt.tight_layout()
plt.grid(visible=1)
plt.legend(prop={'size': 12, 'weight': 'bold'})
plt.show()
plt.figure() # plt.figure()
plt.plot(aspect_ratio, calc_alpha_deviation, '--ob', label = 'Extracted') # plt.plot(aspect_ratio, alpha_x, '-o', label = 'From horz TF')
plt.plot(new_aspect_ratio, sorted_meas_alpha_deviation, '-or', label = 'Measured') # plt.plot(aspect_ratio, alpha_z, '-^', label = 'From vert TF')
plt.xlabel('Aspect Ratio', fontsize= 12, fontweight='bold') # plt.xlabel('Aspect Ratio', fontsize= 12, fontweight='bold')
plt.ylabel('$\\Delta \\alpha$', fontsize= 12, fontweight='bold') # plt.ylabel('$\\alpha$', fontsize= 12, fontweight='bold')
plt.ylim([-0.5, 1]) # plt.tight_layout()
plt.tight_layout() # plt.grid(visible=1)
plt.grid(visible=1) # plt.legend(prop={'size': 12, 'weight': 'bold'})
plt.legend(prop={'size': 12, 'weight': 'bold'}) # plt.show()
plt.show()
# plt.figure()
# plt.plot(aspect_ratio, calc_alpha_deviation, '--ob', label = 'Extracted')
# plt.plot(new_aspect_ratio, sorted_meas_alpha_deviation, '-or', label = 'Measured')
# plt.xlabel('Aspect Ratio', fontsize= 12, fontweight='bold')
# plt.ylabel('$\\Delta \\alpha$', fontsize= 12, fontweight='bold')
# plt.ylim([-0.5, 1])
# plt.tight_layout()
# plt.grid(visible=1)
# plt.legend(prop={'size': 12, 'weight': 'bold'})
# plt.show()
"""Plot ideal crossed beam trap potential resulting for given parameters only""" """Plot ideal crossed beam trap potential resulting for given parameters only"""
# Powers = [40, 10] * u.W # Powers = [40, 10] * u.W
@ -1180,6 +1204,4 @@ if __name__ == '__main__':
# plt.xlim([-500, 500]) # plt.xlim([-500, 500])
# plt.ylim([-1800, -200]) # plt.ylim([-1800, -200])
# plt.legend() # plt.legend()
# plt.show() # plt.show()