C Iteration über mehrere Programmmodule: Unterschied zwischen den Versionen

Aus ITP
Zur Navigation springen Zur Suche springen
Keine Bearbeitungszusammenfassung
Zeile 16: Zeile 16:


Entweder man "tippert" viel, oder man steckt diesen Algorithmus in eine Iteration:
Entweder man "tippert" viel, oder man steckt diesen Algorithmus in eine Iteration:


!#!Kapitel weitere Lastsellungen
!#!Kapitel weitere Lastsellungen
+prog template urs:10
+prog template urs:10
kopf Definition für die Iteration
kopf Definition für die Iteration
sto#lastst      2      $ Laststellung
sto#lastst      2      $ Laststellung
sto#plf        101    $ Primärlastfall
sto#plf        101    $ Primärlastfall
sto#lf          #plf+1  $ aktuelle Lastfallnummer
sto#lf          #plf+1  $ aktuelle Lastfallnummer
sto#lc          22      $ aktuelle Belastung
sto#lc          22      $ aktuelle Belastung
ende
ende


!#!Kapitel Iteration
!#!Kapitel Iteration
+prog aqua iter 99 urs:8
+prog aqua iter 99 urs:8
kopf Neudefinition der Federarbeitslinien
kopf Neudefinition der Federarbeitslinien
let#lastst 2    $ Laststellung
let#lastst 2    $ Laststellung
<nowiki>#include steuaqua
<nowiki>#include steuaqua
#include neudefinition</nowiki>
#include neudefinition</nowiki>
ende
ende


+PROG ASE iter 99 urs:9
+PROG ASE iter 99 urs:9
KOPF nicht lineare Berechnung
KOPF nicht lineare Berechnung
<nowiki>#include steuase
<nowiki>#include steuase
#include berechnungase</nowiki>
#include berechnungase</nowiki>
ENDE
 
ende


+prog template iter 99 urs:11
+prog template iter 99 urs:11
kopf Neunummerierung oder Abbruch
kopf Neunummerierung oder Abbruch
if #lc<#lfnrn
if #lc<#lfnrn
         sto#lastst      #lastst+1      $ Laststellung
         sto#lastst      #lastst+1      $ Laststellung
         sto#plf        #plf+1          $ Primärlastfall
         sto#plf        #plf+1          $ Primärlastfall
         sto#lf          #plf+1          $ aktuelle Lastfallnummer
         sto#lf          #plf+1          $ aktuelle Lastfallnummer
         sto#lc          #lc+1          $ aktuelle Belastung
         sto#lc          #lc+1          $ aktuelle Belastung
else
else
         exit_iteration
         exit_iteration
endif
endif
ende
ende
[[Kategorie:Allgemeines zu CADINP]]
[[Kategorie:Allgemeines zu CADINP]]

Version vom 15. November 2019, 06:44 Uhr

Hinweise

guter Artikel in Forum

s.a. SOFiSTiK - Handbuch "Basisfunktionalitäten" Abschn. 9.6

Bei solchen Berechnungen ist "echte" Kontrolle nicht möglich. Daher sind Plausibilitätskontrollen der Weg. Zu allererst gilt es "Kontrolllastfälle" zu berechnen. Hierbei wird getestet, ob das System plausible Ergebnisse liefert. Eine Möglichkeit sind die Verformungen, eine weitere die Schnittgrößen.

Bei der Iteration gilt es zu kontrollieren, ob auch tatsächlich die korrekten Arbeitslinien entsprechend der Laststellungen verwendet werden.

Auch eine grafische Darstellung der Federwege und Federkräfte ist eine gute Kontrollmöglichkeit. Federn, welche bereits das Fließnievau erreicht haben und deren Steifigkeit nicht erhöht wurde, können keine weiteren Kräfte aufnehmen, aber die Verformungen steigen ggf. weiter an.


Beispiel

Bei der Berechnung von Schienenspannungen müssen für jede Laststellung die Steifigkeiten der Federn angepasst werden. Außerdem ist bei der anschließenden nichtlinearen Berechnung die jeweils vorherige Laststellung als Primärlastfall zu berücksichtigen.

Entweder man "tippert" viel, oder man steckt diesen Algorithmus in eine Iteration:


!#!Kapitel weitere Lastsellungen +prog template urs:10

kopf Definition für die Iteration

sto#lastst 2 $ Laststellung

sto#plf 101 $ Primärlastfall

sto#lf #plf+1 $ aktuelle Lastfallnummer

sto#lc 22 $ aktuelle Belastung

ende

!#!Kapitel Iteration

+prog aqua iter 99 urs:8

kopf Neudefinition der Federarbeitslinien

let#lastst 2 $ Laststellung

#include steuaqua #include neudefinition

ende

+PROG ASE iter 99 urs:9

KOPF nicht lineare Berechnung

#include steuase #include berechnungase

ende

+prog template iter 99 urs:11

kopf Neunummerierung oder Abbruch

if #lc<#lfnrn

       sto#lastst      #lastst+1       $ Laststellung
       sto#plf         #plf+1          $ Primärlastfall
       sto#lf          #plf+1          $ aktuelle Lastfallnummer
       sto#lc          #lc+1           $ aktuelle Belastung

else

       exit_iteration

endif

ende