mr d661 2022-04-17 19:17 采纳率: 100%
浏览 171
已结题

耦合对流弥散方程差分法求解

想采用差分法求解以下方程

img

采用了以下显式差分方法

img

求解结果不稳定

希望有专家能指点正确的差分格式

  • 写回答

3条回答 默认 最新

  • joel_1993 2022-04-17 22:26
    关注

    你好,这个差分格式可以这么写的

    img

    边界条件是要注意的,我用的格式可能跟你的不一样。
    当然用显式差分格式是比较方便的
    下面是我的试验代码:

    clc; clear
    L = 1;
    nx = 101;
    x = linspace(0, L, nx);
    tf = 1;
    nt = 100000;
    t = linspace(0, tf, nt);
    C = zeros(nt, nx);
    S = zeros(nt, nx);
    theta_w = 1;
    rho_b = 1;
    S_max = 1;
    k_att  = 1;
    k_det = 1;
    C0 = 1;
    vp = 1;
    D = 1;
    dx = mean(diff(x));
    dt = mean(diff(t));
    for i = 1:nt-1
        C(i,1) = C0;
        dSdt = theta_w/rho_b*((S_max - S(i,:))/S_max*k_att.*C(i,:) - rho_b/theta_w*k_det*S(i,:));
        S(i+1,:) = S(i,:) + dSdt*dt;
        dCdt = zeros(size(dSdt));
        dCdt(2:end-1) = D*conv(C(i,:), [1,-2,1], 'valid')/(dx)^2 - ...
            vp * conv(C(i,:), [-1,0,1], 'valid')/2/dx - rho_b/theta_w*dSdt(2:end-1);
        C(i+1, 2:end-1) = C(i,2:end-1) + dCdt(2:end-1)*dt;
        C(i+1,1) = C0;
        C(i+1,nx) = C(i, nx);
    end
    

    可见当时间步离散的足够小,这个算法是收敛的,而且很稳定

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月27日
  • 已采纳回答 4月19日
  • 赞助了问题酬金95元 4月17日
  • 创建了问题 4月17日

悬赏问题

  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 求螺旋焊缝的图像处理
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?