FEM Install/fr: Difference between revisions

From FreeCAD Documentation
(Created page with "==== CalculiX ==== Voir ce message de forum [https://forum.freecadweb.org/viewtopic.php?f=18&t=10979&p=198652#p198642 FreeCAD Fem on OSX] comment installer CalculiX sur OSX Le...")
No edit summary
(44 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<languages/>
<languages/>
== Introduction ==
== Introduction ==
Pour pouvoir effectuer une analyse par éléments finis (FEA) à l'aide de l'outil [[Fem_Workbench | FEM Worbench]] FreeCAD utilise deux programmes externes. L'un est utilisé pour générer le FEM-Mesh et l'autre pour résoudre le système d'équations. Si votre FreeCAD est configuré pour effectuer des analyses mécaniques par éléments finis, vous pouvez le vérifier facilement en chargeant et en analysant un fichier exemple. Voir [[FEM_CalculiX_Cantilever_3D]]


Pour pouvoir effectuer une analyse par éléments finis (FEA) dans [[Fem_Workbench/fr|atelier FEM]], FreeCAD utilise deux programmes externes: l’un est utilisé pour générer le [[FEM Mesh/fr|FEM Mesh]], l’autre pour la résolution numérique du analyse réelle. Vous pouvez tester si votre installation FreeCAD est prête pour FEA en exécutant l’exemple [[FEM CalculiX Cantilever 3D]] fourni avec l'installation de FreeCAD depuis la v0.17.
===== FEM Solver =====
Pour résoudre le système d'équations, nous utilisons CalculiX. Voir http://www.calculix.de/ FreeCAD écrit un fichier d’entrée CalculiX, lance CalculiX et lit la sortie de CalculiX. Cela signifie que le binaire CalculiX est autonome et indépendant de FreeCAD. Pour cette raison, et comme il existe plus de possibilités d'obtenir un FEM-Mesh valide, il est recommandé d'installer le solveur en premier. À ce jour (mi-2015), CalculiX est le seul solveur pris en charge du module FEM.


[[Image:FEM_Workbench_workflow.svg|600px]]
===== FEM Mesh Generator =====
As meshing tool to create a FEM-Mesh netgen is used. See https://sourceforge.net/projects/netgen-mesher/ To use Netgen in FEM module FreeCAD needs to be compiled against netgen libraries. Apart from Netgen a common way to create a FEM Mesh is the use FEM GMSH mesh tool. For the use of this tool GMSH has to be installed on your system. Check out [[FEM_Mesh#Create_a_FEM_Mesh]] for the various possibilities to create an FEM Mesh in FreeCAD.


{{Caption|Workflow de l'atelier FEM; le plan de travail appelle deux programmes externes pour effectuer le maillage d'un objet solide et pour résoudre le problème des éléments finis}}
== Installation of external FEM Module Software ==
=== Windows ===
If either a stable or development version from [[Download]] is used no further software needs to be installed. Netgen and CalculiX are included in the FreeCAD download package.


=== Linux ===
=== FEM Solver ===
==== Ubuntu PPA ====
The easiest possibility to get an working FEM Workbench on Linux is the use of the Ubuntu PPA Version. Check out [[Download#Ubuntu_PPA_packages]]. The netgen FEM Mesh Generator is allready included in the ppa version. CalculiX is an extra package provided by the Ubuntu PPA Version as well. If the Ubuntu PPA repository is allready added to your package manager install CalculiX by
apt-get install ccx


Le solveur par défaut pour effectuer des calculs par éléments finis est [[FEM CalculiX|CalculiX]], un solveur simple pour l'analyse de structures. FreeCAD écrit un fichier d'entrée CalculiX, lance le solveur et lit le résultat qui peut ensuite être présenté visuellement dans la fenêtre d'affichage. Cela signifie que le binaire CalculiX est autonome et indépendant de FreeCAD. Etant donné que de nombreux programmes peuvent générer un maillage, il est recommandé d’installer le solveur et de s’assurer qu’il fonctionne en premier.
The following FreeCAD Ubuntu PPA packages have Netgen and CalculiX:
* Ubuntu 14.04 (Trusty Tahr)
* Ubuntu 14.10 (Utopic Unicorn)
* Ubuntu 15.04 (Vivid Vervet)


Si le solveur est correctement installé, vous pouvez exécuter la commande unique {{incode|ccx}} dans le terminal pour obtenir une réponse simple:
For Developers: There is a huge [http://forum.freecadweb.org/viewtopic.php?f=18&t=10393 forum thread] in which the creation of the Ubuntu PPA packages was disscussed. It may be usefull if the Ubuntu PPA packages needs to be updated. On Launchpad there are more than one CalculiX packages. Only one CalculiX package should be installed and any of them should work. There is a simple reason for not taking the one which was allready on Launchpad. We did not know about it (see http://forum.freecadweb.org/viewtopic.php?f=18&t=10393&start=90#p85498)


{{SystemInput|
==== Other ====
User@PC:~$ ccx}}
On other Linux distributions you need to make sure to get the appropriate software and libraries installed yourself before using FEM workbench.


{{Code|code=
==== CalculiX ====
Usage: CalculiX.exe -i jobname
Since CalculiX is a standalone software you either can install a CalculiX binary or compile CalculiX yourself. Any CalculiX version from 2.7.X works with FreeCAD. Since there hasn't been much changes in CalculiX resently lower versions than 2.7.X might work as well.
}}


Si le solveur est installé, assurez-vous que l'atelier FEM est capable de trouver le binaire. Allez à {{MenuCommand|Edit → Preferences → FEM → CalculiX → Search in known binary directories}}. Si vous avez compilé le solveur vous-même, décochez l'option et donnez le chemin correct au fichier binaire. Pour les autres solveurs pouvant être utilisés avec FreeCAD, voir [[FEM Solver/fr|FEM Solveur]].
===== Install CalculiX Binary =====
There are only a few Linux Distributions which are known to have CalculiX Packages in their Repositories. Following a list:
* Arch Linux --> https://aur.archlinux.org/packages/calculix/
* Debian Stretch --> https://packages.debian.org/stretch/calculix-ccx
* Debian Jessie --> The packages of Debian Stretch can be installed by dpkg see [http://forum.freecadweb.org/viewtopic.php?f=4&t=5975&p=110597#p110597 FreeCAD forum]


=== Générateur de maillage FEM ===
On the CalculiX Website it is possible to download a generic Linux binary of CalculiX. Check out http://www.dhondt.de/ Since any Linux Distribution could have different library paths it is likely possible this binary will not work out of the box at your linux distribution. Check out the following FreeCAD forum threads for more infomation:
Afin de créer un [[FEM Mesh/fr|FEM Mesh]], FreeCAD utilise [http://gmsh.info/ Gmsh] comme mailleur par défaut. Pour que cela fonctionne, Gmsh doit être installé séparément de FreeCAD.
* Fedora 21 --> http://forum.freecadweb.org/viewtopic.php?f=18&t=10140
* Some bash commands that may help --> http://forum.freecadweb.org/viewtopic.php?f=3&t=11830&start=20#p95741


Si le programme est correctement installé, vous pouvez exécuter la commande {{incode|gmsh}} dans le terminal pour lancer l'interface graphique du programme. Cette interface n’est pas utilisée par FreeCAD mais montre que le programme est installé.
===== Compile CalculiX =====
Compiling CalculiX is not as easy as it is with many OpenSource software. There are many different resources at FreeCAD forum and the internet. Check out the following:
* Debian --> http://forum.freecadweb.org/viewtopic.php?f=4&t=5975&start=10
* There is a CMake Repository on github, but at FreeCAD forum noone has reported if this one works
** https://github.com/ricortiz/CalculiX-cmake


{{SystemInput|
==== Netgen ====
User@PC:~$ gmsh -info}}
There have been mixed results with the Netgen mesher and the compilation of FreeCAD with Netgen support.
* ToDo


{{Code|code=
==== Further Informations ====
Version : 3.0.6
The [http://www.forum.freecadweb.org/ FreeCAD forum] is a very good resource for informations in this regard. Check out google search on FreeCAD forum page by :
License : GNU General Public License
* [https://www.google.ch/search?q=sys.append.path+site%3Aforum.freecadweb.org#q=calculix+site:forum.freecadweb.org calculix site:forum.freecadweb.org]
Build OS : Linux64
* [https://www.google.ch/search?q=sys.append.path+site%3Aforum.freecadweb.org#q=netgen+site:forum.freecadweb.org netgen site:forum.freecadweb.org]
Build date : 20171107
Build host : lgw01-amd64-034
Build options : 64Bit Ann Bamg Bfgs Blas(Generic) Blossom C++11 Cgns Chaco DIntegration Dlopen Fltk Gmm Jpeg Kbipack Lapack(Generic) LinuxJoystick MPI MathEx Med Mesh Mmg3d Mpeg NativeFileChooser Netgen ONELAB ONELABMetamodel OpenCASCADE OpenGL OptHom Parser Plugins Png Post Python Solver TetGen/BR Tetgen Voro3D Zlib
FLTK version : 1.3.4
OCC version : 6.9.1
MED version : 3.0.6
Packaged by : buildd
Web site : http://gmsh.info
Mailing list : gmsh@onelab.info
}}


Si le mailleur est installé, assurez-vous que FEM Workbench est capable de trouver le binaire. Allez à {{MenuCommand|Edit → Preferences → FEM → Gmsh → Search in known binary directories}}. Si vous avez compilé le mailleur vous-même, décochez l'option et donnez le chemin correct au fichier binaire. Voir [[FEM Mesh/fr|FEM Mesh]] pour les différentes possibilités d'obtenir un maillage valide pour l'analyse.
=== OSX ===
The OSX development packages of FreeCAD 0.17.xxxxx do include Netgen [https://github.com/FreeCAD/FreeCAD/releases] but they do not include CalculiX.


==== CalculiX ====
=== Netgen ===
Voir ce message de forum [https://forum.freecadweb.org/viewtopic.php?f=18&t=10979&p=198652#p198642 FreeCAD Fem on OSX] comment installer CalculiX sur OSX
Les informations suivantes peuvent être obsolètes:
* [http://forum.freecadweb.org/viewtopic.php?f=18&t=10979 forum]
* [http://forum.freecadweb.org/viewtopic.php?f=8&t=14497 forum]


{{Emphasis|Note: le mailleur Netgen a été désactivé en mars 2017, lorsque FreeCAD est passé à l'utilisation de OCCT 7.1. Modifiez ces informations si Netgen est à nouveau utilisable avec la version stable de FreeCAD.}}
[[Category:User Documentation/fr]]

Dans les versions précédentes de FreeCAD, [https://sourceforge.net/projects/netgen-mesher/ Netgen] était le mailleur par défaut. Pour fonctionner avec l'atelier FEM, FreeCAD devait être lié aux bibliothèques Netgen au moment de la compilation. Alors que FreeCAD passait de OCE 0.17 à OCCT 7.1, Netgen 4.9.13 n'a pas réussi à établir de liaison avec cette version d'OCCT. Il a donc été décidé de supprimer le support Netgen dans [[FEM Workbench/fr|Atelier FEM]] (le bouton [[FEM MeshNetgenFromShape|Netgen button]] a été enlevé). Néanmoins, peu après, certains utilisateurs ont signalé qu'ils avaient réussi à appliquer une correction à Netgen 5.3.1, qui fonctionnait donc avec OCCT 7.x et FreeCAD.

Pour référence historique, voir les discussions:
* [https://forum.freecadweb.org/viewtopic.php?f=4&t=17501 (Ubuntu Daily PPA) Transitioning to OCCT7, VTK7...]
* [https://forum.freecadweb.org/viewtopic.php?t=21246 Ubuntu Daily Builds PPA now using OCC 7.1.0]
* [https://forum.freecadweb.org/viewtopic.php?f=4&t=17501&start=200#p165769 patching Netgen 5.3.1] to work with OCCT 7.1
* [https://forum.freecadweb.org/viewtopic.php?t=28368 Troubles with gmsh in FEM wb (netgen nostalgy)]

Bien que Netgen ne soit pas disponible à partir de [[FEM Workbench/fr|Atelier FEM]], il peut toujours être utilisé seul pour produire des maillages pouvant être importés.

Si le programme est correctement installé, vous pouvez exécuter la commande {{incode|netgen}} dans le terminal pour lancer l'interface graphique du programme.

{{SystemInput|
User@PC:~$ netgen -V}}

{{Code|code=
NETGEN-6.2-dev
Developed by Joachim Schoeberl at
2010-xxxx Vienna University of Technology
2006-2010 RWTH Aachen University
1996-2006 Johannes Kepler University Linz
Including OpenCascade geometry kernel
Run parallel Netgen with 'mpirun -np xy netgen'
NETGENDIR = .
Tcl header version = 8.6.8
Tcl runtime version = 8.6.8
using internal Tcl-script
optfile ./ng.opt does not exist - using default values
togl-version : 2
OCC module loaded
}}

== Installation sous Windows ==
Les packages FreeCAD disponibles sur la page [[download/fr|Téléchargements]] incluent déjà Netgen et CalculiX, aucun logiciel supplémentaire ne doit donc être installé.

== Installation sous Linux ==

Les distributions Linux ont différentes manières d'installer un logiciel. De nombreuses distributions ont des référentiels de logiciels et des gestionnaires de paquets; avant de compiler le code source, recherchez dans votre gestionnaire de paquets pour {{incode|netgen}}, {{incode|gmsh}}, {{incode|calculix-ccx}} ou {{incode|ccx}} et installez-les après la instructions de votre propre distribution.

=== PPA sous Ubuntu===

Les [https://launchpad.net/~freecad-maintainers/+archive/ubuntu/freecad-stable freecad-stable] et [https://launchpad.net/~freecad-maintainers/+archive/ubuntu/freecad-daily freecad-daily] PPA (personal package archives) fournissent une version de FreeCAD plus récente que celle disponible dans les dépôts officiels d'Ubuntu. Ces PPA incluent également les derniers {{incode|netgen}}, {{incode|gmsh}} et {{incode|calculix-ccx}}. Voir [[Install on Unix/fr|Installation sous Unix]] pour plus d'informations sur la configuration des référentiels.

Si un PPA est déjà ajouté à votre système, installez les packages comme suit
{{Code|code=
sudo apt-get install netgen
sudo apt-get install gmsh
sudo apt-get install calculix-ccx
}}

Le PPA [https://launchpad.net/~freecad-community/+archive/ubuntu/ppa freecad-community] fournit également les {{incode|netgen}}, {{incode|gmsh}} et {{incode|calculix-ccx}} paquets à tester. S'ils sont suffisamment stables, ils peuvent être ajoutés aux référentiels quotidiens ou stables.

{{Emphasis|Note:}} le fil [http://forum.freecadweb.org/viewtopic.php?f=18&t=10393 Ubuntu Repository] traite de la création des packages PPA Ubuntu. Au moment de sa rédaction, CalculiX n'était pas inclus dans les référentiels Debian. Il y avait donc plusieurs paquets personnels dans Launchpad. Un seul paquet doit être installé.

=== Arch Linux ===
Récupérez le package CalculiX à partir de [https://aur.archlinux.org/packages/calculix/ AUR repository].

=== Debian ===
* Debian 9 Buster: les paquets [https://packages.debian.org/buster/calculix-ccx repository] sont obsolètes, mais vous pouvez utiliser les paquets du PPA Ubuntu ({{incode|freecad-community}}). Voir [https://forum.freecadweb.org/viewtopic.php?f=18&t=31360&start=10#p279925 Gmsh 4 package available for testing in Community Extras PPA] (post de forum).
* Debian 8 Stretch: les packages [https://packages.debian.org/stretch/calculix-ccx repository] sont obsolètes, mais vous pouvez utiliser les packages de la PPA Ubuntu ({{incode|freecad-community}}). Voir [https://forum.freecadweb.org/viewtopic.php?f=18&t=31360&p=279925#p260872 Gmsh 4 package available for testing in Community Extras PPA] (post de forum).
* Debian 7 Jessie: installez les paquets à partir de Debian 8 Stretch en utilisant {{incode|dpkg}}. Voir [[http://forum.freecadweb.org/viewtopic.php?f=4&t=5975&p=110597#p110597 Debian source package for Calculix]] (message sur le forum).

=== binaire CalculiX ===
Les auteurs CalculiX fournissent un binaire Linux précompilé du solveur. Il peut être téléchargé à partir du [http://www.dhondt.de/ site web des auteurs]. Cependant, étant donné que les différentes distributions Linux ont des chemins de bibliothèque différents, ce binaire ne fonctionnera probablement pas sans certains ajustements.

Pour utiliser le binaire avec Fedora 21, voir le fil [http://forum.freecadweb.org/viewtopic.php?f=18&t=10140 Making FEM run on linux fedora 21]. Pour les versions plus récentes de Fedora, vous devez compiler CalculiX vous-même.

Si vous utilisez ce binaire, vérifiez que le binaire est exécutable, qu'il se trouve dans l'exécutable {{incode|$PATH}} de votre système et que vous disposez de la version nécessaire des bibliothèques ({{incode|libgfortran}}, {{incode|liblapack}}, {{incode|libblas}}, etc.) pour lequel il a été compilé. Ceci est mentionné dans le message du forum [http://forum.freecadweb.org/viewtopic.php?f=3&t=11830&start=20#p95741 FEM WB].

Utilisez la commande {{incode|ldd}} pour voir les bibliothèques liées par le binaire. Installez les dépendances manquantes.

{{SystemInput|
User@PC:~$ ldd /usr/bin/ccx
}}

{{Code|code=
linux-vdso.so.1 (0x00007fffbabdc000)
libspooles.so.2.2 => /usr/lib/x86_64-linux-gnu/libspooles.so.2.2 (0x00007fe9bd042000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fe9bce23000)
libarpack.so.2 => /usr/lib/x86_64-linux-gnu/libarpack.so.2 (0x00007fe9bcbd9000)
liblapack.so.3 => /usr/lib/x86_64-linux-gnu/liblapack.so.3 (0x00007fe9bc353000)
libgfortran.so.4 => /usr/lib/x86_64-linux-gnu/libgfortran.so.4 (0x00007fe9bbf74000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fe9bbbd6000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fe9bb7e5000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fe9bb5cd000)
libmpi.so.20 => /usr/lib/x86_64-linux-gnu/libmpi.so.20 (0x00007fe9bb2db000)
/lib64/ld-linux-x86-64.so.2 (0x00007fe9bdaa9000)
libblas.so.3 => /usr/lib/x86_64-linux-gnu/libblas.so.3 (0x00007fe9bb080000)
libopenblas.so.0 => /usr/lib/x86_64-linux-gnu/libopenblas.so.0 (0x00007fe9b8dda000)
libquadmath.so.0 => /usr/lib/x86_64-linux-gnu/libquadmath.so.0 (0x00007fe9b8b9a000)
libopen-rte.so.20 => /usr/lib/x86_64-linux-gnu/libopen-rte.so.20 (0x00007fe9b8912000)
libopen-pal.so.20 => /usr/lib/x86_64-linux-gnu/libopen-pal.so.20 (0x00007fe9b8660000)
librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007fe9b8458000)
libhwloc.so.5 => /usr/lib/x86_64-linux-gnu/libhwloc.so.5 (0x00007fe9b821b000)
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fe9b8017000)
libutil.so.1 => /lib/x86_64-linux-gnu/libutil.so.1 (0x00007fe9b7e14000)
libnuma.so.1 => /usr/lib/x86_64-linux-gnu/libnuma.so.1 (0x00007fe9b7c09000)
libltdl.so.7 => /usr/lib/x86_64-linux-gnu/libltdl.so.7 (0x00007fe9b79ff000)
}}

=== Compiler CalculiX ===

CalculiX étant une application autonome, vous pouvez installer un fichier binaire empaqueté pour votre distribution ou le compiler vous-même. A partir de la version 2.7.x, CalculiX devrait fonctionner avec FreeCAD. Etant donné que le code n'a pas beaucoup changé depuis des années, des versions plus basses que la version 2.7.x peuvent également fonctionner.

Compiler CalculiX est une tâche pour des utilisateurs expérimentés, nécessitant la modification des Makefiles et des options de construction de différentes plates-formes. Voir les informations suivantes:
* Debian: [http://forum.freecadweb.org/viewtopic.php?f=4&t=5975&start=10 Debian source package for Calculix], [https://forum.freecadweb.org/viewtopic.php?f=18&t=31360&start=10#p260506 Gmsh 4 package available for testing in Community Extras PPA], [https://forum.freecadweb.org/viewtopic.php?f=18&t=34024 Compiling CalculiX ccx on fedora, ubuntu and debian].
* Fedora 27, 28, 29: [https://forum.freecadweb.org/viewtopic.php?f=18&t=34024 Compiling CalculiX ccx on fedora, ubuntu and debian].
* Il existe une version CMake du paquet source dans un [https://github.com/ricortiz/CalculiX-cmake github repository], mais sur les forums FreeCAD, personne n'a signalé si ce paquet fonctionnait.

=== Compiler Netgen ===

Netgen était initialement lié par FreeCAD lorsque FreeCAD a utilisé OCE, le fork de la communauté d'OpenCascade (OCCT). Alors que OCE accusait un retard de développement par rapport à OCCT, FreeCAD est revenu à OCCT. Cela a rompu la liaison de Netgen, qui ne pouvait se lier qu'à OCCT 6.9 ou à OCE 0.18 et au-dessous. Les versions OCCT 7.x améliorant la fonctionnalité de base de FreeCAD, il a été décidé de supprimer le support Netgen au profit de Gmsh.

Depuis lors, quelques succès ont été obtenus en corrigeant et en liant les nouvelles versions de Netgen avec OCCT 7.x. Néanmoins, l'inclusion de Netgen avec FreeCAD reste problématique.

== Installation sous OSX ==
{{VeryImportantMessage|Ces informations peuvent être obsolètes. Si vous êtes un utilisateur OSX, veuillez tester et corriger cette section}}
Les packages de développement OSX [https://github.com/FreeCAD/FreeCAD/releases development packages] de FreeCAD peuvent inclure Netgen mais ne peuvent pas inclure CalculiX.

Voir cet article du forum [https://forum.freecadweb.org/viewtopic.php?f=18&t=10979&p=198652#p198642 FEM on Mac OSX] pour plus d'informations sur l'installation de CalculiX et un [https://forum.freecadweb.org/viewtopic.php?f=18&t=10979&start=90#p273746 updated post] pour des informations plus récentes.

Les articles suivants peuvent être obsolètes:
* [http://forum.freecadweb.org/viewtopic.php?f=18&t=10979 FEM on Mac OSX, post 1]
* [http://forum.freecadweb.org/viewtopic.php?f=8&t=14497 MacPorts users: CalculiX port test request]

== Plus d'informations ==

L'[[FEM Workbench/fr|atelier FEM]] est en développement constant. Les informations les plus récentes se trouvent sur le [http://www.forum.freecadweb.org/ Forum FreeCAD].

Si vous rencontrez des problèmes pour installer Netgen, Gmsh ou CalculiX, ou un autre outil externe, commencez par rechercher le forum correspondant:
* [https://www.google.ch/search?q=sys.append.path+site%3Aforum.freecadweb.org#q=netgen+site:forum.freecadweb.org netgen site:forum.freecadweb.org]
* [https://www.google.ch/search?q=sys.append.path+site%3Aforum.freecadweb.org#q=gmsh+site:forum.freecadweb.org gmsh site:forum.freecadweb.org]
* [https://www.google.ch/search?q=sys.append.path+site%3Aforum.freecadweb.org#q=calculix+site:forum.freecadweb.org calculix site:forum.freecadweb.org]


{{FEM Tools navi/fr}}
{{Userdocnavi/fr}}


{{clear}}
{{clear}}

Revision as of 10:35, 8 May 2019

Introduction

Pour pouvoir effectuer une analyse par éléments finis (FEA) dans atelier FEM, FreeCAD utilise deux programmes externes: l’un est utilisé pour générer le FEM Mesh, l’autre pour la résolution numérique du analyse réelle. Vous pouvez tester si votre installation FreeCAD est prête pour FEA en exécutant l’exemple FEM CalculiX Cantilever 3D fourni avec l'installation de FreeCAD depuis la v0.17.

Workflow de l'atelier FEM; le plan de travail appelle deux programmes externes pour effectuer le maillage d'un objet solide et pour résoudre le problème des éléments finis

FEM Solver

Le solveur par défaut pour effectuer des calculs par éléments finis est CalculiX, un solveur simple pour l'analyse de structures. FreeCAD écrit un fichier d'entrée CalculiX, lance le solveur et lit le résultat qui peut ensuite être présenté visuellement dans la fenêtre d'affichage. Cela signifie que le binaire CalculiX est autonome et indépendant de FreeCAD. Etant donné que de nombreux programmes peuvent générer un maillage, il est recommandé d’installer le solveur et de s’assurer qu’il fonctionne en premier.

Si le solveur est correctement installé, vous pouvez exécuter la commande unique ccx dans le terminal pour obtenir une réponse simple:

User@PC:~$ ccx

Usage: CalculiX.exe -i jobname

Si le solveur est installé, assurez-vous que l'atelier FEM est capable de trouver le binaire. Allez à Edit → Preferences → FEM → CalculiX → Search in known binary directories. Si vous avez compilé le solveur vous-même, décochez l'option et donnez le chemin correct au fichier binaire. Pour les autres solveurs pouvant être utilisés avec FreeCAD, voir FEM Solveur.

Générateur de maillage FEM

Afin de créer un FEM Mesh, FreeCAD utilise Gmsh comme mailleur par défaut. Pour que cela fonctionne, Gmsh doit être installé séparément de FreeCAD.

Si le programme est correctement installé, vous pouvez exécuter la commande gmsh dans le terminal pour lancer l'interface graphique du programme. Cette interface n’est pas utilisée par FreeCAD mais montre que le programme est installé.

User@PC:~$ gmsh -info

Version          : 3.0.6
License          : GNU General Public License
Build OS         : Linux64
Build date       : 20171107
Build host       : lgw01-amd64-034
Build options    : 64Bit Ann Bamg Bfgs Blas(Generic) Blossom C++11 Cgns Chaco DIntegration Dlopen Fltk Gmm Jpeg Kbipack Lapack(Generic) LinuxJoystick MPI MathEx Med Mesh Mmg3d Mpeg NativeFileChooser Netgen ONELAB ONELABMetamodel OpenCASCADE OpenGL OptHom Parser Plugins Png Post Python Solver TetGen/BR Tetgen Voro3D Zlib
FLTK version     : 1.3.4
OCC version      : 6.9.1
MED version      : 3.0.6
Packaged by      : buildd
Web site         : http://gmsh.info
Mailing list     : gmsh@onelab.info

Si le mailleur est installé, assurez-vous que FEM Workbench est capable de trouver le binaire. Allez à Edit → Preferences → FEM → Gmsh → Search in known binary directories. Si vous avez compilé le mailleur vous-même, décochez l'option et donnez le chemin correct au fichier binaire. Voir FEM Mesh pour les différentes possibilités d'obtenir un maillage valide pour l'analyse.

Netgen

Note: le mailleur Netgen a été désactivé en mars 2017, lorsque FreeCAD est passé à l'utilisation de OCCT 7.1. Modifiez ces informations si Netgen est à nouveau utilisable avec la version stable de FreeCAD.

Dans les versions précédentes de FreeCAD, Netgen était le mailleur par défaut. Pour fonctionner avec l'atelier FEM, FreeCAD devait être lié aux bibliothèques Netgen au moment de la compilation. Alors que FreeCAD passait de OCE 0.17 à OCCT 7.1, Netgen 4.9.13 n'a pas réussi à établir de liaison avec cette version d'OCCT. Il a donc été décidé de supprimer le support Netgen dans Atelier FEM (le bouton Netgen button a été enlevé). Néanmoins, peu après, certains utilisateurs ont signalé qu'ils avaient réussi à appliquer une correction à Netgen 5.3.1, qui fonctionnait donc avec OCCT 7.x et FreeCAD.

Pour référence historique, voir les discussions:

Bien que Netgen ne soit pas disponible à partir de Atelier FEM, il peut toujours être utilisé seul pour produire des maillages pouvant être importés.

Si le programme est correctement installé, vous pouvez exécuter la commande netgen dans le terminal pour lancer l'interface graphique du programme.

User@PC:~$ netgen -V

NETGEN-6.2-dev
Developed by Joachim Schoeberl at
2010-xxxx Vienna University of Technology
2006-2010 RWTH Aachen University
1996-2006 Johannes Kepler University Linz
Including OpenCascade geometry kernel
Run parallel Netgen with 'mpirun -np xy netgen'
NETGENDIR = .
Tcl header version = 8.6.8
Tcl runtime version = 8.6.8 
using internal Tcl-script
optfile ./ng.opt does not exist - using default values
togl-version : 2
OCC module loaded

Installation sous Windows

Les packages FreeCAD disponibles sur la page Téléchargements incluent déjà Netgen et CalculiX, aucun logiciel supplémentaire ne doit donc être installé.

Installation sous Linux

Les distributions Linux ont différentes manières d'installer un logiciel. De nombreuses distributions ont des référentiels de logiciels et des gestionnaires de paquets; avant de compiler le code source, recherchez dans votre gestionnaire de paquets pour netgen, gmsh, calculix-ccx ou ccx et installez-les après la instructions de votre propre distribution.

PPA sous Ubuntu

Les freecad-stable et freecad-daily PPA (personal package archives) fournissent une version de FreeCAD plus récente que celle disponible dans les dépôts officiels d'Ubuntu. Ces PPA incluent également les derniers netgen, gmsh et calculix-ccx. Voir Installation sous Unix pour plus d'informations sur la configuration des référentiels.

Si un PPA est déjà ajouté à votre système, installez les packages comme suit

sudo apt-get install netgen
sudo apt-get install gmsh
sudo apt-get install calculix-ccx

Le PPA freecad-community fournit également les netgen, gmsh et calculix-ccx paquets à tester. S'ils sont suffisamment stables, ils peuvent être ajoutés aux référentiels quotidiens ou stables.

Note: le fil Ubuntu Repository traite de la création des packages PPA Ubuntu. Au moment de sa rédaction, CalculiX n'était pas inclus dans les référentiels Debian. Il y avait donc plusieurs paquets personnels dans Launchpad. Un seul paquet doit être installé.

Arch Linux

Récupérez le package CalculiX à partir de AUR repository.

Debian

binaire CalculiX

Les auteurs CalculiX fournissent un binaire Linux précompilé du solveur. Il peut être téléchargé à partir du site web des auteurs. Cependant, étant donné que les différentes distributions Linux ont des chemins de bibliothèque différents, ce binaire ne fonctionnera probablement pas sans certains ajustements.

Pour utiliser le binaire avec Fedora 21, voir le fil Making FEM run on linux fedora 21. Pour les versions plus récentes de Fedora, vous devez compiler CalculiX vous-même.

Si vous utilisez ce binaire, vérifiez que le binaire est exécutable, qu'il se trouve dans l'exécutable $PATH de votre système et que vous disposez de la version nécessaire des bibliothèques (libgfortran, liblapack, libblas, etc.) pour lequel il a été compilé. Ceci est mentionné dans le message du forum FEM WB.

Utilisez la commande ldd pour voir les bibliothèques liées par le binaire. Installez les dépendances manquantes.

User@PC:~$ ldd /usr/bin/ccx

linux-vdso.so.1 (0x00007fffbabdc000)
 libspooles.so.2.2 => /usr/lib/x86_64-linux-gnu/libspooles.so.2.2 (0x00007fe9bd042000)
 libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fe9bce23000)
 libarpack.so.2 => /usr/lib/x86_64-linux-gnu/libarpack.so.2 (0x00007fe9bcbd9000)
 liblapack.so.3 => /usr/lib/x86_64-linux-gnu/liblapack.so.3 (0x00007fe9bc353000)
 libgfortran.so.4 => /usr/lib/x86_64-linux-gnu/libgfortran.so.4 (0x00007fe9bbf74000)
 libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fe9bbbd6000)
 libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fe9bb7e5000)
 libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fe9bb5cd000)
 libmpi.so.20 => /usr/lib/x86_64-linux-gnu/libmpi.so.20 (0x00007fe9bb2db000)
 /lib64/ld-linux-x86-64.so.2 (0x00007fe9bdaa9000)
 libblas.so.3 => /usr/lib/x86_64-linux-gnu/libblas.so.3 (0x00007fe9bb080000)
 libopenblas.so.0 => /usr/lib/x86_64-linux-gnu/libopenblas.so.0 (0x00007fe9b8dda000)
 libquadmath.so.0 => /usr/lib/x86_64-linux-gnu/libquadmath.so.0 (0x00007fe9b8b9a000)
 libopen-rte.so.20 => /usr/lib/x86_64-linux-gnu/libopen-rte.so.20 (0x00007fe9b8912000)
 libopen-pal.so.20 => /usr/lib/x86_64-linux-gnu/libopen-pal.so.20 (0x00007fe9b8660000)
 librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007fe9b8458000)
 libhwloc.so.5 => /usr/lib/x86_64-linux-gnu/libhwloc.so.5 (0x00007fe9b821b000)
 libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fe9b8017000)
 libutil.so.1 => /lib/x86_64-linux-gnu/libutil.so.1 (0x00007fe9b7e14000)
 libnuma.so.1 => /usr/lib/x86_64-linux-gnu/libnuma.so.1 (0x00007fe9b7c09000)
 libltdl.so.7 => /usr/lib/x86_64-linux-gnu/libltdl.so.7 (0x00007fe9b79ff000)

Compiler CalculiX

CalculiX étant une application autonome, vous pouvez installer un fichier binaire empaqueté pour votre distribution ou le compiler vous-même. A partir de la version 2.7.x, CalculiX devrait fonctionner avec FreeCAD. Etant donné que le code n'a pas beaucoup changé depuis des années, des versions plus basses que la version 2.7.x peuvent également fonctionner.

Compiler CalculiX est une tâche pour des utilisateurs expérimentés, nécessitant la modification des Makefiles et des options de construction de différentes plates-formes. Voir les informations suivantes:

Compiler Netgen

Netgen était initialement lié par FreeCAD lorsque FreeCAD a utilisé OCE, le fork de la communauté d'OpenCascade (OCCT). Alors que OCE accusait un retard de développement par rapport à OCCT, FreeCAD est revenu à OCCT. Cela a rompu la liaison de Netgen, qui ne pouvait se lier qu'à OCCT 6.9 ou à OCE 0.18 et au-dessous. Les versions OCCT 7.x améliorant la fonctionnalité de base de FreeCAD, il a été décidé de supprimer le support Netgen au profit de Gmsh.

Depuis lors, quelques succès ont été obtenus en corrigeant et en liant les nouvelles versions de Netgen avec OCCT 7.x. Néanmoins, l'inclusion de Netgen avec FreeCAD reste problématique.

Installation sous OSX

Ces informations peuvent être obsolètes. Si vous êtes un utilisateur OSX, veuillez tester et corriger cette section

Les packages de développement OSX development packages de FreeCAD peuvent inclure Netgen mais ne peuvent pas inclure CalculiX.

Voir cet article du forum FEM on Mac OSX pour plus d'informations sur l'installation de CalculiX et un updated post pour des informations plus récentes.

Les articles suivants peuvent être obsolètes:

Plus d'informations

L'atelier FEM est en développement constant. Les informations les plus récentes se trouvent sur le Forum FreeCAD.

Si vous rencontrez des problèmes pour installer Netgen, Gmsh ou CalculiX, ou un autre outil externe, commencez par rechercher le forum correspondant: