欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    一维黎曼问题数值解与计算程序(共12页).doc

    • 资源ID:5239825       资源大小:327KB        全文页数:12页
    • 资源格式: DOC        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    一维黎曼问题数值解与计算程序(共12页).doc

    精选优质文档-倾情为你奉上一维问题数值解与计算程序一维问题,即激波管问题,是一个典型的一维可压缩无黏气体动力学问题,并有 解析解。对它采用二阶精度两步差分格式进行数值求解。同时,为了初学者入门和练习方便,这里给出了用语言和编写的计算一维问题的计算程序,供大家学习参考。A-1利用两步差分格式求解一维问题1.一维问题图A.1 激波管问题示意图一维问题实际上就是激波管问题。激波管是一根两端封闭、内部充满气体的直管,如图A.1所示。在直管中由一薄膜将激波管隔开,在薄膜两侧充有均匀理想气体(可以是同一种气体,也可以是不同种气体),薄膜两侧气体的压力、密度不同。当时,气体处于静止状态。当时,薄膜瞬时突然破裂,气体从高压端冲向低压端,同时在管内形成激波、稀疏波和接触间断等复杂波系。2.基本方程组、初始条件和边界条件设气体是理想气体。一维问题在数学上可以用一维可压缩无黏气体方程组来描述。在直角坐标系下量纲为一的一维方程组为: (A.1)其中 (A.2) 这里、分别是流体的密度、速度、压力和单位体积总能。理想气体状态方程: (A.3)初始条件:;。边界条件:和处为自由输出条件,,。3.二阶精度差分格式两步差分格式: (A.4)其中。计算实践表明,两步差分格式不能抑制激波附近非物理振荡。因此在计算激波时,必须采用人工黏性滤波方法: (A.5)为了在激波附近人工黏性起作用,而在光滑区域人工黏性为零,需要引入一个与密度(或者压力)相关的开关函数: (A.6)由式(A.6) 可以看出,在光滑区域,密度变化很缓,因此值也很小;而在激波附近密度变化很陡,值就很大。带有开关函数的前置人工黏性滤波方法为: (A.7)其中参数往往需要通过实际试算来确定,也可采用线性近似方法得到:(A.8)由于声速不会超过3,所以取,在本计算中取。4.计算结果分析计算分别采用标准的语言和语言编写程序。计算中网格数取,计算总时间为。计算得到在时刻的密度、速度和压力分布如图A.2(语言计算结果)和图A.3(语言计算结果)所示。采用两种不同语言编写程序所得到的计算结果完全吻合。从图A.2和图A.3中可以发现,两步差分格式能很好地捕捉激波,计算得到的激波面很陡、很窄,计算激波精度是很高的。采用带开关函数的前置人工滤波法能消除激波附近的非物理振荡,计算效果很好。从图A.2和图A.3中可以看出通过激波后气体的密度、压力和速度都是增加的;在压力分布中存在第二个台阶,表明在这里存在一个接触间断,在接触间断两侧压力是有间断的,而密度和速度是相等的。这个计算结果正确地反映了一维问题的物理特性,并被激波管实验所验证。 图A.2采用语言程序得到的一维问题密度、速度和压力分布图A.3采用语言程序得到的一维问题密度、速度和压力分布A-2 一维问题数值计算源程序1. 语言源程序/ MacCormack1D.cpp : 定义控制台应用程序的入口点。/*-*利用差分格式求解一维激波管问题(语言版本)* -*/#include "stdafx.h" #include <stdio.h>#include <stdlib.h>#include <math.h>#define GAMA 1.4/气体常数#define PI 3.#define L 2.0/计算区域#define TT 0.4/总时间#define Sf 0.8/时间步长因子#define J 1000/网格数/全局变量double UJ+23,UfJ+23,EfJ+23;/*-计算时间步长入口: U,当前物理量,dx,网格宽度;返回: 时间步长。-*/double CFL(double UJ+23,double dx) int i; double maxvel,p,u,vel; maxvel=1e-100; for(i=1;i<=J;i+) u=Ui1/Ui0; p=(GAMA-1)*(Ui2-0.5*Ui0*u*u); vel=sqrt(GAMA*p/Ui0)+fabs(u); if(vel>maxvel)maxvel=vel; return Sf*dx/maxvel;/*-初始化入口: 无;出口: U, 已经给定的初始值, dx, 网格宽度。-*/void Init(double UJ+23,double & dx) int i; double rou1=1.0 ,u1=0.0,p1=1.0; /初始条件 double rou2=0.125,u2=0.0,p2=0.1; dx=L/J; for(i=0;i<=J/2;i+) Ui0=rou1; Ui1=rou1*u1; Ui2=p1/(GAMA-1)+rou1*u1*u1/2; for(i=J/2+1;i<=J+1;i+) Ui0=rou2; Ui1=rou2*u2; Ui2=p2/(GAMA-1)+rou2*u2*u2/2; /*-边界条件入口: dx,网格宽度;出口: U, 已经给定的边界。-*/void bound(double UJ+23,double dx) int k; /左边界 for(k=0;k<3;k+)U0k=U1k; /右边界 for(k=0;k<3;k+)UJ+1k=UJk;/*-根据U计算E入口: U, 当前U矢量;出口: E, 计算得到的E矢量,U、E的定义见Euler方程组。-*/void U2E(double U3,double E3) double u,p; u=U1/U0; p=(GAMA-1)*(U2-0.5*U1*U1/U0); E0=U1; E1=U0*u*u+p; E2=(U2+p)*u;/*-一维差分格式求解器入口: U, 上一时刻的U矢量,Uf、Ef,临时变量, dx,网格宽度,dt, 时间步长;出口: U, 计算得到的当前时刻U矢量。-*/void MacCormack_1DSolver(double UJ+23,double UfJ+23,double EfJ+23,double dx,double dt) int i,k; double r,nu,q; r=dt/dx; nu=0.25; for(i=1;i<=J;i+) q=fabs(fabs(Ui+10-Ui0)-fabs(Ui0-Ui-10) /(fabs(Ui+10-Ui0)+fabs(Ui0-Ui-10)+1e-100); /开关函数 for(k=0;k<3;k+) Efik=Uik+0.5*nu*q*(Ui+1k-2*Uik+Ui-1k);/人工黏性项 for(k=0;k<3;k+) for(i=1;i<=J;i+)Uik=Efik; for(i=0;i<=J+1;i+)U2E(Ui,Efi); for(i=0;i<=J;i+) for(k=0;k<3;k+) Ufik=Uik-r*(Efi+1k-Efik); /U(n+1/2)(i+1/2) for(i=0;i<=J;i+)U2E(Ufi,Efi); /E(n+1/2)(i+1/2) for(i=1;i<=J;i+) for(k=0;k<3;k+) Uik=0.5*(Uik+Ufik)-0.5*r*(Efik-Efi-1k); /U(n+1)(i) /*-输出结果, 用数据格式画图入口: U, 当前时刻U矢量,dx, 网格宽度;出口: 无。-*/void Output(double UJ+23,double dx) int i; FILE *fp; double rou,u,p; fp=fopen("result.txt","w"); for(i=0;i<=J+1;i+) rou=Ui0; u=Ui1/rou; p=(GAMA-1)*(Ui2-0.5*Ui0*u*u); fprintf(fp,"%20f%20.10e%20.10e%20.10e%20.10en",i*dx,rou,u,p,Ui2); fclose(fp);/*-主函数入口: 无;出口: 无。-*/void main() double T,dx,dt; Init(U,dx); T=0; while(T<TT) dt=CFL(U,dx); T+=dt; printf("T=%10g dt=%10gn",T,dt); MacCormack_1DSolver(U,Uf,Ef,dx,dt); bound(U,dx); Output(U,dx);-2. 语言源程序! MacCormack1D.for -!利用差分格式求解一维激波管问题(语言版本) -*/ program MacCormack1D implicit double precision (a-h,o-z) parameter (M=1000) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:M+1,0:2),Uf(0:M+1,0:2) dimension Ef(0:M+1,0:2)!气体常数 GAMA=1.4 PI=3.!网格数 J=M!计算区域 dL=2.0!总时间 TT=0.4!时间步长因子 Sf=0.8 call Init(U,dx) T=01 dt=CFL(U,dx) T=T+dt write(*,*)'T=',T,'dt=',dt call MacCormack_1D_Solver(U,Uf,Ef,dx,dt)call bound(U,dx) if(T.lt.TT)goto 1 call Output(U,dx) end!-!计算时间步长!入口: U, 当前物理量,dx, 网格宽度;!返回: 时间步长。!- double precision function CFL(U,dx) implicit double precision (a-h,o-z) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:J+1,0:2) dmaxvel=1e-10 do 10 i=1,J uu=U(i,1)/U(i,0) p=(GAMA-1)*(U(i,2)-0.5*U(i,0)*uu*uu) vel=dsqrt(GAMA*p/U(i,0)+dabs(uu) if(vel.gt.dmaxvel)dmaxvel=vel10 continue CFL=Sf*dx/dmaxvel end !-!初始化!入口: 无;!出口: U, 已经给定的初始值,dx,网格宽度。!- subroutine Init(U,dx) implicit double precision (a-h,o-z) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:J+1,0:2)!初始条件 rou1=1.0 u1=0 v1=0 p1=1.0 rou2=0.125 u2=0 v2=0 p2=0.1 dx=dL/J do 20 i=0,J/2 U(i,0)=rou1 U(i,1)=rou1*u1 U(i,2)=p1/(GAMA-1)+0.5*rou1*u1*u120 continue do 21 i=J/2+1,J+1 U(i,0)=rou2 U(i,1)=rou2*u2 U(i,2)=p2/(GAMA-1)+0.5*rou2*u2*u221 continue end!-!边界条件!入口: dx,网格宽度;!出口: U, 已经给定边界。!- subroutine bound(U,dx) implicit double precision (a-h,o-z) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:J+1,0:2)!左边界 do 30 k=0,2 U(0,k)=U(1,k)30 continue!右边界 do 31 k=0,2 U(J+1,k)=U(J,k)31 continue end!-!根据U计算E!入口: U,当前U矢量;!出口: E,计算得到的E矢量,! U、E定义见Euler方程组。!- subroutine U2E(U,E,is,in) implicit double precision (a-h,o-z) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:J+1,0:2),E(0:J+1,0:2) do 40 i=is,in uu=U(i,1)/U(i,0) p=(GAMA-1)*(U(i,2) $ -0.5*U(i,1)*U(i,1)/U(i,0) E(i,0)=U(i,1) E(i,1)=U(i,0)*uu*uu+p E(i,2)=(U(i,2)+p)*uu40 continue end!-!一维差分格式求解器!入口: U, 上一时刻U矢量,! Uf、Ef,临时变量,! dx,网格宽度,dt,,时间步长;!出口: U, 计算得到得当前时刻U矢量。!- subroutine MacCormack_1D_Solver(U,Uf,Ef,dx,dt) implicit double precision (a-h,o-z) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:J+1,0:2),Uf(0:J+1,0:2) dimension Ef(0:J+1,0:2) r=dt/dx dnu=0.25 do 60 i=1,J do 60 k=0,2!开关函数 q=dabs(dabs(U(i+1,0)-U(i,0)-dabs(U(i,0)-U(i-1,0) $ /(dabs(U(i+1,0)-U(i,0)+dabs(U(i,0)-U(i-1,0)+1e-10)!人工黏性项 Ef(i,k)=U(i,k)+0.5*dnu*q*(U(i+1,k)-2*U(i,k)+U(i-1,k) 60 continue do 61 k=0,2 do 61 i=1,J U(i,k)=Ef(i,k)61 continue call U2E(U,Ef,0,J+1) do 63 i=0,J do 63 k=0,2!U(n+1/2)(i+1/2) Uf(i,k)=U(i,k)-r*(Ef(i+1,k)-Ef(i,k)63 continue !E(n+1/2)(i+1/2) call U2E(Uf,Ef,0,J) do 64 i=1,J do 64 k=0,2!U(n+1)(i) U(i,k)=0.5*(U(i,k)+Uf(i,k)-0.5*r*(Ef(i,k)-Ef(i-1,k) 64 continue end!-!输出结果, 用数据格式画图!入口: U, 当前时刻U矢量,! dx,网格宽度;!出口: 无。!- subroutine Output(U,dx) implicit double precision (a-h,o-z) common /G_def/ GAMA,PI,J,JJ,dL,TT,Sf dimension U(0:J+1,0:2) open(1,file='result.txt',status='unknown') do 80 i=0,J+1 rou=U(i,0) uu=U(i,1)/rou p=(GAMA-1)*(U(i,2)-0.5*U(i,0)*uu*uu) write(1,81)i*dx,rou,uu,p,U(i,2)80 continue close(1) 81 format(D20.10,D20.10,D20.10,D20.10,D20.10) end-专心-专注-专业

    注意事项

    本文(一维黎曼问题数值解与计算程序(共12页).doc)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开