Python光學仿真學習Gauss高斯光束在空間中的分布
Gauss光束強度的表達式為

如圖所示

左上圖和左下圖表示激光傳輸過程中的其束腰半徑的變化情況;右圖則表示高斯光束某一橫截面處激光的能量分布。
繪制代碼如下
import matplotlib.pyplot as plt
import numpy as np
def setLabel(ax,*args):
ax.set_xlabel(args[0])
ax.set_ylabel(args[1])
if len(args)==3:
ax.set_zlabel(args[2])
def drawGauss(w0=1,dWave=1.064):
# 軸向坐標
z = np.linspace(-10,10,1000).reshape(1000,1)
# z處光斑半徑
w = np.sqrt(w0**2+z**2*dWave**2/np.pi**2/w0**2)
theta = np.linspace(0,np.pi*2,150).reshape(1,150)
x = w*np.cos(theta)
y = w*np.sin(theta)
fig = plt.figure()
# 三維的高斯光束等功率密度面變化圖
ax1 = fig.add_subplot(221,projection='3d')
ax1.plot_surface(z,x,y)#,cmap=plt.get_cmap('rainbow'))
ax1.set_title("waist shape changed by propagation")
setLabel(ax1,"z","x","y")
# 二維的高斯光束半徑變化圖
ax3 = fig.add_subplot(223)
ax3.plot(z,w,linewidth=1)
ax3.plot(z,-w,linewidth=0.2)
ax3.plot([z[0],z[-1]],[0,0],linewidth=0.5,linestyle=":")
ax3.set_title("waist value changed by propagation")
setLabel(ax3,"z","w")
# Gauss光束在束腰處的切片
X,Y = np.meshgrid(np.linspace(-5,5,100),np.linspace(-5,5,100))
Psi = np.exp(-(X**2+Y**2)/w0**2)/w0
ax2 = fig.add_subplot(222,projection='3d')
ax2.plot_surface(X,Y,Psi)
ax2.set_title("Intensity distribution on waist0")
setLabel(ax2,"x","y","Instensity")
# Gauss光束在束腰處的徑向切片
r = np.linspace(-5,5,200)
Psi = np.exp(-r**2/w0**2)/w0
ax4 = fig.add_subplot(224)
ax4.plot(r,Psi)
ax4.set_title("Intensity distribution on waist0")
setLabel(ax4,"r","Instensity")
plt.show()
如果沿著z軸方向,在不同的位置處對Gauss光束進行切片處理,則不同位置處徑向功率分布如圖所示

實現(xiàn)代碼如下
import matplotlib.animation as animation
def GaussGif1d(w0=1,dWave=1.064):
zAxis = np.arange(100)
# 軸向坐標
z = np.linspace(0,10,100)
# z處的束腰半徑
w = np.sqrt(w0**2+z**2*dWave**2/np.pi**2/w0**2)
x = np.linspace(-10,10,500)
fig = plt.figure()
ax = fig.gca(xlim=(-5,5),ylim=(0,1))
ax.grid()
line, = ax.plot([],[])
time_text = ax.text(0.1,0.9,'',transform=ax.transAxes)
# 初始化圖像
def init():
line.set_data([],[])
time_text.set_text("")
return line, time_text
# 圖像迭代
def animate(i):
wi = w[i]
Psi = np.exp(-x**2/wi**2)/wi
line.set_data(x,Psi)
time_text.set_text("z="+str(z[i]))
return line, time_text
ani = animation.FuncAnimation(fig, animate, zAxis,
interval=200, init_func=init)
ani.save('gauss.gif',writer='imagemagick')
plt.show()
以上就是Python光學仿真學習Gauss高斯光束在空間中的分布的詳細內(nèi)容,更多關(guān)于Python光學仿真Gauss高斯光束空間分布的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python如何實現(xiàn)遠程控制電腦(結(jié)合微信)
這篇文章主要介紹了python如何實現(xiàn)遠程控制電腦,利用python設(shè)計了一個程序來實現(xiàn)自由管控,感興趣的小伙伴們可以參考一下2015-12-12
python如何實現(xiàn)異步調(diào)用函數(shù)執(zhí)行
這篇文章主要介紹了python如何實現(xiàn)異步調(diào)用函數(shù)執(zhí)行,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07
win與linux系統(tǒng)中python requests 安裝
requests是Python的一個HTTP客戶端庫,跟urllib,urllib2類似,今天我們主要來談?wù)剋in與linux系統(tǒng)中python requests的安裝方法以及使用指南2016-12-12
Python開發(fā)之迭代器&生成器的實戰(zhàn)案例分享
在 Python 中,迭代器和生成器都是用來遍歷數(shù)據(jù)集合的工具,可以按需逐個生成或返回數(shù)據(jù),從而避免一次性加載整個數(shù)據(jù)集合所帶來的性能問題和內(nèi)存消耗問題。本文主要和大家分享幾個貼近實際運維開發(fā)工作中的場景案例,希望對大家有所幫助2023-04-04
Python數(shù)據(jù)可視化:頂級繪圖庫plotly詳解
今天小編就為大家分享一篇Python數(shù)據(jù)可視化:頂級繪圖庫plotly詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12

