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. openfoam中添加新变量并输出

openfoam中添加新变量并输出

已定时 已固定 已锁定 已移动 OpenFOAM
3 帖子 3 发布者 2.5k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • R 离线
    R 离线
    raymondieei
    写于 最后由 编辑
    #1

    各位老师好,由于openfoam里进行LES计算时,内置的field average只能输出雷诺应力,但是我的雷诺应力和经典文献结果对不上,所以我想在openfoam里增加速度二阶量UU及其时均值的计算。
    但是我在controlDict的增加了function以后并没有在结果文件里看到我定义的物理量,不知道各位有没有过类似的工作的可以指点一下。感谢!以下是我的代码

    functions
    {
        velocityUU
        {
            libs ("libutilityFunctionObjects.so");
            type coded;
            name velocityUU; // 将名称与输出文件的名称一致    
    
            region          region0;
            enabled         true;
            log             true;      
            executeControl  timeStep;
            executeInterval 1;
            writeControl    timeStep;
            writeInterval   1;
    
            codeInclude
            #{
                #include "fvCFD.H"
                #include <cmath>
                #include <iostream>
            #};
            
            codeOptions
            #{
                -I$(LIB_SRC)/finiteVolume/lnInclude \
                -I$(LIB_SRC)/meshTools/lnInclude
            #};
            
            codeLibs
            #{
                -lmeshTools \
                -lfiniteVolume
            #};
    
            codeExecute
            #{
                // 获取速度场 U
                const volVectorField& U = mesh().lookupObject<volVectorField>("U");
    
                // 计算速度场 U 的平方
                volScalarField UXSquared = U[0] * U[0];
    
                // 定义静态指针,用于存储 volScalarField 对象
                static autoPtr<volScalarField> pField;
    
                // 如果指针无效,创建 volScalarField 对象
                if (!pField.valid())
                {
                    pField.set(
                        new volScalarField(
                            IOobject(
                                "velocityUU",    // 输出文件的名称与函数名称一致
                                mesh().time().timeName(),
                                U.mesh(),
                                IOobject::NO_READ,
                                IOobject::AUTO_WRITE
                            ),
                            UXSquared
                        )
                    );
                }
    
                // 获取 velocityUU 引用
                volScalarField& result = pField();
    
                // 将 result 标记为有效
                result.checkIn();
    
                // 更新 result 的值
                result = UXSquared;
            #};
        }
    }
    
    
    1 条回复 最后回复
  • 李东岳李 在线
    李东岳李 在线
    李东岳 管理员
    写于 最后由 编辑
    #2

    强制.wirte()试试会不会出来

    http://dyfluid.com/index.html
    需要帮助debug算例的看这个 https://cfd-china.com/topic/8018

    1 条回复 最后回复
  • M 离线
    M 离线
    myheart
    写于 最后由 编辑
    #3

    我也不是很懂,从代码角度来看,貌似只有进入了if判断语句中才会进行变量的输出?是不是得把IO操作放在外层

    1 条回复 最后回复

  • 登录

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