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中文网

D

DJohn1211

@DJohn1211
关于
帖子
9
主题
1
群组
0
粉丝
0
关注
0

帖子

最新

  • OpenFOAM libtorch tutorial step by step
    D DJohn1211

    @李东岳 李老师您好,我在看您发的那个顶盖驱动流的代码的时候有个问题,我的电脑安装了openfoam10和11,同样的文件内容为什么在of10下我可以成功编译,但在of11下不可以呢。在11下,一开始提示找不到libtriSurface.so和libsurfMesh.so,然后我在bashrc中添加了,export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/john/OpenFOAM/OpenFOAM-11/platforms/linux64GccDPInt32Opt/lib,随后再次运行出现了这样的问题。
    3ede8b6c-c28f-448a-bbeb-577d81b25e5b-image.png
    2a999f20-6b9c-4d98-a662-0dbbcedbb11e-image.png
    61c724be-a76b-413e-8b89-f3528c9dc992-image.png


  • OpenFOAM libtorch tutorial step by step
    D DJohn1211

    @leaon 您好,我也和您遇到了一样的问题,请问您如何解决的呢


  • openfoam11中incompressiblevof求解器
    D DJohn1211

    @李东岳 在 openfoam11中incompressiblevof求解器 中说:

    volScalarField nuML("nuML", mesh, dimensionedScalar("nu", dimensionSet(0, 2, -1, 0, 0, 0, 0), 0.0));

    你有一行代码这么写的,这么写的不对

    李老师,我在定义这个变量的时候是这么定义的:

    volScalarField nuML
    (
        IOobject
        (
            "nuML",                
            runTime.timeName(),    
            mesh,                  
            IOobject::NO_READ,   
            IOobject::NO_WRITE   
        ),
        mesh,
        dimensionedScalar("zero", dimViscosity, 0.0) 
    );
    

    但我还是没有运行成功您的教程,想请问李老师可以把您的算例在论坛共享一下吗?然后我还有一个问题是这样的,我想在of10下icofoam的基础上先修改,但是我只是在头文件引入了#include "NN.H",并没有在求解器中修改内容,就不能编译,我看了一下报错,大致的意思是openfoam和libtorch的数据结构不兼容,但是按照您在http://dyfluid.com/上的算例来看不应该会出现这种报错,想请教李老师一下这其中的原因。这是我这部分的log文件log.wmake


  • openfoam11中incompressiblevof求解器
    D DJohn1211

    @李东岳 在 openfoam11中incompressiblevof求解器 中说:

    下周给你做个算例更新到 dyfluid.com

    李老师您好,感谢您百忙之中更新的数据驱动LES,但我在运行的时候遇到了一些问题,我按照您在网站上的步骤这么设计了一下。

    #include <torch/torch.h>
    #include "fvCFD.H"
    #include "viscosityModel.H"
    #include "incompressibleMomentumTransportModels.H"
    #include "pisoControl.H"
    #include "pressureReference.H"
    #include "fvModels.H"
    #include "fvConstraints.H"
    #include "NN.H"
    
    // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
    
    int main(int argc, char *argv[])
    {
        // 初始化OpenFOAM运行时间
        #include "setRootCaseLists.H"
        #include "createTime.H"
        #include "createMesh.H"
    
        pisoControl piso(mesh);
    
        #include "createFields.H"
        #include "initContinuityErrs.H"
    
    
        volScalarField nuML
        (
            IOobject
            (
                "nuML",                
                runTime.timeName(),    
                mesh,                  
                IOobject::NO_READ,   
                IOobject::NO_WRITE   
            ),
            mesh,
            dimensionedScalar("zero", dimViscosity, 0.0) 
        );
    
    
        // 创建并加载神经网络
        auto net = std::make_shared<NN>();
        torch::load(net, "net.pth"); // 加载已训练的模型
        
    
        while (runTime.loop())
        {
            Info << "Time = " << runTime.userTimeName() << nl << endl;
    
            #include "CourantNo.H"
            net->eval(); // 设置网络为评估模式
            
            // 计算速度梯度
            volTensorField gradU("", fvc::grad(U));
    
            // 准备输入数据
            auto inBatch = torch::zeros({nuML.size(), 9}, torch::kFloat);
    
            forAll(nuML, celli)
            {
                inBatch[celli][0] = gradU[celli].component(tensor::XX);
                inBatch[celli][1] = gradU[celli].component(tensor::XY);
                inBatch[celli][2] = gradU[celli].component(tensor::XZ);
                inBatch[celli][3] = gradU[celli].component(tensor::YX);
                inBatch[celli][4] = gradU[celli].component(tensor::YY);
                inBatch[celli][5] = gradU[celli].component(tensor::YZ);
                inBatch[celli][6] = gradU[celli].component(tensor::ZX);
                inBatch[celli][7] = gradU[celli].component(tensor::ZY);
                inBatch[celli][8] = gradU[celli].component(tensor::ZZ);
            }
    
            // 执行神经网络预测
            auto yPred = net->forward(inBatch);
    
            // 更新粘性系数 nuML
            forAll(nuML, celli)
            {
                nuML[celli] = yPred[celli].item<float>() / 1e5 + 2e-5;
            }
    
    
            runTime.write();
        }
    
        Info << "End" << endl;
        return 0;
    }
    

    但是出现了一些warning,不知道哪里出现了问题,我把我的log文件附在这里,想请李老师有空的时候能帮忙看一下问题,谢谢李老师。log.wmake


  • openfoam11中incompressiblevof求解器
    D DJohn1211

    谢谢李老师


  • OpenFoam-11 自定义求解器
    D DJohn1211

    您好,我最近也在研究of11的求解器,觉得应该去modules文件夹下找你需要自定义的文件


  • openfoam11中incompressiblevof求解器
    D DJohn1211

    李老师您好,打扰您了,我尝试了几次混编,想在pimple循环中对动量方程的求解不采用原来的方式,但总是调用libtorch失败,不知道李老师有没有时间能写一个简单的示例代码呢


  • openfoam11中incompressiblevof求解器
    D DJohn1211

    李老师您好,我看过您发的OpenFOAM libtorch tutorial step by step,我现在有个想法想请教一下您,您写的pinn的代码相当于把整个求解器替换掉,那我如果只通过网络替换其中部分方程的求解该怎么做呢?向请教您一下。举个例子来说,我如果只想把其中的速度方程用一个简单的卷积网络来替换,其他部分还保持原interfoam求解器,我应该怎么自定义这个求解器呢?


  • openfoam11中incompressiblevof求解器
    D DJohn1211

    想请问一下论坛里的各位大佬,我最近新安装了of11,看到interfoam求解器变成了incompressiblevof,我想在新版本下重新自定义一下一个新的类似于incompressiblevof求解器,但是我感觉和原来的interfoam求解器差别很大,比如原来interfoam中的ueqn的计算文件我在of11中不太清除incompressiblevof是怎么调用的,或者说在of11中incomprssiblevof是如何解这套方程的呢!
    (f020687f-3e9d-4179-864c-ea704339ebb4-image.png
    这是原来interfoam中计算u的文件内容
    c7915cf0-5c86-43ce-a83d-03110c2f832c-image.png
    小白请教一下各位大佬

  • 登录

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