DFLUX调用应力应变的问题

浏览:7507 回答:2
大神们好!我正在编写一个DFLUX,FLUX(1)是关于应力应变的方程,运行的时候总提醒有错误,方程为
q=( α^2X ΩX ε^2XE)/2
其中,E=( σ/ ε)*sin(d)
σ为应力, ε为应变,是上一增量步的输出结果。
我写的程序如下
SUBROUTINE DFLUX(FLUX,SOL,JSTEP,JINC,TIME,NOEL,NPT,COORDS,JLTYP,
1 TEMP,PRESS,SNAME)
C
INCLUDE 'ABA_PARAM.INC'
C
PARAMETER(TWO=2.d0)
DIMENSION COORDS(3),FLUX(2),TIME(2)
CHARACTER*80 SNAME
FLUX(1)=0
PI=3.1415926
ALPHA=0.9
OMEGA=20000*2*PI
D=OMEGA*0.0000125
c Heat generation
CALL SPRINC(S,PS,2,NDI,NSHR)
c Get the strain
EPS=SQRT(2*(PS(1)+PS(2)+PS(3))/3)
CALL SPRINC(S,PS,1,NDI,NSHR)
c Get the stress
S=SQRT((PS(1)-PS(2))**2+(PS(2)-PS(3))**2+(PS(3)-PS(1))**2)/2)
MODULUS=(S/EPS)*SIN(D)
c Generate heat
FLUX(1)=ALPHA**2*OMEGA*EPS**2*MODULUS/TWO
RETURN
END SUBROUTINE DFLUX
总觉得是在CALL SPRINC那里有问题,不知道应力应变是不是这样调用。
感谢!

邀请回答 我来回答

全部回答

(2)
默认 最新
xiaoniudashu
楼主,我是刚开始学习这个DFLUX,能否将您完善后的程序发上来供我们学习一下,谢谢!:D
2015年2月6日
评论 点赞
十番队长
我已经知道怎么做了,写一个USFLD,在里面调用,然后定义 common block,传递给别的子程序
2015年2月1日
评论 点赞

没解决?试试专家一对一服务

换一批
    App下载
    技术邻APP
    工程师必备
    • 项目客服
    • 培训客服
    • 平台客服

    TOP