-
Notifications
You must be signed in to change notification settings - Fork 42
/
CfdObjects.py
100 lines (87 loc) · 4.73 KB
/
CfdObjects.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# ***************************************************************************
# * *
# * Copyright (c) 2016 - Bernd Hahnebach <[email protected]> *
# * *
# * This program is free software; you can redistribute it and/or modify *
# * it under the terms of the GNU Lesser General Public License (LGPL) *
# * as published by the Free Software Foundation; either version 2 of *
# * the License, or (at your option) any later version. *
# * for detail see the LICENCE text file. *
# * *
# * This program is distributed in the hope that it will be useful, *
# * but WITHOUT ANY WARRANTY; without even the implied warranty of *
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
# * GNU Library General Public License for more details. *
# * *
# * You should have received a copy of the GNU Library General Public *
# * License along with this program; if not, write to the Free Software *
# * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 *
# * USA *
# * *
# ***************************************************************************
__title__ = "CfdObjects"
__author__ = "Bernd Hahnebach, Qingfeng Xia"
__url__ = "http://www.freecadweb.org"
import FreeCAD
from ObjectsFem import makeMaterialFluid # FreeCAD stable version 0.18, 0.019 is working
from cfdobjects import _CfdResult, CfdSolverFenics, CfdSolverFoam, _CaeMeshGmsh, _CaeMeshImported, _CfdFluidBoundary
def makeCfdAnalysis(name):
'''makeCfdAnalysis(name): makes a Cfd Analysis object based on Fem::FemAnalysisPython'''
obj = FreeCAD.ActiveDocument.addObject("Fem::FemAnalysisPython", name)
if FreeCAD.GuiUp:
from cfdguiobjects._ViewProviderCfdAnalysis import _ViewProviderCfdAnalysis
_ViewProviderCfdAnalysis(obj.ViewObject)
return obj
def makeCfdSolver(solver_name ='OpenFOAM'):
if solver_name == 'OpenFOAM':
obj = CfdSolverFoam.makeCfdSolverFoam()
elif solver_name == 'Fenics':
obj = CfdSolverFenics.makeCfdSolverFenics()
else:
# Todo: ChoiceDialog to choose different solver, commandSolver
FreeCAD.Console.Error("only solver name with Fenics and OpenFOAM is supported")
return obj
def makeCfdMeshGmsh(name="CFDMeshGMSH"):
'''makeCfdMeshGmsh(name): makes a GMSH CFD mesh object'''
doc = FreeCAD.ActiveDocument
obj = doc.addObject("Fem::FemMeshObjectPython", name)
#from cfdobjects._CaeMeshGmsh import _CaeMeshGmsh
_CaeMeshGmsh._CaeMeshGmsh(obj)
if FreeCAD.GuiUp:
from cfdguiobjects._ViewProviderCaeMesh import _ViewProviderCaeMesh
_ViewProviderCaeMesh(obj.ViewObject)
obj.ElementOrder = '1st'
obj.OptimizeStd = False
#obj.RecombineAll = True # genereate bad mesh for curved mesh
#may also set meshing algorithm, frontal, gmsh is best for Fenics
return obj
def makeCfdMeshImported(name="ImportedCFDMesh"):
'''make mesh object to load external mesh'''
doc = FreeCAD.ActiveDocument
obj = doc.addObject("Fem::FemMeshObjectPython", name)
_CaeMeshImported._CaeMeshImported(obj)
if FreeCAD.GuiUp:
from cfdguiobjects._ViewProviderCaeMesh import _ViewProviderCaeMesh
_ViewProviderCaeMesh(obj.ViewObject)
return obj
def makeCfdFluidMaterial(name="FluidMaterial"):
'''makeCfdFluidMaterial(name): makes a CFD fluid material object from FemObjects.makeFemMaterialFluid'''
obj = makeMaterialFluid(FreeCAD.ActiveDocument, name)
return obj
def makeCfdFluidBoundary(name="CfdFluidBoundary"):
''' makeCfdFoamBoundary([name]): Creates a advaned/raw boundary condition setup dict for OpenFOAM'''
obj = FreeCAD.ActiveDocument.addObject("Part::FeaturePython", name)
_CfdFluidBoundary._CfdFluidBoundary(obj)
if FreeCAD.GuiUp:
from cfdguiobjects._ViewProviderCfdFluidBoundary import _ViewProviderCfdFluidBoundary
_ViewProviderCfdFluidBoundary(obj.ViewObject)
return obj
def makeCfdResult(result_obj_name = "CfdResult"):
doc = FreeCAD.ActiveDocument
obj= doc.addObject('Fem::FemResultObjectPython', result_obj_name)
#from _CfdResult import _CfdResult
_CfdResult._CfdResult(obj)
if FreeCAD.GuiUp:
from cfdguiobjects._ViewProviderCfdResult import _ViewProviderCfdResult
_ViewProviderCfdResult(obj.ViewObject)
return obj