版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
螺旋槳渦格法的初步實現(xiàn)螺旋槳升力面理論有渦分布法,偶極子分布法和加速度勢法等。經(jīng)過多年的應用實踐,現(xiàn)在普遍采用的是渦分布法。雖然面元法的發(fā)展比升力面方法在理論上更為完善,尤其是壓力分布的預報計算顯著優(yōu)于后者,但就螺旋槳合力的計算而言,兩者基本具有同樣的計算精度,因此升力面理論方法目前仍是螺旋槳理論設計所采用的主要工具。隨著計算機速度和內(nèi)存的不斷提高和擴大,渦格法(VortexLatticeMethod,即VLM)得到越來越廣泛的應用。至今,各學者所發(fā)表的各種渦升力面理論的論文,就原理而言都是一致的,而主要差別僅在于渦模型包括尾渦處理和數(shù)值方法兩方面。作為螺旋槳理論的初學者,為了深入理解升力面理論以及應用方式,我們將通過自編程序在計算機上進行簡單的渦格法實現(xiàn)。由于螺旋槳的幾何形狀較為復雜,而我們的目的在于對升力面渦格法有初步的認識,因此我們對螺旋槳作一定程度上的簡化,既能反映渦格法的計算特征,又能使計算相對簡便。在對渦格法理論模型進行簡單的介紹之后,本文將給出渦格法的實現(xiàn)程序,并對不同攻角以及不同拱弧面下的計算結果進行分析比較。一、渦格法理論模型1、螺旋槳幾何特征本文使用一空間曲面(拱弧面,即升力面)代替螺旋槳槳葉,槳葉厚度可由離散的源匯分布來模擬,但在本文中不予考慮。該拱弧面在xoy平面的投影為展長2.0,弦長1.0的矩形平面,在xoz平面上的投影為一剖面拱弧。為了比較不同的拱弧線對槳葉性能的影響,本文使用三種不同的剖面拱弧線,它們分別為NACAa二0.8剖面拱弧、圓弧以及拋物線拱弧。為了比較不同的最大拱高值對槳葉性能的影響,本文取兩種不同的最大拱高,分別為fmax=0.02*c和fmax=0.04*c,其中c為弦長1.0。2、控制方程渦格法的思想是將升力面設置在拱弧面上,然后在升力面上進行渦格劃分,并在每個渦格上布置馬蹄渦和控制點,而每個馬蹄渦的強度是未知的,可以通過在控制點處滿足拱弧面上法向速度為零的邊界條件進行求解。本文中渦格為均勻網(wǎng)格劃分,展向劃分m個渦格,弦向劃分n個渦格,在每個渦格中將馬蹄渦的展向渦段布置在每格的1/4弦向格長位置處,而控制點置于3/4弦向格長及1/2展向格長位置,Weissinger證明了這樣做已隱含著庫塔條件的滿足。對于弦向渦線則沿渦格線分成直線渦段,亦即說整個弦向渦的幾何形狀用折線代替,尾渦區(qū)渦線另行處理。這樣,對于每一個控制點,滿足物面不可穿透條件可得:(v+v)?n=0IJ0IJ其中v和n分別表示第(I,J)個渦格控制點的誘導速度和法向矢量,v表示流場的入流速IJij - - - 0度。v為所有的升力面馬蹄渦在第(I,J)個渦格控制點的誘導速度的疊加,即:?口f -vIJ+K(vIJ+K(uci+1,l—Uc)+(uwi,l i+1,j-uw)]*ri,j i,j其中us,Y(uc-uc),uw-uw分別表示單位渦強的第(i,j)個馬蹄渦的展向渦段、i,j i+1,1 i,l i+1,ji,jl=j弦向渦段以及尾渦段對第(I,J個渦格控制點的誘導速度,可根據(jù)Biot-Savart定理求得,而廠表示第(i,j)個馬蹄渦的渦強,為待求的未知量。i,j對所有的控制點滿足方程聯(lián)立求解,即可得每個渦格內(nèi)馬蹄渦的渦強。3、 葉面區(qū)的渦系模型在葉面區(qū)內(nèi),展向均勻劃分15個格,弦向均勻劃分20格,而每一個馬蹄渦按渦格劃分為展向渦段和弦向渦段。由于NACAa二0.8的剖面拱弧型值為一系列散點坐標,所以在求解渦段端點及控制點坐標時需要進行插值處理??紤]到最大拱高值相對于弦長較小,使用線性插值和三次樣條插值的結果差別不大,因此選用較為簡單的線性插值即可。對于控制點的法向矢量,通過求取與控制點相鄰兩點所組成的直線斜率,然后再作簡單的三角處理即可求得。對于圓弧以及拋物線拱弧,可直接求得各點的坐標值和法向矢量。但為了保持程序的統(tǒng)一性,本文依然先求得拱弧線的一系列散點坐標,然后按與NACAa=0.8拱弧相類似的處理方法求取各點的坐標值和法向矢量。4、 尾流區(qū)的渦系模型尾流區(qū)內(nèi)尾渦的處理較為復雜,且對計算結果有較大的影響。尾流區(qū)是自由空間,故渦的走向須沿著流場內(nèi)該點的速度方向。而流場速度是需問題解出后才知道,故尾流區(qū)是事先未知的,這就構成了解升力面問題的非線性。為了使求解問題簡化,本文事先假定了尾流區(qū)的范圍和形狀。本文將尾流區(qū)分為過渡尾流區(qū)及遠尾流區(qū),以便更好的符合實際情況。在過渡尾流區(qū),尾渦在隨邊處沿剖面拱弧的切線方向泄出,由于受來流速度的影響,尾渦在過渡尾流區(qū)結束的地方與來流方向一致。過渡尾流區(qū)的長度為一倍弦長。在過渡尾流區(qū)內(nèi),尾渦的走向成二次拋物線型。與葉面區(qū)類似,過渡尾流區(qū)內(nèi)的尾渦按弦向共劃分n個渦段。同時,考慮到展向兩端的尾渦卷曲,尾渦在隨邊處的下泄方向不僅與剖面拱弧的切線方向有關,而且與來流速度相關,因此本文中尾渦的下泄方向為:v=av+(1—ci)vTOC\o"1-5"\h\zw 0 t其中V,v,v分別表示尾渦下泄方向,來流速度方向和隨邊處剖面拱弧的切線方向,cw0t 一 f 一與展向坐標有關,其表達式為:f f fa=2*(y/s—0.5)2其中y為尾渦下泄點的展向坐標,s為展長。在遠尾流區(qū),尾渦方向與來流速度方向一致,為半無限長渦線,處理較為簡單。二、數(shù)值結果的比較分析
本文計算了NACAa二0.8剖面拱弧、圓弧以及拋物線等三種不同的拱弧面,不同最大拱高值分別為fmax=0.02*c和fmax=0.04*c(其中c為弦長1.0),不同攻角分別為0.0,2.5,5.0和10.0下的渦強分布。為了便于比較,本文中所給結果僅為槳葉在展向中部的渦強分布,此處的渦強值最大。下面給出部分數(shù)值結果的比較分析,其中離散點標識為數(shù)值計算結果,而線條值為樣條擬合結果,由于渦強在導邊附近變化較為激烈,故擬合值可能存在較大誤差,僅作為參考。1、不同攻角下渦強沿弦向分布的比較圖1所示為當剖面拱弧和最大拱高一定時,不同攻角下渦強沿弦向分布的比較。從圖1中可以看出,當攻角從0.0增加到10.0度時,渦強均增大,且在導邊處變化較為明顯,隨邊處變化較小。當fmax=0.02*c時,攻角為0.0導致導邊附近環(huán)量為負值;當fmax=0.04*c時,攻角為0.0和2.5均導致導邊附近環(huán)量為負值,說明具有較大拱高值的拱弧線在大攻角入流條件下才能取得較好的升力性能。同時,NACAa二0.8剖面拱弧在0?0.8倍弦長范圍內(nèi)渦強變化較為平緩,在0.8~1.0倍弦長內(nèi)渦強呈直線下降到0,且?guī)焖l件滿足較好;而圓弧和拋物線剖面在整個弦長范圍內(nèi)渦強變化較為平緩,但庫塔條件滿足不是很好。(a)(a)NACAa=0.8剖面,fmax=0.02*c(b)NACAa二0.8剖面,fmax=0.04*ca-100yisioo.*-?■00??00下庚攻甬下潘區(qū)沿蔻向分布的比較■:arc:fmax=0.02-ca-100yisioo.*-?■00??00下庚攻甬下潘區(qū)沿蔻向分布的比較■:arc:fmax=0.02-c)下潘強沿處向分布?H匕較arc:fmax=OO4-c>-002(c)圓弧剖面,(c)圓弧剖面,fmax=0.02*c(d)圓弧剖面,fmax=0.04*c0.1"100iM-a?00不同攻角下爲強沿菠向分心的比較parabolafmax=002*c0.1"100iM-a?00不同攻角下爲強沿菠向分心的比較parabolafmax=002*c不同攻角下爲強沿菠向分專的比較parabolafmax=004*c-002(e)拋物線剖面,fmax=0.02*c(f)拋物線剖面,fmax=0.04*c圖1、不同攻角下渦強沿弦向分布的比較2、不同拱弧下渦強沿弦向分布的比較圖2所示為當最大拱高值和攻角一定時,不同拱弧下渦強沿弦向分布的比較。從圖中可以看到,圓弧剖面和拋物線剖面所得到的渦強分布極其相似,幾乎無法分辨出兩者的差別可能需要增加插值點數(shù)才能提高精度,顯示出兩者的差別。同時,NACAa0.8剖面拱弧在0~0.8倍弦長范圍內(nèi)渦強變化較為平緩,在0.8~1.0倍弦長內(nèi)渦強呈直線下降到0,且?guī)焖l件滿足較好;而圓弧和拋物線剖面在整個弦長范圍內(nèi)渦強都有變化,且?guī)焖l件滿足不是很好。當fmax=0.04*c,攻角為2.5度時,螺旋槳未達到正常的工作狀態(tài)。此外,圓弧剖面和拋物線剖面所得到的渦強分布擬合曲線出現(xiàn)鋸齒狀,可能是由于求剖面型值時插值節(jié)點較少導致精度不夠,增加插值節(jié)點可能會有所改善。(a)fmax=0.02*c,攻角為2.5度 (b)fmax=0.02*c,攻角為5.0度(c)(c)fmax=0.04*c,攻角為2.5度(d)fmax=0.04*c,攻角為5.0度圖2、不同拱弧下渦強沿弦向分布的比較3、不同拱高下渦強沿弦向分布的比較3、不同拱高下渦強沿弦向分布的比較圖3所示為NACAa二0.8剖面在攻角一定時,不同最大拱高值下渦強沿弦向分布的比較。從圖中可以看到,當fmax=0.02*c,攻角為2.5度,或fmax=0.04*c,攻角為5.0度時,NACAa二0.8剖面得到的渦強分布較為理想。(a)(a)NACAa二0.8剖面,攻角為0.0度(b)NACAa二0.8剖面,攻角為2.5度0.04*fmax?O02"cfmax?OO4*c02ac002060406不同拱&下潘暹檔菠向分布的比較NACA:8=10.0.不同拱玄下爲強縉菠向分畝的比較NACA;a=5.0003500250.04*fmax?O02"cfmax?OO4*c02ac002060406不同拱&下潘暹檔菠向分布的比較NACA:8=10.0.不同拱玄下爲強縉菠向分畝的比較NACA;a=5.0003500250.020005-0015,fmax=0M*c"(a)(a)NACAa二0.8剖面,攻角為5.0度(b)NACAa二0.8剖面,攻角為10.0度圖3、不同拱高下渦強沿弦向分布的比較三、渦格法程序的實現(xiàn)及數(shù)值結果的后處理本文中渦格法程序使用C語言編寫,起初的編寫環(huán)境為linux操作系統(tǒng),編譯工具為gcc。后來為了使用Matlab作圖,于是改用Windows操作系統(tǒng)的MicrosoftVisualC++編譯器進行編譯。由于編譯器的差別,有少量語言規(guī)則不一致,所以需要作一些修改。如在gcc中,可以定義一個含有變量的可變長度數(shù)組,但在MicrosoftVisualC++中則只能定義固定長度的數(shù)組。當然這僅是極小的差別,稍作修改以后程序是可移植的。本文使用渦格法源程序如下#include<stdio.h>//inputandoutputlibrary.#include<math.h>//compilewithgcc,youmustusetheargument"-lm"tolink<math.h>#definepi3.1415926#defineM300#defineN300intgetzp(doublep[],doublex[],doublez[],intnp,doublev0[],doubles,doublec);intinducedu(doubleppa[3],doubleppb[3],doubleppc[3],doubleiu[3]);intinduceduw(doubleppa[3],doublewvvector[3],doubleppc[3],doubleiuw[3]);intsolve(doublea[],doublesolu[],doubleb[],intn);intmain(){inti,j,k,l,I,J,m=15,n=20;double s=2.0,c=1.0;//s:spanlength;c:chordlength.doublev0[3],absv0=1.0;double vv0[3];//vv0:vectoroftheinletflowvelocity.// double a=0.0;// double a=2.5;// double a=5.0;double a=10.0;doublematrix[M*N],rhs[M],sol[M];doubleus[3],uc[3],uw[3],vinduced[3];//horseshoevortexinducedvelocity.double normal[3],pa[3],pb[3],pc[3];//normalvector,pointa,pointb,pointc.doublewvector[3];//wakevortexvector.//writetheresulttothefile!FILE*fp;/*//NACAa=0.8int ip,np=27;//ip:indexofpoint;np:numberofpoint.double xc[27]={0,0.005,0.0075,0.0125,0.025,0.05,0.075,0.1,0.15,0.2,0.25,0.3,0.35,0.4,0.45,0.5,0.55,0.6,0.65,0.7,0.75,0.8,0.85,0.9,0.95,0.975,1.0};double zf[27]={0,0.0423,0.0595,0.0907,0.1586,0.2712,0.3657,0.4482,0.5869,0.6993,0.7905,0.8635,0.9202,0.9615,0.9881,1.0,0.9971,0.9786,0.9434,0.8892,0.8121,0.7087,0.5425,0.3586,0.1713,0.0823,0};doublex[27],z[27],fmax;//x:x-coordinate,z:z-coordinate,fmax:maximumofthef.doubledx,dz,df;//fmax=0.02*c;fmax=0.04*c;for(ip=0;ip<np;ip++){x[ip]=c*xc[ip];z[ip]=fmax*zf[ip];}*//*//arcpropeller!int ip,np=51;//ip:indexofpoint; np:numberofpoint.doublex[51],z[51],fmax;//x:x-coordinate,z:z-coordinate,fmax:maximumofthef.double dx,dz,df;double x0,z0,r;//fmax=0.02*c;fmax=0.04*c;r=(c*c/4.0+fmax*fmax)/(2.0*fmax);x0=c/2.0;z0=fmax-r;for(ip=0;ip<np;ip++){x[ip]=c*ip/(np-1.0);z[ip]=z0+sqrt(r*r-(x[ip]-x0)*(x[ip]-x0));}*///parabolapropellerint ip,np=51;//ip:indexofpoint; np:numberofpoint.doublex[51],z[51],fmax;//x:x-coordinate,z:z-coordinate,fmax:maximumofthef.double dx,dz,df;double a0,a1,a2;//fmax=0.02*c;fmax=0.04*c;a0=0;a1=4.0*fmax/c;a2=-4.0*fmax/(c*c);for(ip=0;ip<np;ip++){x[ip]=c*ip/(np-1.0);z[ip]=a0+a1*x[ip]+a2*x[ip]*x[ip];}//Setvaluestotheinletflowvelocityvectorandthevectoroftheinflowvelocity.v0[0]=absv0*cos(a*pi/180);v0[1]=0.0;v0[2]=absv0*sin(a*pi/180);vv0[0]=cos(a*pi/180);vv0[1]=0.0;vv0[2]=sin(a*pi/180);//Setvaluestothematrix[][],rhs[]andsol[]beforeyouusethem,oryouwillgetweirdvalues.for(I=0;I<M;I++){for(J=0;J<N;J++){matrix[I*M+J]=0.0;}rhs[I]=0.0;sol[I]=0.0;}//Computetheelementvaluesofthematrixandtheright-hand-sidevector.//I:indicatetheinducedvelocitypoint;J:indicatethevortexsegment.for(I=0;I<M;I++){i=I/n;j=I-i*n;//i,j:indicatethemeshlocationoftheinducedvelocitypoint//computethecoordinateofthepointc.pc[0]=(j+0.75)*(c/n);pc[1]=(i+0.5)*(s/m);getzp(pc,x,z,np,vv0,s,c);//getthez-coordinateofthepoint.//Computetheright-hand-sidevector.for(ip=0;ip<np;ip++){if(pc[0]>=x[ip]&&pc[0]<x[ip+1]){dx=x[ip+1]-x[ip];dz=z[ip+1]-z[ip];df=sqrt(dx*dx+dz*dz);normal[0]=-dz/df;//note:itis"-dz/df",not"dz/df".normal[1]=0;normal[2]=dx/df;}}for(k=0;k<3;k++){rhs[I]=rhs[I]-v0[k]*normal[k];}for(J=0;J<N;J++){vinduced[0]=vinduced[1]=vinduced[2]=0.0;i=J/n;j=J-i*n;//i,j:indicatethemeshlocationofthevortexsegment.//computethevortexinducedvelocityiny-coordinate.//computethecoordinateofthepointa.pa[0]=(j+0.25)*(c/n);pa[1]=i*(s/m);getzp(pa,x,z,np,vv0,s,c);//getthez-coordinateofthepoint.//computethecoordinateofthepointb.pb[0]=(j+0.25)*(c/n);pb[1]=(i+1)*(s/m);getzp(pb,x,z,np,vv0,s,c);//getthez-coordinateofthepoint.inducedu(pa,pb,pc,us);//computeus.for(k=0;k<3;k++){vinduced[k]=vinduced[k]+us[k];}//computeuc(i+1).for(l=j;l<2*n;l++){//papa[0]=(l+0.25)*(c/n);pa[1]=(i+1)*(s/m);getzp(pa,x,z,np,vv0,s,c);//pbpb[0]=(l+1+0.25)*(c/n);pb[1]=(i+1)*(s/m);getzp(pb,x,z,np,vv0,s,c);inducedu(pa,pb,pc,uc);//computeuc(i+1).for(k=0;k<3;k++){vinduced[k]=vinduced[k]+uc[k];}//computeuc(i).for(l=j;l<2*n;l++){//papa[0]=(l+0.25)*(c/n);pa[1]=i*(s/m);getzp(pa,x,z,np,vv0,s,c);//pbpb[0]=(l+1+0.25)*(c/n);pb[1]=i*(s/m);getzp(pb,x,z,np,vv0,s,c);inducedu(pa,pb,pc,uc);//computeuc(i).for(k=0;k<3;k++){vinduced[k]=vinduced[k]-uc[k];}}//computeuw(i+1).//papa[0]=(2*n+0.25)*(c/n);pa[1]=(i+1)*(s/m);getzp(pa,x,z,np,vv0,s,c);//setthewakevortexvector.wvector[0]=vv0[0];wvector[1]=vv0[1];wvector[2]=vv0[2];induceduw(pa,wvector,pc,uw);//computeuw(i+1).for(k=0;k<3;k++){vinduced[k]=vinduced[k]+uw[k];}//computeuw(i).//papa[0]=(2*n+0.25)*(c/n);pa[1]=i*(s/m);getzp(pa,x,z,np,vv0,s,c);//wvectorwvector[0]=vv0[0];wvector[1]=vv0[1];wvector[2]=vv0[2];induceduw(pa,wvector,pc,uw);//computeuw(i).for(k=0;k<3;k++){vinduced[k]=vinduced[k]-uw[k];}//Setthematrixvalues.for(k=0;k<3;k++){matrix[I*M+J]=matrix[I*M+J]+vinduced[k]*normal[k];}}//matchesfor(J=0;J<N;J++){}//matchesfor(I=0;I<N;I++){printf("\ntheright-hand-sidevectoris:\n");for(I=0;I<M;I++){printf("(%d)%g",I,rhs[I]);}//SolvethelinearsystemwithSORiterationmethod.solve(matrix,sol,rhs,M);fp=fopen("4p100.txt","w");//themeaningofthename:'2'meansfmax=0.02*c;'n'meansNACAa=0.8propeller;'00'meanstheangleoftheinletvelocitya=0.0//inthesameway,'4'meansfmax=0.04*c;'a'meansarcpropeller;'p'meansparabolapropeller;//'25'meansa=2.5;'50'meansa=5.0;'100'meansa=10.0;//writethehorseshoevortexintensitydistributionofthemiddlepropelleriny-coordinate.for(I=((m-1)/2)*n;I<((m-1)/2+1)*n;I++){ //note:itis((m-1)/2)*n,not((m+1)/2)*n.fprintf(fp,"%f%g\n",(I%n+0.75)/n,sol[I]);}fclose(fp);return0;}//Ggetzp(doublep[],doublex[],doublez[],intnp,doublevv0[],doubles,doublec){if(p[0]>=0.0&&p[0]<=c){int ip;//ip:indexofpoint.double dx,dz;for(ip=0;ip<np;ip++){if(p[0]>=x[ip]&&p[0]<x[ip+1]){dx=x[ip+1]-x[ip];dz=z[ip+1]-z[ip];p[2]=z[ip]+dz*(p[0]-x[ip])/dx;//interpolatingthez-coordinateofthepoint.}}}else{inti;doublealpha;//avariablewhosevalueisbetween0and1.doublevt[3],vw[3];doublea[3],b[3];doubledx,dz,df;alpha=2*(p[1]/s-0.5)*(p[1]/s-0.5);//inordertodiscriptionthewakevortexdeformation.dx=x[np-1]-x[np-2];dz=z[np-1]-z[np-2];df=sqrt(dx*dx+dz*dz);vt[0]=dx/df;vt[1]=0.0;vt[2]=dz/df;for(i=0;i<3;i++){vw[i]=alpha*vv0[i]+(1-alpha)*vt[i];}b[0]=vw[2]/vw[0];//computetheslopeofthevector.b[1]=vv0[2]/vv0[0];b[2]=0.0;//solvethelinearsystembyanaliticalmethod.a[0]=(b[1]-b[0])/(2*c);a[1]=b[1]-4*a[0]*c;a[2]=b[2]-a[0]*c*c-a[1]*c;p[2]=a[0]*p[0]*p[0]+a[l]*p[0]+a[2];//z=al*xA2+a2*x+a3}return0;}//computethehorseshoevortexinducedvelocityonthesufaceofthepropeller,inducedu(doubleppa[3],doubleppb[3],doubleppc[3],doubleiu[3])//note:abisvortex,pointcisinducedvelocitypoint.{doublea,b,c,d,e,v;doubleavector[3],cvector[3],vvector[3];//vvector=(avectorXcvector)/(a*d).a=sqrt(pow(ppb[0]-ppa[0],2)+pow(ppb[l]-ppa[l],2)+pow(ppb[2]-ppa[2],2));//a=||pb-pa||b=sqrt(pow(ppb[0]-ppc[0],2)+pow(ppb[l]-ppc[l],2)+pow(ppb[2]-ppc[2],2));//b=||pb-pc||c=sqrt(pow(ppa[0]-ppc[0],2)+pow(ppa[l]-ppc[l],2)+pow(ppa[2]-ppc[2],2));//c=||pa-pc||e=(a*a+c*c-b*b)/(2*a);d=sqrt(c*c-e*e);//thedistancefromthepointctothevortexsegment.//Computetheabsolutevalueoftheinducedvelocity.//note:d=sqrt(c*c-e*e),maybed>=0.0l*cisareasonablejudgementcriteria!if(d>=0.0l*c){v=((e/c)+(a-e)/b)/(4*pi*d);}elseif(e<0){v=(l.0/(e*e)-l.0/pow(a-e,2))*d/(8*pi);//note:itis"l.0/(e*e)",not"l.0/e*e"!}else{v=(l.0/pow(a-e,2)-l.0/(e*e))*d/(8*pi);//note:itis"l.0/(e*e)",not"l.0/e*e"!}//Computethevectoroftheinducedvalue.//note:"avectorXcvector"isequalto"avectorXdvector".avector[0]=ppb[0]-ppa[0];avector[1]=ppb[1]-ppa[1];avector[2]=ppb[2]-ppa[2];//ppa-->ppbcvector[0]=ppc[0]-ppa[0];cvector[1]=ppc[1]-ppa[1];cvector[2]=ppc[2]-ppa[2];//ppa-->ppc//vvector=(avectorXcvector)/(a*d).note:"X"(multiplicationcross,crossproduct)vvector[0]=(avector[1]*cvector[2]-avector[2]*cvector[1])/(a*d);vvector[1]=-(avector[0]*cvector[2]-avector[2]*cvector[0])/(a*d);vvector[2]=(avector[0]*cvector[1]-avector[1]*cvector[0])/(a*d);iu[0]=v*vvector[0];iu[1]=v*vvector[1];iu[2]=v*vvector[2];return0;}//Subroutineinduceduw():induceduw(doubleppa[3],doublewvvector[3],doubleppc[3],doubleiuw[3]){intk;doublec,d,e,v;doublecvector[3],vvector[3];c=sqrt(pow(ppa[0]-ppc[0],2)+pow(ppa[1]-ppc[1],2)+pow(ppa[2]-ppc[2],2));//c=||pa-pc||cvector[0]=ppc[0]-ppa[0];cvector[1]=ppc[1]-ppa[1];cvector[2]=ppc[2]-ppa[2];//ppa-->ppce=0.0;for(k=0;k<3;k++){e+=cvector[k]*wvvector[k];//e=cvector[]multiplicationdot(innerproduct)wvvector[].}d=sqrt(c*c-e*e);//Computetheabsolutevalueoftheinducedvelocity.if(d>=0.01*c){v=(e/c+1)/(4*pi*d);}elseif(e<0){v=d/(8*pi*e*e);}else{v=(2-d*d/(2*e*e))/(4*pi*d);}//Computethevectoroftheinducedvalue.//vvector=(wvvectorXcvector)/d.note:"X"(multiplicationcross,crossproduct)vvector[0]=(wvvector[1]*cvector[2]-wvvector[2]*cvector[1])/d;vvector[1]=-(wvvector[0]*cvector[2]-wvvector[2]*cvector[0])/d;vvector[2]=(wvvector[0]*cvector[1]-wvvector[1]*cvector[0])/d;//Computethewakevortexinducedvelocity.iuw[0]=v*vvector[0];iuw[1]=v*vvector[1];iuw[2]=v*vvector[2];return0;}//SolvethelinearsystemwithSORsolve(doublea[],doublesolu[],doubleb[],intn){inti,j,k,NN=1000;//now"N"isaconstant.doublee=1e-5,w=1.0;//e:thecriteriaoftheconvergence;w:relaxationvariable.doublet[M];//cannotallocateanarrayofconstantsize0 >t[n]doublesum=0.0;//m=0;for(k=0;k<NN&&m!=n;k++){m=0
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度電力系統(tǒng)電力物資安全儲存與運輸合同3篇
- 二零二五年建筑公司內(nèi)部工程承包合同范本5篇
- 臨時服務協(xié)議:專項工作期間合作意向書版A版
- 2025年度農(nóng)家樂鄉(xiāng)村旅游服務合同范本3篇
- 2024版有關房屋分配協(xié)議書
- 2024租賃期滿設備回收合同
- 二零二五年租房合同涉及的環(huán)保要求3篇
- 二零二五版出租車行業(yè)駕駛員勞動合同執(zhí)行規(guī)范6篇
- 二零二五年能源設施工程設計合同補充協(xié)議3篇
- 2024版智能可穿戴設備設計與生產(chǎn)合同
- 《世界史通史溫習》課件
- 人教版初中語文2022-2024年三年中考真題匯編-學生版-專題08 古詩詞名篇名句默寫
- 2024-2025學年人教版(2024)七年級(上)數(shù)學寒假作業(yè)(十二)
- 山西粵電能源有限公司招聘筆試沖刺題2025
- 第2課 各種各樣的運動(說課稿)-2023-2024學年三年級下冊科學教科版
- 醫(yī)療行業(yè)軟件系統(tǒng)應急預案
- 股權質(zhì)押權借款合同模板
- 2025年中國社區(qū)團購行業(yè)發(fā)展環(huán)境、運行態(tài)勢及投資前景分析報告(智研咨詢發(fā)布)
- 建材行業(yè)綠色建筑材料配送方案
- 使用錯誤評估報告(可用性工程)模版
- 放射性藥物專題知識講座培訓課件
評論
0/150
提交評論