580x
005367
2023-03-23

Odczytywanie odkształcenia węzła za pomocą programu Python

Jak odczytać odkształcenie w określonym węźle za pomocą programu Python?


Odpowiedź:

W przykładowym programie najpierw tworzony jest wspornik z IPE 200. Jest on poddany obciążeniu na pręcie 3,5 kN i przeprowadzane są obliczenia.

Ta tabela jest dostępna w wierszu 34:

Metoda ResultTables.NodesDeformations () wymaga 3 argumentów. Najpierw określa się, jakiego rodzaju wyniki mają zostać odczytane. Mogą być to wyniki 

  • Przypadki obciążeń
  • Kombinacje obciążeń
  • Kombinacje wyników
  • Sytuacje obliczeniowe
  • Etapy budowy

sein.

Następnie podany zostanie numer przypadku obciążenia, kombinacji obciążeń itp. W końcu, numer węzła zostaje przeniesiony do metody. 

Wartość zwrotna d metody jest listą zawartą w słowniku. W wierszu 37, d jest wyświetlane w całości. Wiersz 40 pokazuje, w jaki sposób można uzyskać dostęp do określonej wartości. [0] jest indeksem listy, a [' displacement_z'] jest kluczem słownika.


            

from RFEM.enums import *
from RFEM.initModel import *
from RFEM.BasicObjects.material import Material
from RFEM.BasicObjects.section import Section
from RFEM.BasicObjects.node import Node
from RFEM.BasicObjects.member import Member
from RFEM.TypesForNodes.nodalSupport import NodalSupport
from RFEM.LoadCasesAndCombinations.staticAnalysisSettings import StaticAnalysisSettings
from RFEM.LoadCasesAndCombinations.loadCase import LoadCase
from RFEM.Loads.memberLoad import MemberLoad
from RFEM.Results.resultTables import ResultTables

Model(True, "Beam.rf6")
Model.clientModel.service.delete_all()
Model.clientModel.service.begin_modification()

Material(1, 'S235')
Section(1, 'IPE 200')

Node(1, 0.0, 0.0, 0.0)
Node(2, 5.0, 0.0, 0.0)

Member.Beam(1, 1, 2, start_section_no=1, end_section_no=1)

NodalSupport(1, '1', NodalSupportType.FIXED)

StaticAnalysisSettings.GeometricallyLinear(1, "Linear")
LoadCase(1, 'Load', [True, 0.0, 0.0, 1.0])

MemberLoad(1, 1, '1', magnitude=3500)

Calculate_all()

d = ResultTables.NodesDeformations(CaseObjectType.E_OBJECT_TYPE_LOAD_CASE, 1, 2)

# all:
print(d)

# displacement in Z
print(d[0]['displacement_z'])

Model.clientModel.service.finish_modification()



Autor

Pan Faulstich jest odpowiedzialny za zapewnienie jakości programu RFEM i zapewnia wsparcie klienta.