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
2 帖子 2 发布者 2.2k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • 李东岳李 在线
    李东岳李 在线
    李东岳 管理员
    写于 最后由 编辑
    #1
    codedSource
    {
        type            vectorCodedSource;
        selectionMode   cellZone;
        cellZone        BANANA;
    
        fields          (U);
        name            codedSource;
    	
        codeAddSup
        #{  
        	        const label cellZoneID = mesh().cellZones().findZoneID("BANANA"); // find ID for the cellZone "BANANA"
    		const cellZone& zone = mesh().cellZones()[cellZoneID];
    		const cellZoneMesh& zoneMesh = zone.zoneMesh();
    		const labelList& cellsZone = zoneMesh[cellZoneID]; //list of all cellZone cell ID's  
                    
                    const scalarField& V = mesh_.V(); // Cell volume
                     
                    Foam::Field<Foam::Vector<double> >& USource = eqn.source(); // get source from fvMatrix
    		//scalarField & Udiag = eqn.diag(); // get diagonal of fvMatrix
                    
                    const scalarField& rho = mesh().lookupObject<scalarField>("rho"); // get density field
                  
                    const vector g (0,-9.81,0)      // gravitational vector
    
    
                    forAll(cellsZone,i)
    			{
            		const label celli = cellsZone[i];
    			
    			USource[celli] -= rho[celli]*g/V[celli];
    			}
        #};
        
        codeCorrect
        #{
        Pout<< "**codeCorrect**" << endl;
        
        #};
        codeSetValue
        #{
        Pout<< "**codeSetValue**" << endl;
        #};  
        code
        #{
                $codeInclude
                $codeCorrect
                $codeAddSup
                $codeSetValue
        #};
    

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

    1 条回复 最后回复
  • S 离线
    S 离线
    shiyu
    写于 最后由 编辑
    #2

    Hi,东岳大佬,请教下openfoam里可以实现分区网格计算,比如两个分区,并设置interface boundary condition来coupling这两个区域吗?如果可以,麻烦给点思路,谢谢。
    我暂时想到的只有fluid-solid interaction,即FSI toolbox in Foam-extend,改写solid domain为fluid-fluid interaction,来实现,不过有些繁琐了。

    BR,
    Shiyu

    1 条回复 最后回复

  • 登录

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