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. 已知某点坐标,获取该点的速度。单核可行,多核并行就会出现由于分块找不到cellID。

已知某点坐标,获取该点的速度。单核可行,多核并行就会出现由于分块找不到cellID。

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

    已知某点坐标,获取该点的速度。单核可行,多核并行就会出现由于分块找不到cellID的情况。代码如下:
    point b (1,1,1);
    label cellID = mesh.findCell(b);
    vector intU = U[cellID];
    怎么解决呐?可以用reduce函数?但是没看明白。或者有没有其它办法获得该点的速度值,使其在并行的情况下有效。
    鞠躬感谢!

    1 条回复 最后回复
  • 学流体的小明学 离线
    学流体的小明学 离线
    学流体的小明 神
    写于 最后由 编辑
    #2

    并行计算时候,每个进程掌握的网格就固定那些。
    举例b点只存在于processor x1,不在processor x2当中,processor x2自然无法获取b点的信息。
    要想processor x2获取b点信息,可以用reduce函数,也就是进程之间通讯一下。
    首先初始化intU为零向量,然后赋值,再reduce。

    point b (1,1,1);
    label cellID = mesh.findCell(b);
    vector intU(0,0,0);
    intU = U[cellID];
    reduce(U,sumOp<vector>());
    

    具体代码你再看一下,我这个是思路,代码可能哪里不对。

    1 条回复 最后回复

  • 登录

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