NextFEM REST API wrapper in pure Python
Project description
NextFEMpy
NextFEM REST API wrapper in pure Python, to be used with NextFEM Designer or NextFEM Server. It is a complete set of REST API call, wrapped in Python functions, distinguishing between mandatory and optional arguments.
If you're looking for NextFEMpy source, look into /nextfempy folder. If you're looking for sample code using nextfempy, look into /samples folder.
Installation instructions
pip install nextfempy
Usage
Before using with your local installation of NextFEM Designer, start the plugin REST API Server.
from nextfempy import NextFEMrest
# connect to local copy of NextFEM Designer
nf=NextFEMapiREST.NextFEMrest()
To handle a property:
nf.autoMassInX=False
print(str(nf.autoMassInX))
To call a NextFEM API method:
nf.addOrModifyCustomData("test","Test")
print(nf.getCustomData("test"))
Sample code
A simple 3D frame using REST API. Remember to start the plugin REST API Server in NextFEM Designer.
import os
from nextfempy import NextFEMrest
# current dir, to be used eventually to save model
dir = os.path.dirname(os.path.realpath(__file__))
# connects to the open instance of NextFEM Designer with REST API server plugin running on your machine
nf=NextFEMrest()
# clear model
nf.newModel()
# material and section
mat=nf.addMatFromLib("C25/30"); print("Mat="+str(mat))
cSect=nf.addCircSection(0.2)
bSect=nf.addRectSection(0.2,0.2)
# nodes
n1=nf.addNode(0,0,0); n2=nf.addNode(0,0,3)
n3=nf.addNode(3,0,0); n4=nf.addNode(3,0,3)
n5=nf.addNode(0,3,0); n6=nf.addNode(0,3,3)
n7=nf.addNode(3,3,0); n8=nf.addNode(3,3,3)
# beams
b1=nf.addBeam(n1,n2,cSect,mat); b2=nf.addBeam(n3,n4,cSect,mat)
b3=nf.addBeam(n2,n4,bSect,mat)
b4=nf.addBeam(n5,n6,cSect,mat); b5=nf.addBeam(n7,n8,cSect,mat)
b6=nf.addBeam(n6,n8,bSect,mat)
b7=nf.addBeam(n2,n6,bSect,mat); b8=nf.addBeam(n4,n8,bSect,mat)
# restraints
nf.setBC(n1,True,True,True,True,True,True)
nf.setBC(n3,True,True,True,True,True,True)
nf.setBC(n5,True,True,True,True,True,True)
nf.setBC(n7,True,True,True,True,True,True)
# loading
nf.addLoadCase("sw"); nf.setSelfWeight("sw")
nf.addLoadCase("perm"); nf.addLoadCase("var")
# floorload type
print(nf.setFloorLoad("floor1","perm",-2.5,0,0,1)); print(nf.setFloorLoad("floor1","var",-3,0,0,1))
# floor plane on beams - nodes 2,4,8,6
print("Apply loading plane: " + str(nf.addFloorPlane("floor1",2,n2,n4,n8,n6)))
# analysis: run all loadcases and print outcome
print(nf.RunModel())
nf.refreshDesignerView(0,True)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nextfempy-0.2.9.tar.gz.
File metadata
- Download URL: nextfempy-0.2.9.tar.gz
- Upload date:
- Size: 50.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cfca7826e9cce21676905538ef1394130c2bbdb88fba39e15606cd6a90175afe
|
|
| MD5 |
facfbff521c77fb8bac998f4689bf7b4
|
|
| BLAKE2b-256 |
77cc09022969d74fed19984e69f9ce73bc9d5ea0630e500094518474e7f711e6
|
File details
Details for the file nextfempy-0.2.9-py3-none-any.whl.
File metadata
- Download URL: nextfempy-0.2.9-py3-none-any.whl
- Upload date:
- Size: 49.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ac1d9fb9d67f93c4ef225f7cdea96cd3ec45329c8faa6fe63f62d1161a069fc7
|
|
| MD5 |
5b58e60fc7930c73a65116340e4eba20
|
|
| BLAKE2b-256 |
fc4887a272c2214617b8b705a08d7f66cb6d31e27f9cb097b0f98bc70ce1e487
|