FEM FemMesh2Mesh/fr: Difference between revisions

From FreeCAD Documentation
(Created page with "== Convertir 2D éléments ==")
No edit summary
(5 intermediate revisions by 2 users not shown)
Line 4: Line 4:
|[[FEM_CreateNodesSet/fr|Jeu de nœuds]]
|[[FEM_CreateNodesSet/fr|Jeu de nœuds]]
|[[FEM_SolverCalculixCxxtools/fr|Solveur Calculix standard]]
|[[FEM_SolverCalculixCxxtools/fr|Solveur Calculix standard]]
|[[FEM_Module/fr|Atelier FEM]]
|[[FEM_Workbench/fr|Atelier FEM]]
|IconL=FEM_CreateNodesSet.svg
|IconL=FEM_CreateNodesSet.svg
|IconR=FEM_SolverCalculixCxxtools.svg
|IconR=FEM_SolverCalculixCxxtools.svg
Line 12: Line 12:
{{GuiCommand/fr
{{GuiCommand/fr
|Name=FEM FemMesh2Mesh
|Name=FEM FemMesh2Mesh
|Name/fr=FEM Maillage à maillage
|Name/fr=FEM Maillage à maillage MEF
|MenuLocation=Mesh → Maillage à maillage
|MenuLocation=Mesh → Maillage à maillage
|Workbenches=[[FEM_Workbench/fr|FEM]]
|Workbenches=[[FEM_Workbench/fr|FEM]]
Line 47: Line 47:
== Convertir 2D éléments ==
== Convertir 2D éléments ==


<div class="mw-translate-fuzzy">
== Convertir 2D éléments ==
Sélectionnez un maillage et lancez le code suivant dans la fenêtre Python de FreeCAD
Sélectionnez un maillage et lancez le code suivant dans la fenêtre Python de FreeCAD
</div>


{{Code|code=
{{Code|code=
Line 77: Line 74:




<div class="mw-translate-fuzzy">
{{Docnav/fr
{{Docnav/fr
|[[FEM_CreateNodesSet/fr|Jeu de nœuds]]
|[[FEM_CreateNodesSet/fr|Jeu de nœuds]]
|[[FEM_SolverCalculixCxxtools/fr|Solveur Calculix standard]]
|[[FEM_SolverCalculixCxxtools/fr|Solveur Calculix standard]]
|[[FEM_Module/fr|Atelier FEM]]
|[[FEM_Workbench/fr|Atelier FEM]]
|IconL=FEM_CreateNodesSet.svg
|IconL=FEM_CreateNodesSet.svg
|IconR=FEM_SolverCalculixCxxtools.svg
|IconR=FEM_SolverCalculixCxxtools.svg
|IconC=Workbench_FEM.svg
|IconC=Workbench_FEM.svg
}}
}}
</div>


{{FEM Tools navi{{#translation:}}}}
{{FEM Tools navi{{#translation:}}}}
{{Userdocnavi{{#translation:}}}}
{{Userdocnavi{{#translation:}}}}
{{clear}}

Revision as of 19:58, 23 August 2021

FEM Maillage à maillage MEF

Emplacement du menu
Mesh → Maillage à maillage
Ateliers
FEM
Raccourci par défaut
Aucun
Introduit dans la version
-
Voir aussi
FEM Tutoriel

Description

Cet outil converti une surface un élément 3D ou un élément FEM maille sélectionné en un élément maille . En interne, l'élément FEM maille choisi est unique (non partagé entre deux éléments) et l'utilise pour créer une face ou un élément maille. Optionnellement il permet de créer un maillage déformé causé par les forces établies . Ceci est fait par ajout du déplacement de FEM résultant des nœuds du maillage.

Les éléments bidimensionnels du maillage FEM ne sont pas pris en compte. Si vous devez les convertir, vous pouvez utiliser le script python ci-dessous.

Utilisation

  1. Sélectionnez un objet de maillage MEF.
  2. En option, sélectionnez également les résultats FEM.
  3. Il existe plusieurs façons d'appeler la commande:

Script

Exemple: Téléchargez l'exemple 3D FEM de FreeCAD à partir de l'atelier Start et exécutez le code suivant

femmesh_obj = App.ActiveDocument.getObject("Result_mesh").FemMesh
result = App.ActiveDocument.getObject("CalculiX_static_results")
import femmesh.femmesh2mesh
out_mesh = femmesh.femmesh2mesh.femmesh_2_mesh(femmesh_obj, result)
import Mesh
Mesh.show(Mesh.Mesh(out_mesh))

Convertir 2D éléments

Sélectionnez un maillage et lancez le code suivant dans la fenêtre Python de FreeCAD

import Mesh

def extend_by_triangle(i, j, k):
    triangle = [input_mesh.getNodeById(element_nodes[i]),
                input_mesh.getNodeById(element_nodes[j]),
                input_mesh.getNodeById(element_nodes[k])]
    return output_mesh.extend(triangle) 

selection = FreeCADGui.Selection.getSelection()
input_mesh = App.ActiveDocument.getObject(selection[0].Name).FemMesh
output_mesh = []
for element in input_mesh.Faces:
    element_nodes = input_mesh.getElementNodes(element)
    if len(element_nodes) in [3, 6]:  # tria3 or tria6 (ignoring mid-nodes)
        extend_by_triangle(0, 1, 2)
    elif len(element_nodes) in [4, 8]:  # quad4 or quad8 (ignoring mid-nodes)
        extend_by_triangle(0, 1, 2)
        extend_by_triangle(2, 3, 0)

obj = Mesh.Mesh(output_mesh)
Mesh.show(obj)