24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 864  |  回复: 3

zouji1983

金虫 (正式写手)

[求助] fortran error求助

当我在debug mode下debug我的fortran code时,出现erro‘user breakpoint called from code 07c90120e’,同时在黑屏里出现'run-time error M6201:MATH-floorOMAIN error'. 网上查了一些资源,也没有找到解,请高手指点,多谢!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

至尊木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
贴代码吧

出错信息,不同的编译器是不同的。
2楼2012-09-13 15:00:20
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zouji1983

金虫 (正式写手)

嗯。谢谢!代码如下:
module thermodynamics

        use global
        use numlib

        implicit none

contains

        !*******************************************************************************************
        !        SUBROUTINE CONVERT_COMPOSITION
        !        This subroutine calculates the local phase concentrations at point (ix,iy) based on the
        !        equality of diffusion potential of that component in all phases and a mass balance.
        !
        ! STATUS : ONLY FOR UP TO THREE COMPONENTS
        !*******************************************************************************************
        subroutine convert_composition(ix,iy)
                integer :: ix, iy, i
                real(8) :: r
                real(8), dimension(1:np*(nc-1)) :: sol, RT
                real(8), dimension(1:np*(nc-1),1:np*(nc-1)) :: coeff
                integer, dimension(1:np*(nc-1)) :: IPIV
               
                coeff = 0.d0
       
                coeff(1,1) = dmudx(1,1,1,ix,iy)
                coeff(1,2) = -dmudx(1,1,2,ix,iy)
                coeff(1,3) = dmudx(1,2,1,ix,iy)
                coeff(2,1) = dmudx(1,2,1,ix,iy)
                coeff(2,3) = dmudx(2,2,1,ix,iy)
                coeff(2,4) = -dmudx(2,2,2,ix,iy)
                coeff(3,1) = phi(1,ix,iy)
                coeff(3,2) = phi(2,ix,iy)
                coeff(4,3) = phi(1,ix,iy)
                coeff(4,4) = phi(2,ix,iy)

                RT(1) = dmudx(1,1,1,ix,iy)*xp(1,1,ix,iy) + dmudx(1,2,1,ix,iy)*xp(2,1,ix,iy) - mu(1,1,ix,iy) - dmudx(1,1,2,ix,iy)*xp(1,2,ix,iy) - dmudx(1,2,2,ix,iy)*xp(2,2,ix,iy) + mu(1,2,ix,iy)
                RT(2) = dmudx(2,2,1,ix,iy)*xp(2,1,ix,iy) + dmudx(1,2,1,ix,iy)*xp(1,1,ix,iy) - mu(2,1,ix,iy) - dmudx(2,2,2,ix,iy)*xp(2,2,ix,iy) - dmudx(1,2,2,ix,iy)*xp(1,2,ix,iy) + mu(2,2,ix,iy)
                RT(3) = x(1,ix,iy,old)
                RT(4) = x(2,ix,iy,old)

                sol = RT(

                call ludcmp(coeff,np*(nc-1),np*(nc-1),IPIV,r)
                call lubksb(coeff,np*(nc-1),np*(nc-1),IPIV,sol)

                xp(1,1:2,ix,iy) = sol(1:2)
                xp(2,1:2,ix,iy) = sol(3:4)

        end subroutine convert_composition

        !*******************************************************************************************
        !        FUNCTION DMUDX
        !        This function retrieves the derivative of the diffusion potential mu_{iu}^{ip} with
        !        respect to the concentration variable x_{iv}^{ip}
        !
        ! STATUS : FINAL FOR 3-COMPONENT SYSTEM --> only i,j
        !*******************************************************************************************
        function dmudx(iu,iv,ip,ix,iy)
                integer :: iu, iv, ip, ix, iy, i, j
                real(8) :: dmudx       
                i = floor(xp(1,ip,ix,iy)/thermo_dx+0.5d0)+1        ! x1
                j = floor(xp(2,ip,ix,iy)/thermo_dx+0.5d0)+1        ! x2

                if (ip == 2) then
                ! Wollastonite @ 1320C
                        if (iu == iv) then
                                dmudx = 2.d11
                        else
                                dmudx = 0.d0
                        end if
                else
                        if (iu == iv) then
                                dmudx = (((A(iu,thermo_p(ip),i+1,j+1)-A(iu,thermo_p(ip),i,j+1))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+A(iu,thermo_p(ip),i,j+1))-((A(iu,thermo_p(ip),i+1,j)-A(iu,thermo_p(ip),i,j))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+A(iu,thermo_p(ip),i,j)))/thermo_dx*(xp(2,ip,ix,iy)-(j-1)*thermo_dx)+((A(iu,thermo_p(ip),i+1,j)-A(iu,thermo_p(ip),i,j))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+A(iu,thermo_p(ip),i,j))
                        else
                                dmudx = (((B(iu,iv,thermo_p(ip),i+1,j+1)-B(iu,iv,thermo_p(ip),i,j+1))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+B(iu,iv,thermo_p(ip),i,j+1))-((B(iu,iv,thermo_p(ip),i+1,j)-B(iu,iv,thermo_p(ip),i,j))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+B(iu,iv,thermo_p(ip),i,j)))/thermo_dx*(xp(2,ip,ix,iy)-(j-1)*thermo_dx)+((B(iu,iv,thermo_p(ip),i+1,j)-B(iu,iv,thermo_p(ip),i,j))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+B(iu,iv,thermo_p(ip),i,j))
                        end if
                end if

        end function dmudx

        !*******************************************************************************************
        !        FUNCTION MU
        !        This function retrieves the diffusion potential for component k in phase i from linear
        !        interpolation from the descretized tables for the chemical potential
        !         (CHPOT in the program and input/MU_.txt files)
        !
        ! STATUS : FINAL FOR 3-COMPONENT SYSTEM --> only i,j
        !*******************************************************************************************
        function mu(iu,ip,ix,iy)
                integer :: iu, ip, ix, iy, i, j
                real(8) :: mu       
                i = floor(xp(1,1,ix,iy)/thermo_dx+0.5d0)+1        ! x1
                j = floor(xp(2,1,ix,iy)/thermo_dx+0.5d0)+1        ! x2

                if (ip == 2) then
                ! Wollastonite @ 1320C
                        if (iu == 1) then
                                mu = dmudx(1,1,2,ix,iy)*xp(1,ip,ix,iy) - .8915873511e11
                        else
                                mu = dmudx(2,2,2,ix,iy)*xp(2,ip,ix,iy) - .3652507619e11
                        end if
                else
                        mu = (((CHPOT(iu,thermo_p(1),i+1,j+1)-CHPOT(iu,thermo_p(1),i,j+1))/(thermo_dx)*(xp(1,1,ix,iy)-(i-1)*thermo_dx)+CHPOT(iu,thermo_p(1),i,j+1))-((CHPOT(iu,thermo_p(1),i+1,j)-CHPOT(iu,thermo_p(1),i,j))/(thermo_dx)*(xp(1,1,ix,iy)-(i-1)*thermo_dx)+CHPOT(iu,thermo_p(1),i,j)))/thermo_dx*(xp(2,1,ix,iy)-(j-1)*thermo_dx)+((CHPOT(iu,thermo_p(1),i+1,j)-CHPOT(iu,thermo_p(1),i,j))/(thermo_dx)*(xp(1,1,ix,iy)-(i-1)*thermo_dx)+CHPOT(iu,thermo_p(1),i,j))
                end if

        end function mu

        !*******************************************************************************************
        !        FUNCTION F
        !        This function retrieves the gibbs energy for phase i from linear interpolation from
        !        the descretized tables for the gibbs free energy
        !
        ! STATUS : FINAL FOR 3-COMPONENT SYSTEM --> only i,j
        !*******************************************************************************************
        function f(ip,ix,iy)
                integer :: ip, ix, iy, i, j
                real(8) :: f
                i = floor(xp(1,ip,ix,iy)/thermo_dx+0.5d0)+1        ! x1
                j = floor(xp(2,ip,ix,iy)/thermo_dx+0.5d0)+1        ! x2

                if (ip == 2) then
                ! Wollastonite @ 1320C
                        f = dmudx(1,1,2,ix,iy)/2.d0*xp(1,ip,ix,iy)**2+dmudx(2,2,2,ix,iy)/2.d0*xp(2,ip,ix,iy)**2-.8915873511e11*xp(1,ip,ix,iy)-.3652507619e11*xp(2,ip,ix,iy) - .2093397165e11
                else
                        f = (((GIBBS(thermo_p(ip),i+1,j+1)-GIBBS(thermo_p(ip),i,j+1))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+GIBBS(thermo_p(ip),i,j+1))-((GIBBS(thermo_p(ip),i+1,j)-GIBBS(thermo_p(ip),i,j))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+GIBBS(thermo_p(ip),i,j)))/thermo_dx*(xp(2,ip,ix,iy)-(j-1)*thermo_dx)+((GIBBS(thermo_p(ip),i+1,j)-GIBBS(thermo_p(ip),i,j))/(thermo_dx)*(xp(1,ip,ix,iy)-(i-1)*thermo_dx)+GIBBS(thermo_p(ip),i,j))
                end if

        end function f
               
end module thermodynamics
3楼2012-09-13 15:37:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zouji1983

金虫 (正式写手)

代码比较多,谢谢!
4楼2012-09-13 15:38:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 zouji1983 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料专硕(0856) 339分求调剂 +10 哈哈哈鹅哈哈哈 2026-04-04 10/500 2026-04-05 18:51 by 蓝云思雨
[考研] 315求调剂 +13 欣喜777 2026-04-04 14/700 2026-04-05 18:48 by liuying2007
[考研] 307分材料专业求调剂 +7 Hll胡 2026-04-05 7/350 2026-04-05 18:47 by 无际的草原
[考研] 348求调剂 +6 wukira 2026-04-04 6/300 2026-04-05 18:11 by 猪会飞
[考研] 085600调剂 +9 东照照照 2026-04-04 9/450 2026-04-05 13:44 by ujn_zhuj
[考研] 化学357分,考研调剂 +10 .Starry. 2026-04-04 11/550 2026-04-05 10:57 by cql1109
[考研] 数一英一 347 人工智能国奖论文都有求调剂 +3 乌拉儿山脉 2026-03-30 7/350 2026-04-05 10:32 by zhq0425
[考研] 一志愿电子科技大学085600材料与化工 329分求调剂 +10 Naiko 2026-04-04 10/500 2026-04-05 09:40 by sam3303
[考研] 290求调剂 +7 luoziheng 2026-04-04 7/350 2026-04-04 23:17 by lqwchd
[考研] 315求调剂 +13 小羊小羊_ 2026-04-02 14/700 2026-04-04 20:30 by 蓝云思雨
[考研] 348分环境工程·调剂 +10 吴彦祖24k 2026-04-03 11/550 2026-04-04 14:19 by 无际的草原
[考研] 387求调剂 +4 爱吃片豆土 2026-04-03 5/250 2026-04-04 08:10 by 岸上的一条鱼
[考研] 一志愿北京交通大学材料工程总分358 +4 cs0106 2026-04-03 4/200 2026-04-03 13:41 by 百灵童888
[考研] 085600,320分求调剂 +6 大馋小子 2026-04-02 6/300 2026-04-02 21:54 by dongzh2009
[考研] 362求调剂 +14 西南交材料专硕3 2026-03-31 14/700 2026-04-02 17:50 by yunlongyang
[考研] 一志愿郑大材料工程290求调剂 +20 Youth_ 2026-03-30 20/1000 2026-04-02 14:48 by 5896
[考研] 材料调剂 +12 一样YWY 2026-04-01 12/600 2026-04-02 09:15 by olim
[考研] 一志愿346上海大学生物学 +3 上海大学346调剂 2026-04-01 3/150 2026-04-02 08:36 by w虫虫123
[考研] 生物学327,求调剂 +5 书上的梅子 2026-04-01 6/300 2026-04-02 06:47 by ilovexiaobin
[考研] 285求调剂 +7 AZMK 2026-03-30 13/650 2026-04-01 17:00 by 七度不信任
信息提示
请填处理意见