Python光學(xué)仿真之對光的干涉理解學(xué)習(xí)
光的干涉
干涉即兩束光在疊加過程中出現(xiàn)的強度周期性變化情況,其最簡單的案例即為楊氏雙縫干涉。

如圖所示,光從 S S S點發(fā)出,通過兩個狹縫 S 1 , S 2 S_1,S_2 S1,S2,最終匯聚在右側(cè)的干涉屏上,在不同位置處將會產(chǎn)生不同的相位差。

import numpy as np
import matplotlib.pyplot as plt
#兩束光疊加
waveAdd = lambda I1,I2,theta : I1+I2+2*np.sqrt(I1*I2)*np.cos(theta)
#同一束光經(jīng)過小孔之后的光程差,dSlit為小孔間距,dWave為波長
#point為衍射屏上某點,theta為衍射屏相對小孔所在直線傾角
def interSlit(dSlit,point=(1,1,1),n=1,dWave=1.06e-6):
pVar = sum(np.array(point)**2) + 0.25*dSlit**2
delt = 2*np.pi*n/dWave*(
np.sqrt(pVar+point[0]*dSlit)-
np.sqrt(pVar-point[0]*dSlit))
return delt
#楊氏干涉,只考慮x方向
#dSlit:小孔間距;dScreen:衍射屏距離
#nGrid:網(wǎng)格個數(shù);dGrid:網(wǎng)格間距
def interYang(dSlit=1e-3,dScreen=1,n=1,I1=1,I2=1,
dWave=1.06e-6,nGrid=500,dGrid=1e-5):
xAxis = np.arange(-nGrid,nGrid+1)*dGrid
I = [waveAdd(I1,I2,interSlit(
dSlit,(x,0,dScreen),n,dWave))
for x in xAxis]
plt.plot(xAxis,I)
plt.show()
得到的衍射強度圖為

雙縫干涉是一個非常實用的模型,可以應(yīng)用到許多光學(xué)裝置中,例如Fresnel雙面鏡,F(xiàn)resnel雙棱鏡,Lloyds鏡,Billet剖開透鏡等等。其中Frenel雙面鏡如圖所示

光源入射到雙面鏡之后在鏡后產(chǎn)生了兩個像點 P , Q 二者相當(dāng)于一對小孔,于是可以在右側(cè)的干涉屏上產(chǎn)生干涉。
其仿真過程與楊氏干涉只差一個小孔的轉(zhuǎn)換,圖像亦如出一轍。
#alpha為雙鏡銳角,dSA為光源到劈點距離,dScreen為S像點連線到干涉屏距離
def lensFresnel(alpha=0.1,dSA=1e-3,dScreen=1,
n=1,I1=1,I2=1,dWave=1.06e-6,
nGrid=500,dGrid=1e-4):
dSlit = 2*dSA*np.sin(alpha)
interYang(dSlit,dScreen,n,I1,I2,dWave,nGrid,dGrid)
以上就是Python光學(xué)仿真之對光的干涉理解學(xué)習(xí)的詳細(xì)內(nèi)容,更多關(guān)于Python理解光的干涉的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
pycharm配置python 設(shè)置pip安裝源為豆瓣源
這篇文章主要介紹了pycharm配置python 設(shè)置pip安裝源為豆瓣源,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
Python實現(xiàn)遍歷子文件夾并將文件復(fù)制到不同的目標(biāo)文件夾
這篇文章主要介紹了如何基于Python語言實現(xiàn)遍歷多個子文件夾,將每一個子文件夾中大量的文件,按照每一個文件的文件名稱的特點復(fù)制到不同的目標(biāo)文件夾中,感興趣的可以了解下2023-08-08

