版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、 專(zhuān)業(yè)技術(shù)資料VSim螺旋線行波管模擬案例講義第一部分 概述模擬的對(duì)象為一個(gè)典型的螺旋線行波管?;窘Y(jié)構(gòu)是在金屬管內(nèi)裝有螺旋線和介質(zhì)夾持桿,然后在兩端引入輸入和輸出端口。當(dāng)電子束進(jìn)入螺旋線波導(dǎo)時(shí),就產(chǎn)生微波放大。實(shí)際模擬時(shí)我們用很多圈的螺旋線,為了看清幾何,我們用一組示意圖來(lái)描述:第二部分 幾何生成從上面的圖形可以看到,整個(gè)幾何模型包括下面的主要內(nèi)容:金屬外殼:在外殼上安裝了耦合端口,這里使用的耦合端口是一個(gè)簡(jiǎn)單的同軸線針頭-壁面耦合,在模擬的時(shí)候直接從同軸線送入TEM波。然后是作為波導(dǎo)的螺旋線,同軸線針頭直接耦合到螺旋線上。接下來(lái),為了支持螺旋線,需要三根介質(zhì)夾持桿:剖面圖顯示出夾持結(jié)構(gòu):實(shí)
2、際計(jì)算中,我們需要使用一個(gè)圈數(shù)很多的螺旋線(N=100 turns以上)。此外,在實(shí)踐中還需要加入衰減器。我們首先把匝數(shù)調(diào)整到100,然后可以看到衰減器的結(jié)構(gòu)(去掉外殼以便看清):中央綠色的是衰減器。這里需要考慮一下VSim的邏輯,金屬件都必須被實(shí)現(xiàn)為幾何結(jié)構(gòu)(gridBoundary),而夾持桿(介電結(jié)構(gòu))和衰減器(電導(dǎo)耗散)既可以實(shí)現(xiàn)為幾何結(jié)構(gòu),也可以直接用函數(shù)引入,它們并不是必須被寫(xiě)成gridBoundary的。確定一個(gè)結(jié)構(gòu)是否要被實(shí)現(xiàn)為gridBoundary,要看它的具體應(yīng)用。例如如果設(shè)置夾持桿和衰減器都要吸收電子,那么就應(yīng)該將它們實(shí)現(xiàn)為gridBoundary,而如果我們暫時(shí)不考慮
3、夾持桿和衰減器的吸收,那么就可以到處理電磁場(chǎng)的時(shí)候再寫(xiě)這個(gè)部分。除了上述的部分之外,VSim邏輯建議把所有的粒子發(fā)射源(emitter)都設(shè)置成為gridBoundary。所以,在幾何建模部分,需要建立金屬部件和發(fā)射體的gridBoundary。特別是,如果整個(gè)系統(tǒng)中有若干組金屬部件,但其中只有一個(gè)用作發(fā)射體,那么這個(gè)必須額外被單獨(dú)幾何建模一次,吸收體同理。gridBoundary可以用常規(guī)的<gridBoundary>對(duì)象來(lái)做,也可以使用geometry宏來(lái)做。下面是用geometry宏實(shí)現(xiàn)的金屬部件幾何,其中復(fù)雜的主要是螺旋線結(jié)構(gòu)?;舅悸肪褪菑囊粋€(gè)實(shí)體開(kāi)始,不斷貼上或者挖去部
4、分,最后形成金屬部件。$ DM_FRAC = 0.25$ import geometryfillGeoExpression(tube, geoCylinderXP(x-XBGN_GUN_WALL,y,z,REND_TUBE,LENGTH_TUBE_SHELL) )$ if PERIODIC_GEOMETRY=0fillGeoExpression(inputCoaxShell, geoCylinderXP(y-YBGN_COAX,z,x-XBGN_HELIX,RSHELL_COAX,LEGNTH_COAX) )fillGeoExpression(outputCoaxShell, geoCylin
5、derXP(y-YBGN_COAX,z,x-XEND_HELIX,RSHELL_COAX,LEGNTH_COAX) )$ endifvoidGeoExpression(tubeInterior, geoCylinderXP(x-XEND_GUN_WALL,y,z,RBGN_TUBE,LENGTH_TUBE_INTERIOR) )$ if PERIODIC_GEOMETRY=0voidGeoExpression(inputCoaxInterior, geoCylinderXP(y-YBGN_COAX,z,x-XBGN_HELIX,ROUTER_COAX,LEGNTH_COAX) )voidGeo
6、Expression(outputCoaxInterior, geoCylinderXP(y-YBGN_COAX,z,x-XEND_HELIX,ROUTER_COAX,LEGNTH_COAX) )$ endiffillGeoExpression(helix, geoCylinderXP(x-XBGN_HELIX_WIRE,yHelix(y,z),zHelix(x,y,z),RWIRE_HELIX,LENGTH_HELIX_WIRE) )$ if PERIODIC_GEOMETRY=0voidGeoExpression(trimHelixInput, myHalfCylinderXPZ(x-XB
7、GN_HELIX_WIRE,y,-z,RBGN_TUBE,LENGTH_TRIM_HELIX_INPUT) )voidGeoExpression(trimHelixOutput, myHalfCylinderXPZ(x-XTRIM_HELIX_OUTPUT,y,z,RBGN_TUBE,LENGTH_TRIM_HELIX_OUTPUT) )fillGeoExpression(inputCoaxInner, geoCylinderXP(y-YBGN_COAX,z,x-XBGN_HELIX,RINNER_COAX,LEGNTH_COAX) )fillGeoExpression(outputCoaxI
8、nner, geoCylinderXP(y-YBGN_COAX,z,x-XEND_HELIX,RINNER_COAX,LEGNTH_COAX) )$ endifsaveGeoToGridBoundary(metalParts,DM_FRAC)其中有一部分幾何用$ if PERIODIC_GEOMETRY=0來(lái)設(shè)置為條件形式。這些部分主要是兩端的切斷以及饋電的同軸線接口。涉及到的幾個(gè)宏的具體描述參考VSim In Depth。emitter幾何可以類(lèi)似地來(lái)做,應(yīng)該指出的是emitter一般來(lái)說(shuō)不必和金屬部件有什么關(guān)系,但是實(shí)踐中emitter往往是金屬部件的一部分。在這種情況下,emitter必
9、須被獨(dú)立地實(shí)現(xiàn)為一個(gè)gridBoundary:resetGeoToVoid()fillGeoExpression(emitterDisk, geoCylinderXP(x-XBGN_GUN_WALL,y,z,RBGN_TUBE,THICKNESS_ENDCAPS) )saveGeoToGridBoundary(emitter,DM_FRAC)第三部分:場(chǎng)模型和頻率分析基本框架產(chǎn)生金屬部件模型后,就可以啟用電磁場(chǎng)模型了。電磁場(chǎng)模型看上去很復(fù)雜,實(shí)際上基本都是從一個(gè)模板產(chǎn)生的,最簡(jiǎn)單的模板是以前用的dMYee宏。對(duì)于微波器件,一般我們可以從VSim6的例子中選擇一個(gè)類(lèi)似的模型,然后逐步修改成我們需
10、要的模型。這里我們使用的是一個(gè)比較通用的模板,它基本來(lái)自于dMYee宏。<MultiField yeeEM># 場(chǎng)定義.#推進(jìn)公式# - - - - - - - - - - - - - - - - - - - - - - - - -# update operations# 實(shí)際的推進(jìn)步驟</MultiField>通常幾乎不會(huì)有人真的從頭寫(xiě)出整個(gè)電磁模塊,而都是在一個(gè)類(lèi)型比較相似的模塊上進(jìn)行修改。當(dāng)然,我們可以使用以前遺留的一個(gè)宏deymittra.mac,此外現(xiàn)在的TWT輸入文件也是一個(gè)不錯(cuò)的模板。這個(gè)模板是利用MultiField寫(xiě)成的。為了在需要的時(shí)候修改這個(gè)模板,
11、我們需要解釋其基本內(nèi)容。一般來(lái)說(shuō),MultiField框架要包含三個(gè)主要的部分:場(chǎng)定義,更新器和算法包裝。由于MultiField是一個(gè)具有相當(dāng)自由的場(chǎng)計(jì)算框架,原則上我們應(yīng)該首先列出場(chǎng)方程。實(shí)踐中因?yàn)槲⒉ㄆ骷膱?chǎng)模型是非常類(lèi)似的,一般只要簡(jiǎn)單修改就可以,無(wú)需如此復(fù)雜。這里為了解釋清楚,我們列出基本概念。微波器件計(jì)算的電磁場(chǎng),一般包含靜態(tài)外場(chǎng)(主要是外磁場(chǎng))和微波時(shí)變電磁場(chǎng)。時(shí)變電磁場(chǎng)的方程是和在計(jì)算電磁學(xué)中的方法一樣,電場(chǎng)強(qiáng)度(和電流強(qiáng)度)被定義在網(wǎng)格的棱邊上,而磁場(chǎng)強(qiáng)度B被定義在面心,如同下面這個(gè)圖:和標(biāo)準(zhǔn)計(jì)算電磁學(xué)稍有區(qū)別的是,由于存在粒子電流J,為了計(jì)算的精度,上述方程是被拆成三步來(lái)進(jìn)
12、行FDTD推進(jìn)。按照VSim的邏輯,我們引入一個(gè)參數(shù)toDtFrac,它的取值從0.0到1.0。我們假設(shè)每個(gè)推進(jìn)步推進(jìn)中,迭代器的絕對(duì)時(shí)間從推進(jìn)到,每個(gè)電磁場(chǎng)推進(jìn)步的時(shí)間步長(zhǎng)是。實(shí)際中MultiField總是要由一組“更新步”組成,而每個(gè)更新步代表從“當(dāng)前時(shí)間”推進(jìn)到某個(gè)值?,F(xiàn)在我們可以列出PIC算法里面最標(biāo)準(zhǔn)的電磁場(chǎng)推進(jìn)步,推進(jìn)開(kāi)始的時(shí)刻是,所有場(chǎng)的“內(nèi)部時(shí)間”都是:第一步:進(jìn)行磁場(chǎng)B的推進(jìn)。設(shè)置toDtFac參數(shù)為0.5,也就是推進(jìn)目標(biāo)時(shí)間然后按照法拉第電磁感應(yīng)定律將磁場(chǎng)推進(jìn)為其中,其中是磁場(chǎng)在這個(gè)更新步之前的內(nèi)部時(shí)間。這里顯然。于是,于是磁場(chǎng)被推進(jìn)了半個(gè)時(shí)間步,推進(jìn)結(jié)束后,磁場(chǎng)內(nèi)部時(shí)間被
13、推進(jìn)到。第二步:進(jìn)行電場(chǎng)E的推進(jìn),這是利用廣義的安培定律:由于電場(chǎng)只有一步推進(jìn),因此這里的toDtFrac=1.0,所以,并且在執(zhí)行這個(gè)推進(jìn)后,電場(chǎng)的內(nèi)部時(shí)間被推進(jìn)到。第三步:再次推進(jìn)磁場(chǎng),仍然使用法拉第定律,并且設(shè)置toDtFrac=1.0,于是并且。執(zhí)行這個(gè)推進(jìn)后,磁場(chǎng)內(nèi)部時(shí)間被推進(jìn)到。現(xiàn)在我們可以分析行波管的MultiField模型了。在開(kāi)始的部分,必須定義這個(gè)MultiField框架所蘊(yùn)含的場(chǎng):<Field edgeE>numComponents = 3offset = edgeoverlap = 1 2</Field><Field faceB>nu
14、mComponents = 3offset = faceoverlap = 1 2</Field><Field edgeJ>kind = depFieldnumComponents = 3offset = edgeoverlap = 1 2</Field>$ if INCLUDE_PARTICLES=1<Field nodalE>numComponents = 3offset = noneoverlap = 1 2dumpPeriod = 0</Field><Field nodalB>numComponents = 3of
15、fset = noneoverlap = 1 2dumpPeriod = 0</Field>$ endif幾個(gè)場(chǎng)的語(yǔ)法是一樣的,都是要定義場(chǎng)的分量,位置(offset參數(shù)用來(lái)約定場(chǎng)量定義是在頂點(diǎn),面心還是棱邊上),存盤(pán)周期以及鬼網(wǎng)格結(jié)構(gòu)。在這里首先定義了電場(chǎng),磁場(chǎng)和電流場(chǎng)。接下來(lái)兩個(gè)節(jié)點(diǎn)電磁場(chǎng)nodalE和nodalB是用來(lái)將計(jì)算出的電磁場(chǎng)傳遞給帶電粒子計(jì)算。所以這個(gè)部分是使用了條件編譯。接下來(lái)是更新算法,我們看到一系列的FieldUpdater和FieldMultiUpdater:<FieldMultiUpdater yeeFaraday>gridBoundary =
16、 metalPartsinteriorness = deymittrakind = yeeFaradayUpdatercomponents = 0 1 2expandToTopInComponentDir = 1lowerBounds = 0 0 0upperBounds = NX NY NZreadFields = edgeEwriteFields = faceB</FieldMultiUpdater><FieldUpdater deyMittraFaraday>gridBoundary = metalPartsinteriorness = deymittrakind
17、 = deyMittraUpdaterlowerBounds = 0 0 0upperBounds = NX NY NZreadFields = edgeEwriteFields = faceB</FieldUpdater><FieldMultiUpdater yeeAmpere>gridBoundary = metalPartsinteriorness = deymittrakind = yeeAmpereUpdatercomponents = 0 1 2contractFromBottomInNonComponentDir = 1lowerBounds = 0 0
18、0upperBounds = NX NY NZreadFieldCompShifts = 0 0readFields = faceB edgeJwriteFields = edgeE</FieldMultiUpdater>$ if INCLUDE_PARTICLES=1<FieldUpdater nodalEupdate>kind = edgeToNodeVeclowerBounds = 0 0 0upperBounds = $NX+1$ $NY+1$ $NZ+1$readFields = edgeEwriteFields = nodalE</FieldUpdat
19、er><FieldUpdater nodalBupdate>kind = faceToNodeVeclowerBounds = 0 0 0upperBounds = $NX+1$ $NY+1$ $NZ+1$readFields = faceBwriteFields = nodalB</FieldUpdater>$endif這里面有五個(gè)Updater。一般來(lái)說(shuō)前三個(gè)都是標(biāo)準(zhǔn)的:yeeFaradayUpdater和deyMittraUpdater用來(lái)推進(jìn)電磁場(chǎng)的法拉第感應(yīng)定律:由于導(dǎo)體表面處沒(méi)有切向電場(chǎng),需要對(duì)這個(gè)方程做特殊考慮,所以法拉第定律包含了兩個(gè)updater
20、,yeeFaradayUpdater用于計(jì)算不和導(dǎo)體接觸的網(wǎng)格,而deyMittraUpdater用于計(jì)算導(dǎo)體邊界處的網(wǎng)格,兩個(gè)updater一般都是在一起應(yīng)用的。yeeAmpereUpdatery用來(lái)推進(jìn)安培定律:上面兩種updater足以完成FDTD推進(jìn)步驟,為了把電磁場(chǎng)輸出給粒子,需要把edgeE和faceB的值傳送給nodalE和nodalB,這是后面兩個(gè)updater完成的工作。一般情況下我們基本不需要修改這些updater,只要補(bǔ)充我們需要的updater并且封裝就可以了。最后是包裝成完整的推進(jìn)步:<UpdateStep finishFaraday>toDtFrac =
21、 0.5messageFields = faceBupdaters = yeeFaraday deyMittraFaraday</UpdateStep><UpdateStep Ampere>toDtFrac = 1.0updaters = yeeAmperemessageFields = edgeE</UpdateStep><UpdateStep startFaraday>toDtFrac = 1.0messageFields = faceBupdaters = yeeFaraday deyMittraFaraday</UpdateStep
22、>$ if INCLUDE_PARTICLES=1<UpdateStep getEatNodes>toDtFrac = 1.0updaters = nodalEupdatemessageFields = nodalE</UpdateStep><UpdateStep getBatNodes>toDtFrac = 1.0updaters = nodalBupdate messageFields = nodalB</UpdateStep>$ endif按照我們說(shuō)的那樣,首先是finishFarady(半步法拉第定律),然后是Ampere(一步安培
23、定律),再startFarady(另外半步法拉第定律)。實(shí)際上完成這三步之后,一個(gè)FDTD推進(jìn)步就完成,剩下的兩個(gè)更新步用于將E和B輸出到nodalE和nodalB。加入介質(zhì)和損耗上面的計(jì)算只包含了導(dǎo)體部分,而實(shí)際的行波管還包含夾持桿和衰減器。從模擬的角度來(lái)說(shuō)夾持桿是一塊電介質(zhì),而衰減器是一塊部分導(dǎo)體。對(duì)于電介質(zhì)和衰減介質(zhì)的建模,VSim有兩種方案,一種是使用現(xiàn)成的兩個(gè)求解器(更新器),另一種是干脆自己寫(xiě)一個(gè)更新器。兩者的區(qū)別是前者可以處理復(fù)雜外形(包括CAD導(dǎo)入),但是只能是均勻的介電函數(shù)或者電導(dǎo)函數(shù);后者只能處理用函數(shù)描述的結(jié)構(gòu),但可以處理介電/電導(dǎo)函數(shù)的演化。這里因?yàn)橥庑魏芎?jiǎn)單,我們使用
24、第二種方法。首先看一下處理介電和電導(dǎo)問(wèn)題的方法,在考慮介電和電導(dǎo)的情況下,安培定律是使用半點(diǎn)差分,這個(gè)方程可以寫(xiě)成化簡(jiǎn)后就是或者寫(xiě)成其中第二個(gè)方程完全等價(jià)于原來(lái)的安培更新步,所以我們只需要在原來(lái)的安培更新步之前之后各插入一個(gè)轉(zhuǎn)換步,就可以實(shí)現(xiàn)帶電導(dǎo)和介電的器件的求解。為了實(shí)現(xiàn)這兩個(gè)步驟,首先要寫(xiě)出介電和電導(dǎo)的表達(dá)式,這兩個(gè)表達(dá)式是:<function epsRelTerm(x,y,z)> 1.0 + (EPS_ROD-1.0)*geoCylinderXP(x-XBGN_HELIX_WIRE,y-YROD1,z-ZROD1,RADIUS_ROD,LENGTH_HELIX_WIRE)
25、+ (EPS_ROD-1.0)*geoCylinderXP(x-XBGN_HELIX_WIRE,y-YROD2,z-ZROD2,RADIUS_ROD,LENGTH_HELIX_WIRE) + (EPS_ROD-1.0)*geoCylinderXP(x-XBGN_HELIX_WIRE,y-YROD3,z-ZROD3,RADIUS_ROD,LENGTH_HELIX_WIRE)</function># definitions for attenuator$ VPHASEX_HELIX = LIGHTSPEED*SINPHI$ XBGNTURN_ATTENUATOR = XBGN_HELI
26、X + BGNTURN_ATTENUATOR*PITCH_HELIX$ LENGTH_ATTENUATOR = (ENDTURN_ATTENUATOR - BGNTURN_ATTENUATOR)*PITCH_HELIX$ SIGMA = (VPHASEX_HELIX*EPS0/LENGTH_ATTENUATOR)*ln(10.0*(DB_ATTENUATOR/10.0)$ ATTENUATE_FACTOR = 0.5*DT*SIGMA/EPS0<function attenuateTerm(x,y,z)> ATTENUATE_FACTOR*geoPipeXP(x-XBGNTURN_
27、ATTENUATOR,y,z,RMID_HELIX,REND_TUBE,LENGTH_ATTENUATOR)</function>然后需要在MultiField框架內(nèi)加入updater和updaterStep:<Field epsRelMinus> # = epsRel - 0.5*sigma*dt/eps0numComponents = 3overlap = 1 2offset = edge<InitialCondition vacuumEps>kind = variablelowerBounds = 0 0 0upperBounds = NX NY NZ
28、components = 0 1 2<STFunc component0>kind = expressionexpression = epsRelTerm(x,y,z) - attenuateTerm(x,y,z)</STFunc><STFunc component1>kind = expressionexpression = epsRelTerm(x,y,z) - attenuateTerm(x,y,z)</STFunc><STFunc component2>kind = expressionexpression = epsRelT
29、erm(x,y,z) - attenuateTerm(x,y,z)</STFunc></InitialCondition></Field><Field epsRelPlus># = epsRel + 0.5*sigma*dt/eps0numComponents = 3overlap = 1 2offset = edge<InitialCondition vacuumEps>kind = variablelowerBounds = 0 0 0upperBounds = NX NY NZcomponents = 0 1 2<STFu
30、nc component0>kind = expressionexpression = epsRelTerm(x,y,z) + attenuateTerm(x,y,z)</STFunc><STFunc component1>kind = expressionexpression = epsRelTerm(x,y,z) + attenuateTerm(x,y,z)</STFunc><STFunc component2>kind = expressionexpression = epsRelTerm(x,y,z) + attenuateTerm
31、(x,y,z)</STFunc></InitialCondition></Field><FieldUpdater EtoD>kind = fieldBinOpUpdaterlowerBounds = 0 0 0upperBounds = NX NY NZbinOp = multiplyaCoeff = 0.0bCoeff = 0.0readFields = edgeE epsRelMinus writeFields = edgeE</FieldUpdater><FieldUpdater DtoE>kind = fieldB
32、inOpUpdaterlowerBounds = 0 0 0upperBounds = NX NY NZbinOp = divideaCoeff = 0.0bCoeff = 0.0readFields = edgeE epsRelPlus writeFields = edgeE</FieldUpdater>上面是電磁場(chǎng)的基本部分。按照我們知道的,行波管除了等離子體自生電磁場(chǎng)之外,還有一個(gè)導(dǎo)向磁場(chǎng),為此我們還要再加入一個(gè)更新器:<FieldUpdater addInBstatic>kind = STFuncUpdateroperation = addlowerBounds
33、 = 0 0 0upperBounds = $NX+1$ $NY+1$ $NZ+1$writeFields = nodalBcomponent = 0<STFunc wave>kind = expressionexpression = BSTATIC</STFunc></FieldUpdater>然后我們需要把這些updater安裝在正確的位置,首先我們裝入EtoD和DtoE:<UpdateStep Ampere>toDtFrac = 1.0updaters = EtoD yeeAmpere DtoEmessageFields = edgeE&l
34、t;/UpdateStep>然后裝入靜磁場(chǎng):<UpdateStep getBatNodes>toDtFrac = 1.0updaters = nodalBupdate addInBstaticmessageFields = nodalB</UpdateStep>最后還有一個(gè)問(wèn)題,即行波管具有輸入和輸出端口。在VSim6中,最簡(jiǎn)單的實(shí)現(xiàn)輸入和輸出端口的方法是使用Port和incident宏。這兩個(gè)宏必須使用在ampereUpdater附近:applyPortAtBoundary_beforeAmpere(1,1,LIGHTSPEED,DY,DT,edgeE,NX,N
35、Y,NZ)<UpdateStep Ampere>.</UpdateStep>applyPortAtBoundary_afterAmpere(1,1,LIGHTSPEED,DY,DT,edgeE,NX,NY,NZ)addIncidentWaveAtBoundaryPort(1,1,LIGHTSPEED,DY,DT,edgeE,NX,NY,NZ,0,0,inputWaveX(x,y,z,t)addIncidentWaveAtBoundaryPort(1,1,LIGHTSPEED,DY,DT,edgeE,NX,NY,NZ,2,0,inputWaveZ(x,y,z,t)此外,這
36、兩個(gè)宏都包含在port文件里面,所以要在文件的開(kāi)頭加入$import port原理上,這樣行波管的cold部分就設(shè)計(jì)完成了,接下來(lái),我們可以加入一些診斷來(lái)檢查電磁波會(huì)不會(huì)在行波管內(nèi)正常傳播。例如,加入出射信號(hào)診斷:# input signals$ IXVINPUTBGN = int(XBGN_HELIX-RSHELL_COAX-XBGN)/DX)$ IXVINPUTMID = int(XBGN_HELIX -XBGN)/DX)$ IXVINPUTEND = int(XBGN_HELIX+RSHELL_COAX-XBGN)/DX)<History inputVoltage>kind
37、= pseudoPotentialfield = yeeEM.edgeEreferencePoint = IXVINPUTMID $NY-1$ $int(NZ/2)$measurePoint = $IXVINPUTEND+1$ $NY-1$ $int(NZ/2)$</History><History inputPoynting>kind = fieldPoynlowerBounds = IXVINPUTBGN $NY-1$ 0upperBounds = $IXVINPUTEND+1$ $NY-1$ NZfields =yeeEM.edgeE, yeeEM.faceB&l
38、t;/History># output signals$ IXVOUTPUTBGN = int(XEND_HELIX-RSHELL_COAX-XBGN)/DX)$ IXVOUTPUTMID = int(XEND_HELIX -XBGN)/DX)$ IXVOUTPUTEND = int(XEND_HELIX+RSHELL_COAX-XBGN)/DX)$ IYVINPUT = NY-1<History outputVoltage>kind = pseudoPotentialfield = yeeEM.edgeEreferencePoint = IXVOUTPUTMID $NY-1
39、$ $int(NZ/2)$measurePoint = $IXVOUTPUTEND+1$ $NY-1$ $int(NZ/2)$</History><History outputPoynting>kind = fieldPoynlowerBounds = IXVOUTPUTBGN $NY-1$ 0upperBounds = $IXVOUTPUTEND+1$ $NY-1$ NZfields = yeeEM.edgeE, yeeEM.faceB</History>診斷的內(nèi)容包括輸入輸出功率/電壓。其中電壓需要特殊注意。嚴(yán)格的說(shuō)電磁波器件并沒(méi)有電壓,實(shí)踐中VSim用
40、“偽勢(shì)”量度兩點(diǎn)之間的壓差。在現(xiàn)在的情況下,輸入輸出電壓就是在輸入和輸出端口同軸電纜芯部和外皮上各任選一點(diǎn)然后測(cè)量的偽勢(shì)。輸入電壓輸出電壓第四部分:粒子加入和放大性能物理建模的最后一步是加入粒子。由于沒(méi)有背景等離子體,所以只要加入粒子發(fā)射和吸收就可以了。引入粒子的基本模式就是先寫(xiě)一個(gè)標(biāo)準(zhǔn)的Species: $ NPARTICLES_PER_CELL_PER_TIME_STEP = 0.1 $ VEMIT = sqrt(2.0*BEAM_VOLTAGE/511.0e3)*LIGHTSPEED $ BEAM_AREA = PI*BEAM_RADIUS*2 $ JDENS = BEAM_CURREN
41、T/BEAM_AREA $ NSTEPS_ACROSS_CELL = DX/(VEMIT*DT) $ NOMINAL_DENSITY = JDENS/(VEMIT*1.602176487e-19) $ NOMINAL_PARTICLES_PER_CELL = NPARTICLES_PER_CELL_PER_TIME_STEP*NSTEPS_ACROSS_CELL <Species electron> kind = relBorisVW charge = -1.602176487e-19 mass = 9.10938215e-31 nominalDensity = NOMINAL_D
42、ENSITY nomPtclsPerCell = NOMINAL_PARTICLES_PER_CELL fields = yeeEM.nodalE yeeEM.nodalB currDeps = Jdepostion.</Species>這里有一個(gè)需要特殊注意的地方,是我們必須將粒子和電磁場(chǎng)耦合起來(lái)。耦合包含兩部分,一個(gè)是讓粒子接受電磁場(chǎng)力的作用,這是通過(guò)fields = yeeEM.nodalE yeeEM.nodalB 這樣語(yǔ)法實(shí)現(xiàn)的;另一點(diǎn)則是將粒子的電流密度傳遞給電磁場(chǎng),這是通過(guò)currDeps語(yǔ)句。 為了讓currDeps生效,我們還要對(duì)其中的Jdepositi
43、on進(jìn)行定義:<VectorDepositor Jdepostion> kind = areaWeighting depField = yeeEM.edgeJ </VectorDepositor>其中areaWeighting 表示使用面積權(quán)重計(jì)算,具體到這個(gè)語(yǔ)法的詳細(xì)內(nèi)容可以研究手冊(cè),我們這里只指出一點(diǎn):如果使用的是MultiField類(lèi)型的場(chǎng),那么我們的電流是自己定義的,因此必須使用一個(gè)獨(dú)立的VectorDepositior;如果按照以前的方法使用emMultiField,那么電流場(chǎng)自動(dòng)定義成SumRhoJ,也就無(wú)需自己再定義VectorDepositior,當(dāng)然對(duì)
44、應(yīng)地也不需要定義edgeJ。定義了粒子類(lèi)型后,需要引入一個(gè)粒子源。在現(xiàn)在的情況下,發(fā)射體已經(jīng)定義,所以直接使用一個(gè)cutCellPosGen的xvLoaderEmitter就好。一般我們總是xvLoaderEmitter:<ParticleSource beamEmission> kind = xvLoaderEmitter positionFunction = bitReversed useCornerMove = true emitBasedOnLocalForce = false load = false applyTimes = 0.0 1.0 <PositionGe
45、nerator bitRevSlab> kind = cutCellPosGen numMacroPtclsPerStep = $int(NPARTICLES_PER_CELL_PER_TIME_STEP*BEAM_AREA/(DY*DZ)$ emitterBoundary = emitter emissionOffset = 0.01 <STFunc mask> kind=expression expression = H(x-(XEND_GUN_WALL-DX)*H(BEAM_RADIUS*2-y*2-z*2)-0.5 </STFunc> </PositionGenerator> <VelocityGenerator emitVelGen> kind = funcVelGen velocityIsLocal = true <STFunc component0> kind = expression # negative sign is necessary expression = -VEMIT </STFunc> </Velocit
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年舞蹈表演藝術(shù)人才培養(yǎng)機(jī)構(gòu)合同模板2篇
- 2024年餐館廚師勞動(dòng)合同3篇
- 2025年度網(wǎng)絡(luò)安全監(jiān)測(cè)合同范本共十七項(xiàng)安全防護(hù)措施3篇
- 2024年限期土地開(kāi)發(fā)承包協(xié)議
- 1《義務(wù)教育數(shù)學(xué)課程標(biāo)準(zhǔn)(2022年版)》自測(cè)卷
- 2024年采購(gòu)合作合同范本一
- 2024年節(jié)能打印機(jī)銷(xiāo)售及售后服務(wù)合同3篇
- 2025年度住宅防盜門(mén)個(gè)性化定制合同3篇
- 2024年珠海房產(chǎn)買(mǎi)賣(mài)合同3篇
- 2025年度船舶建造項(xiàng)目股權(quán)轉(zhuǎn)讓與工程監(jiān)理合同3篇
- 滬教版 三年級(jí)數(shù)學(xué)上冊(cè) 圖形與幾何習(xí)題2
- 大使涂料(安徽)有限公司年產(chǎn)6萬(wàn)噸科技型工業(yè)涂料、水性環(huán)保涂料生產(chǎn)項(xiàng)目環(huán)境影響報(bào)告書(shū)
- 利樂(lè)包和康美包的比較
- 法院執(zhí)行庭長(zhǎng)供職報(bào)告1400字
- 推動(dòng)架機(jī)械加工工序卡片
- 重慶市綦江區(qū)篆塘鎮(zhèn)白坪村建筑用砂巖礦采礦權(quán)評(píng)估報(bào)告
- 甘肅社火100首歌詞
- 行政查房情況記錄表
- GB/T 2315-2000電力金具標(biāo)稱(chēng)破壞載荷系列及連接型式尺寸
- 腹主動(dòng)脈瘤的護(hù)理查房
- 星級(jí)酒店每日防火巡查記錄本
評(píng)論
0/150
提交評(píng)論