通过 FiPy 解决圆柱体外网格表面的最佳方法,
Best way to address outer mesh surfaces of a cylinder by FiPy ,
我可以通过任何 FiPy 或 ... 模块处理外部网格面中心吗?
对于半径为 'R' 的圆柱体,会在其上创建类似 O'grid 扫描的相关网格。看起来,'R' 大于最外面的网格面中心;所以它们之间是有区别的(图),不能轻易用“R”来表示。
我需要提及围绕圆柱壁(不是顶壁和底壁)的所有外网格面中心。网格系统由“FiPy Gmsh”导入(FiPy version = 3.1 and Python 2.7)。 FiPy 'solver.mesh.getFaceCenters()' 得到一个简单的网格面中心数组。我认为外六边形网格层的圆柱壁相关外表面可以通过以下代码解决:
reduce(numpy.logical_and, (FORMULAs)) # where FORMULAs are specifying mesh face center coordinates limits
我尝试使用以下代码,但如果 FORMULA 适用,则需要对段 '> R' 进行一些更改。
x,y,z = solver.mesh.getFaceCenters()
np.sqrt(x ** 2 + y ** 2) > R # as FORMULAs
如果有人能帮助我解决这个问题,我将不胜感激。
我认为最好的方法一定是使用 FiPy 和 numpy 模块。
这在 the documentation for Gmsh2D
中讨论。
虽然可以参数化地定义这样的面,但由于离散化网格的有限分辨率,有必要允许一些位置误差。在抽象几何定义中定义你想要的面并直接引用它们要好得多,例如,你在 Gmsh 中的 GEO 文件会有类似
的内容
Physical Volume("FORMULA") = {5, 6, 7};
然后您的 FiPy 脚本将使用
访问它们
formula_faces = solver.mesh.physicalFaces["FORUMULA"]
我可以通过任何 FiPy 或 ... 模块处理外部网格面中心吗? 对于半径为 'R' 的圆柱体,会在其上创建类似 O'grid 扫描的相关网格。看起来,'R' 大于最外面的网格面中心;所以它们之间是有区别的(图),不能轻易用“R”来表示。
我需要提及围绕圆柱壁(不是顶壁和底壁)的所有外网格面中心。网格系统由“FiPy Gmsh”导入(FiPy version = 3.1 and Python 2.7)。 FiPy 'solver.mesh.getFaceCenters()' 得到一个简单的网格面中心数组。我认为外六边形网格层的圆柱壁相关外表面可以通过以下代码解决:
reduce(numpy.logical_and, (FORMULAs)) # where FORMULAs are specifying mesh face center coordinates limits
我尝试使用以下代码,但如果 FORMULA 适用,则需要对段 '> R' 进行一些更改。
x,y,z = solver.mesh.getFaceCenters()
np.sqrt(x ** 2 + y ** 2) > R # as FORMULAs
如果有人能帮助我解决这个问题,我将不胜感激。 我认为最好的方法一定是使用 FiPy 和 numpy 模块。
这在 the documentation for Gmsh2D
中讨论。
虽然可以参数化地定义这样的面,但由于离散化网格的有限分辨率,有必要允许一些位置误差。在抽象几何定义中定义你想要的面并直接引用它们要好得多,例如,你在 Gmsh 中的 GEO 文件会有类似
的内容Physical Volume("FORMULA") = {5, 6, 7};
然后您的 FiPy 脚本将使用
访问它们formula_faces = solver.mesh.physicalFaces["FORUMULA"]