Skip to content
  • 最新
  • 版块
  • 东岳流体
  • 随机看[请狂点我]
皮肤
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(不使用皮肤)
  • 不使用皮肤
折叠
CFD中文网

CFD中文网

  1. CFD中文网
  2. OpenFOAM
  3. Interface到底是做什么的呢?

Interface到底是做什么的呢?

已定时 已固定 已锁定 已移动 OpenFOAM
5 帖子 2 发布者 1.6k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • W 离线
    W 离线
    w352405196
    写于2024年12月31日 07:23 最后由 李东岳 编辑 2024年12月31日 21:49
    #1

    新手请教各位老师,AX=B,边界条件的影响不是应该加到稀疏矩阵A的对角系数和源项B中了吗,initMatrixInterfaces和updateMatrixInterfaces是什么作用呢,针对特定边界条件吗?汽车的算例,我测试X和B都没有发生改变

    initMatrixInterfaces
    (
    bouCoeffsCmpt,
    interfaces,
    psiCmpt,
    sourceCmpt,
    cmpt
    );
    updateMatrixInterfaces
    (
    bouCoeffsCmpt,
    interfaces,
    psiCmpt,
    sourceCmpt,
    cmpt
    );
    void Foam::lduMatrix::Amul
    (
    scalarField& Apsi,
    const tmp<scalarField>& tpsi,
    const FieldField<Field, scalar>& interfaceBouCoeffs,
    const lduInterfaceFieldPtrsList& interfaces,
    const direction cmpt
    ) const
    {
    scalar* __restrict__ ApsiPtr = Apsi.begin();
    const scalarField& psi = tpsi();
    const scalar* const __restrict__ psiPtr = psi.begin();
    const scalar* const __restrict__ diagPtr = diag().begin();
    const label* const __restrict__ uPtr = lduAddr().upperAddr().begin();
    const label* const __restrict__ lPtr = lduAddr().lowerAddr().begin();
    const scalar* const __restrict__ upperPtr = upper().begin();
    const scalar* const __restrict__ lowerPtr = lower().begin();
    initMatrixInterfaces
    (
    interfaceBouCoeffs,
    interfaces,
    psi,
    Apsi,
    cmpt
    );
    const label nCells = diag().size();
    for (label cell=0; cell<nCells; cell++)
    {
    ApsiPtr[cell] = diagPtr[cell]*psiPtr[cell];
    }
    const label nFaces = upper().size();
    for (label face=0; face<nFaces; face++)
    {
    ApsiPtr[uPtr[face]] += lowerPtr[face]*psiPtr[lPtr[face]];
    ApsiPtr[lPtr[face]] += upperPtr[face]*psiPtr[uPtr[face]];
    }
    // Update interface interfaces
    updateMatrixInterfaces
    (
    interfaceBouCoeffs,
    interfaces,
    psi,
    Apsi,
    cmpt
    );
    tpsi.clear();
    }
    1 条回复 最后回复
  • Z 离线
    Z 离线
    ZY-GONG
    写于2025年1月13日 14:40 最后由 编辑
    #2

    https://marinecfd.xyz/post/from-geometricfield-to-fvmatrix/
    这个或许能回答

    W 1 条回复 最后回复 2025年1月14日 06:39
  • W 离线
    W 离线
    w352405196
    在 2025年1月14日 06:39 中回复了 ZY-GONG 最后由 编辑
    #3

    @ZY-GONG 多谢老师,这部分内容非常关键,写的非常好。我还有个问题,并行耦合边界条件是如何处理的?也就是说不同线程之间如何交互?怎么知道线程0和线程1之间相邻网格的对应关系

    Z 1 条回复 最后回复 2025年1月14日 06:45
  • Z 离线
    Z 离线
    ZY-GONG
    在 2025年1月14日 06:45 中回复了 w352405196 最后由 编辑
    #4

    @w352405196 :135: 我也是小白,并行这块我也不是很明白了,需要别的老师来回答你了

    W 1 条回复 最后回复 2025年1月14日 06:47
  • W 离线
    W 离线
    w352405196
    在 2025年1月14日 06:47 中回复了 ZY-GONG 最后由 编辑
    #5

    @ZY-GONG 好的,多谢老师,辛苦了

    1 条回复 最后回复
2024年12月31日 07:23

5/5

2025年1月14日 06:47

2025年1月14日 06:47
  • 登录

  • 登录或注册以进行搜索。
5 / 5
  • 第一个帖子
    5/5
    最后一个帖子
0
  • 最新
  • 版块
  • 东岳流体
  • 随机看[请狂点我]