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
8 帖子 2 发布者 1.5k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • B 离线
    B 离线
    bcp
    写于 最后由 编辑
    #1

    求助各位大佬,我想要在interFoam求解器的动量方程加阻尼消波项,修改UEqn.H,编译可以通过,运行算咧的时候报错量纲不匹配,改了好多次一直都是这个问题,是我定义的有问题吗

    dimensionedScalar nu1
    (
        "nu1",
        dimensionSet(0,2,-1,0,0,0,0),
        1.48e-05
    );
    dimensionedScalar nu2
    (
        "nu2",
        dimensionSet(0,2,-1,0,0,0,0),
        1.0e-6
    );
    // Need to store rho for ddt(rho, U)
    volScalarField rho
    (
        IOobject
        (
            "rho",
            runTime.timeName(),
            mesh,
            IOobject::READ_IF_PRESENT
        ),
        alpha1*rho1 + alpha2*rho2
    );
    
    volScalarField nu
    (
        IOobject
        (
            "nu",
            runTime.timeName(),
            mesh,
            IOobject::READ_IF_PRESENT
        ),
        alpha1*nu1+alpha2*nu2
    );
    
    
    volScalarField muf
    (
        IOobject
        (
            "muf",
            runTime.timeName(),
            mesh,
            IOobject::READ_IF_PRESENT
        ),
        rho*nu
    );
    ![3.png](/assets/uploads/files/1734663338888-3.png) 
    
     dimensionedScalar r0
        (
            "r0",
            dimensionSet(0,0,-1,0,0,0,0),
            0
        );
    
        dimensionedScalar r1
        (
            "r1",
            dimensionSet(0,0,-1,0,0,0,0),
            5
        );
    
        dimensionedScalar x1 = max(mesh.Cf().component(vector::X))-min(mesh.Cf().component(vector::X));
    
        dimensionedScalar x0
        (
           "x0",
           2.4
        );
    
        volScalarField rField
        (
            "rField",
            max(r1*(mesh.C().component(vector::X)-x0)/(x1-x0),r0)
        );
    
        fvVectorMatrix UEqn
        (
            fvm::ddt(rho, U) + fvm::div(rhoPhi, U)
            - fvm::laplacian(muf,U)
            - rho*U*rField
        );
    
    
    1 条回复 最后回复
  • 学流体的小明学 离线
    学流体的小明学 离线
    学流体的小明 神
    写于 最后由 学流体的小明 编辑
    #2

    UEqn当中各项的量纲是 $[\mu][U]/L^2=M/(L^2T^2)$
    rField的量纲应该是$T^{-1}$才对,但看起来你写出来的并不是这样
    你可以在定义场的时候显式地指定量纲

    volScalarField B                                            
    (
        IOobject
        (
            "B",
            runTime.timeName(),
            mesh,
            IOobject::NO_READ,
            IOobject::AUTO_WRITE
        ),
        mesh,
        dimensionedScalar(dimless, 0.0)
    );
    
    B 1 条回复 最后回复
  • B 离线
    B 离线
    bcp
    在 中回复了 学流体的小明 最后由 编辑
    #3

    @学流体的小明 感谢大佬回复,我是这样定义的,我在rField之前定义了r1和r0,这两者的量纲都是(0 0 -1 0 0 0 0),然后rField是根据r1和r0通过公式求得的,这种情况下rFiedl的量纲和r1和r0相同吗

    学流体的小明学 2 条回复 最后回复
  • 学流体的小明学 离线
    学流体的小明学 离线
    学流体的小明 神
    在 中回复了 bcp 最后由 编辑
    #4
    此回复已被删除!
    1 条回复 最后回复
  • 学流体的小明学 离线
    学流体的小明学 离线
    学流体的小明 神
    在 中回复了 bcp 最后由 编辑
    #5

    @bcp 我搞错了,之前没看对你计算rField的公式。我以为是你rField的计算公式不对。

    你把报错代码发一下。
    debug,分别输出rho、U、rField的量纲看一看

    B 1 条回复 最后回复
  • B 离线
    B 离线
    bcp
    在 中回复了 学流体的小明 最后由 编辑
    #6

    @学流体的小明 感谢大佬,问题已经解决啦:146:

    学流体的小明学 1 条回复 最后回复
  • 学流体的小明学 离线
    学流体的小明学 离线
    学流体的小明 神
    在 中回复了 bcp 最后由 编辑
    #7

    @bcp OKK,可以把怎样解决的发出来吗?大家有相同问题的话也可以参考你的方案。

    B 1 条回复 最后回复
  • B 离线
    B 离线
    bcp
    在 中回复了 学流体的小明 最后由 编辑
    #8

    @学流体的小明 后来我看了一下运行日志发现量纲不匹配并不是动量方程的量纲不匹配,是我在定义阻尼区起点的时候没有定义量纲所以会一直报错,后来把阻尼区起点定义量纲之后就可以啦,整个代码是这样的。```

     dimensionedScalar r0
    (
        "r0",
        dimensionSet(0,0,-1,0,0,0,0),
        0
    );
    
    dimensionedScalar r1
    (
        "r1",
        dimensionSet(0,0,-1,0,0,0,0),
        5
    );
    
    dimensionedScalar x1 = max(mesh.Cf().component(vector::X))-min(mesh.Cf().component(vector::X));
    
    dimensionedScalar x0
    (
       "x0",
       dimensionSet(0,1,0,0,0,0,0),
       12
    );
    
    
    volScalarField R
    (
           "R",
           max(r1*(mesh.C().component(vector::X)-x0)/(x1-x0),r0)
    );
    
    
    fvVectorMatrix UEqn
    (
        fvm::ddt(rho, U) + fvm::div(rhoPhi, U)
        - fvm::laplacian(muf,U)
        - (fvc::grad(U)&fvc::grad(muf))
        + rho*U*R
    );
    
    1 条回复 最后回复

  • 登录

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