FreeCAD Logo FreeCAD 1.0
  • Englisch Afrikaans Arabisch Weißrussisch Katalanisch Tschechisch Deutsch Griechisch Spanisch Spanisch Baskisch Finnisch Philippinisch Französisch Galicisch Kroatisch Ungarisch Indonesisch Italienisch Japanisch Kabylisch Koreanisch Litauisch Niederländisch Norwegisches Bokmål Polnisch Portugiesisch Portugiesisch Rumänisch Russisch Slowakisch Slowenisch Serbisch Schwedisch Türkisch Ukrainisch Valencianisch Vietnamesisch Chinesisch Chinesisch
  • Funktionen
  • Herunterladen
  • Blog
  • Dokumentation
    Inhaltsverzeichnis Erste Schritte Benutzerdokumentation Das FreeCAD-Handbuch Dokumentation der Arbeitsbereiche Python-Dokumentation Dokumentation der C++ Programmierung Anleitungen Häufig gestellte Fragen Datenschutzrichtlinie Über FreeCAD
  • Mitwirken
    Wie kann ich helfen Sponsor Einen Fehler melden Einen Pull Request durchführen Jobs und Finanzierung Richtlinien für Beiträge Entwicklerhandbuch Übersetzungen
  • Community
    Verhaltenskodex Forum The FPA GitHub GitLab Codeberg Mastodon Matrix IRC IRC via Webchat Gitter Discord Reddit Twitter Facebook LinkedIn Kalender
  • ♥ Donate

Donate

$
SEPA-Informationen
Bitte richten Sie Ihre SEPA-Überweisung an:
Beneficiary: The FreeCAD project association
IBAN: BE04 0019 2896 4531
BIC/SWIFT: GEBABEBBXXX
Kreditinstitut: BNP Paribas Fortis
Adresse: Rue de la Station 64, 1360 Perwez, Belgium

While Stripe doesn't support monthly donations, you can still become a sponsor! Simply make a one-time donation equivalent to 12 months of support, and you'll gain access to the corresponding sponsoring tier. It's an easy and flexible way to contribute.

If you are not sure or not able to commit to a regular donation, but still want to help the project, you can do a one-time donation, of any amount.

Choose freely the amount you wish to donate one time only.

You can support FreeCAD by sponsoring it as an individual or organization through various platforms. Sponsorship provides a steady income for developers, allowing the FPA to plan ahead and enabling greater investment in FreeCAD. To encourage sponsorship, we offer different tiers, and unless you choose to remain anonymous, your name or company logo will be featured on our website accordingly.

from 1 USD / 1 EUR per month. You will not have your name displayed here, but you will have helped the project a lot anyway. Together, normal sponsors maintain the project on its feet as much as the bigger sponsors.

from 25 USD / 25 EUR per month. Your name or company name is displayed on this page.

from 100 USD / 100 EUR per month. Your name or company name is displayed on this page, with a link to your website, and a one-line description text.

from 200 USD / 200 EUR per month. Your name or company name and logo displayed on this page, with a link to your website and a custom description text. Companies that have helped FreeCAD early on also appear under Gold sponsors.

Instead of donating each month, you might find it more comfortable to make a one-time donation that, when divided by twelve, would give you right to enter a sponsoring tier. Don't hesitate to do so!

Choose freely the amount you wish to donate each month.

Please inform your forum name or twitter handle as a notein your transfer, or reach to us, so we can give you proper credits!

Anleitung
Thema
FEM
Niveau
fortgeschrittener Anfänger
Bearbeitungszeit
1 Stunde
Autoren
M42kus
FreeCAD-Version
0.17
Beispieldateien
Siehe auch
None

Der Arbeitsbereich FEM unterstützt schon viele unterschiedliche Randbedingungen und mehrere Berechnungsprogramme (Löser). Trotzdem brauchen Anwender oft Randbedingungen, die noch nicht von FreeCAD unterstützt werden. Diese Seite ist Startpunkt für eine Reihe von Anleitungen und anderen Quellen, die beschreiben, wie der Arbeitsbereich FEM mit dem vorhandenen Framework (<-?) erweitert werden kann. Während diese Reihe auch für Software-Entwickler hilfreich sein kann, ist die Idee dahinter, dass FEM-Anwender mit etwas Interesse für Python-Programmierung ermöglicht wird, selbst hinzuzufügen, was sie brauchen.

Neue Beschränkungen, Gleichungen oder Löser hinzuzufügen ist hauptsächlich Routinearbeit. Aber beim ersten Mal ist es wahrscheinlich nicht so einfach, wie es aussieht. Ein Verständnis für die folgenden Themen wird hilfreich sein:

  • Python-Skripting in FreeCAD.
    • Tutorial Skripterstellung mit Python
    • Grundlagen der Skripterstellung in FreeCAD
  • FreeCAD mit Python erweitern.
    • Skriptgenerierte Objekte
  • Ein grundlegendes Verständnis des Lösers, für den neue Objekte hinzugefügt werden sollen (z. B. CalculiX oder Elmer), ist wichtig.
  • Ein wenig Wissen über Build-Systeme, insbesondere CMake (das von FreeCAD verwendete Build-System).

Build-System (cmake)

Das Build-System muss unabhängig davon geändert werden, welche Objekte zum Arbeitsbereich FEM hinzugefügt werden sollen. Jedes Python-Modul (Datei) muss registriert werden. Der Arbeitsbereich FEM erfordert, dass jedes neue Python-Modul in Mod/Fem/CMakeLists.txt registriert wird. Dies gilt unabhängig vom Typ des Python-Moduls (GUI oder Nicht-GUI). Wo genau das Modul eingefügt werden muss, hängt von der Rolle des Moduls ab. Löser, Gleichungen und Beschränkungen verwenden alle unterschiedliche Listen. Meistens funktioniert es, nach ähnlichen Dateien zu suchen und die neue Datei in dieselbe Liste einzufügen.

Als Beispiel fügen wir eine neue Einschränkung namens pressure hinzu, die mit der Strömungsgleichung zusammenhängt. Daher wird FlowPressure häufig als Name für diese Beschränkung verwendet. Eine neue Beschränkung erfordert mindestens die folgenden neuen Module:

  • constraint_<name>.py
  • view_constraint_<name>.py
  • CommandFemConstraint<name>.py (kann unnötig sein)

Diese drei Dateien müssen zu Mod/Fem/CMakeLists.txt hinzugefügt werden, genauso wie Mod/Fem/App/CMakeLists.txt. Alle eingefügten Codezeilen werden durch einen Startbefehl gekennzeichnet. +.

Mod/Fem/CMakeLists.txt

SET(FemObjects_SRCS
    femobjects/__init__.py
    femobjects/base_fempythonobject.py
    femobjects/constraint_bodyheatsource.py
    femobjects/constraint_electrostaticpotential.py
    femobjects/constraint_flowvelocity.py
    femobjects/constraint_initialflowvelocity.py
+   femobjects/constraint_initialflowpressure.py
    femobjects/constraint_selfweight.py
...
    femobjects/solver_ccxtools.py
)
...
SET(FemGuiViewProvider_SRCS
    femviewprovider/__init__.py
    femviewprovider/view_base_femconstraint.py
    femviewprovider/view_base_femobject.py
    femviewprovider/view_constraint_bodyheatsource.py
    femviewprovider/view_constraint_electrostaticpotential.py
    femviewprovider/view_constraint_flowvelocity.py
+   femviewprovider/view_constraint_flowpressure.py
    femviewprovider/view_constraint_initialflowvelocity.py
    femviewprovider/view_constraint_selfweight.py
...
    femviewprovider/view_solver_ccxtools.py
)

Quellorganisation

Zur Organisation des Python-Codes verwendet das FEM-Modul den folgenden Ansatz. Das Modul ist in die folgenden Pakete unterteilt:

  • femobjects, das alle nicht-GUI-ähnlichen Python-Proxys für Dokumentobjekte enthält, und
  • femviewproviders, das alles GUI-bezogene wie Python-Proxys für View-Provider enthält
  • C++-basierte Aufgabenfelder werden in 'Gui' gespeichert,
  • Symbole finden sich in 'Gui/Resources/icons/',
  • .ui-Dateien werden in 'Gui/Resources/ui/' gespeichert.

Ein Paket folgt diesem Muster nicht: femsolver. Es befindet sich auf derselben Ebene wie femobjects und femguiobjects (src/Mod/Fem/femsolver). Das Paket enthält Löser- und Gleichungs-bezogene Pakete und Module und ist wie folgt organisiert:

.femsolver
.femsolver.elmer
.femsolver.elmer.equations
.femsolver.calculix
.femsolver.calculix.equations
.femsolver.z88
.femsolver.z88.equations

Löser

In FreeCAD kann ein Löser in zwei Teile unterteilt werden:

  • Der eine Teil ist das Dokumentobjekt, das vom Benutzer zur Interaktion mit dem Löser verwendet wird. Über dieses Objekt können die Löser-Parameter eingestellt und der Lösungsprozess gesteuert werden.
  • Der andere Teil sind die sogenannten Aufgaben eines Lösers. Der Lösungsprozess ist in diese Aufgaben unterteilt, nämlich: Prüfen, Vorbereiten, Lösen und Ergebnisse. Diese übernehmen die eigentliche Arbeit, indem sie die Analyse in ein Format exportieren, das vom Löser-Programm verstanden wird, das Programm starten und die Ergebnisse wieder in FreeCAD laden.

Die meisten Dateien, die sich auf einen Löser beziehen, befinden sich in einem Unterpaket des Pakets femsolver (z. B. für Elmer in femsolver/elmer). Die folgende Liste enthält alle Dateien, die mit der Implementierung eines Lösers zusammenhängen. Dies sind die Dateien, die kopiert und geändert werden müssen, um FreeCAD um einen neuen Löser zu erweitern. Das angegebene Beispiel stammt aus der Löser-Implementierung von Elmer.

  • femsolver/elmer/solver.py: Dokumentobjekt in der Baumansicht sichtbar. Implementiert in Python über einen Dokument-Proxy und einen Ansichts-Proxy.
  • femsolver/elmer/tasks.py: Modul, das eine Aufgabenklasse pro Aufgabe enthält, die für eine Löser-Implementierung erforderlich ist. Diese Aufgaben unterteilen den Prozess der Lösung einer Analyse in die folgenden Schritte: Prüfen, Vorbereiten, Lösen, Ergebnisse.
  • femcommands/commands.py: Fügt das Löser-Dokumentobjekt zum aktiven Dokument hinzu. Erforderlich, um über die Grafische Benutzeroberfläche auf das Löser-Objekt zuzugreifen.

Gleichungen

Eine Gleichung repräsentiert eine bestimmte physikalische Größe, die bei der Lösung der Analyse berücksichtigt werden muss (z. B. Strömung, Wärme). Nicht alle Löser in FreeCAD unterstützen (alle) Gleichungen. Gleichungen werden durch untergeordnete Objekte des entsprechenden Löser-Objekts dargestellt. In der Baumansicht sieht dies wie folgt aus:

  • Elmer-Löser
    • Elastizität
    • Wärme
    • Strömung
    • Elektrostatik

Die meisten löserspezifischen Optionen (z. B. maximale Iterationen, Lösungsmethode usw.) werden über die Gleichungsobjekte festgelegt. Eine Folge davon ist, dass jeder Löser seine eigene Implementierung derselben Gleichung haben muss. CalculiX hätte ein anderes Wärmeobjekt als Elmer. Um zu vermeiden, dass in der GUI mehrere Schaltflächen für dieselbe Physik vorhanden sind, fügt jedes Löserobjekt seine Gleichungen selbst hinzu.

Die eigentliche Implementierung kann in einen generischen und einen löserspezifischen Teil unterteilt werden. Der generische Teil befindet sich im Modul femsolver.equationbase. Der löserspezifische Teil befindet sich in einzelnen Equations-Unterpaketen der Löserpakete (z. B. femsolver/elmer/equations).

Das Hinzufügen neuer Gleichungen zu Elmer sollte sehr einfach sein. Für Neulinge gibt es ein Tutorial, das zeigt, wie man eine neue Gleichung zu Elmer hinzufügt, indem man den vorhandenen Elastizitätslöser zu FreeCAD hinzufügt: Tutorial FEM Gleichung hinzufügen.

Beschränkungen

Beschränkungen definieren Randbedingungen für das zu lösende Problem. In FreeCAD sind Beschränkungen nicht spezifisch für einen bestimmten Löser. Eine Problemkonfiguration kann von allen Lösern gelöst werden, die alle Bedingungen in der Analyse unterstützen.

Das Hinzufügen neuer Einschränkungen ist recht einfach. Für Neulinge gibt es ein Tutorium.: Tutorium FEM-Beschränkung hinzufügen.

Diese Seite wird abgerufen von https://wiki.freecad.org/Extend_FEM_Module

Kontaktiere uns!
Forum GitHub Mastodon Matrix IRC Gitter.im Discord Reddit Twitter Facebook LinkedIn

© Das FreeCAD-Team. Bildnachweis (von oben nach unten): ppemawm, r-frank, epileftric, regis, rider_mortagnais, bejant.

Dieses Projekt wird unterstützt von: , KiCad Services Corp. und andere Sponsoren

GitHubDiese Seite auf GitHub verbessern