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.2k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • W 离线
    W 离线
    w352405196
    写于 最后由 李东岳 编辑
    #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 条回复 最后回复
  • ZY-GONGZ 离线
    ZY-GONGZ 离线
    ZY-GONG
    写于 最后由 编辑
    #2

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

    W 1 条回复 最后回复
  • W 离线
    W 离线
    w352405196
    在 中回复了 ZY-GONG 最后由 编辑
    #3

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

    ZY-GONGZ 1 条回复 最后回复
  • ZY-GONGZ 离线
    ZY-GONGZ 离线
    ZY-GONG
    在 中回复了 w352405196 最后由 编辑
    #4

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

    W 1 条回复 最后回复
  • W 离线
    W 离线
    w352405196
    在 中回复了 ZY-GONG 最后由 编辑
    #5

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

    1 条回复 最后回复

  • 登录

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