Skip to main content

Finite element processing and visualization for geometrically exact deformations.

Project description

veux logo example structure rendered with veux

Finite element visualization


DOI Latest PyPI version

veux is a finite element visualization library that leverages modern web technologies to produce sharable, efficient, and detailed renderings.



Unlike most tools that only provide temporary visualization, veux generates persistent 3D models that can be stored in files, shared with colleagues, and viewed with any standard 3D model viewer. This means anyone can interact with the renderings without needing to install specialized software or even Python. Simply open the 3D object with your computer’s 3D viewer (e.g., 3D Viewer on Windows) or load it into a free online viewer in like gltf-viewer.

veux is further distinguished by its features for geometrically exact simulations of constrained bodies like rods and shells.

Documentation is available at https://veux.io/ and an extensive set of examples at https://gallery.stairlab.io.

Features

  • Detailed Render frames with extruded cross sections
  • Persistence: Save finite element visualizations as persistent 3D models that can be revisited and analyzed at any time.
  • Portability: Share renderings effortlessly with colleagues, enabling seamless collaboration and review.
  • Accessibility: View and interact with the models using any standard 3D model viewer, eliminating the need for specialized software or Python installation.

Getting Started

To install veux run:

pip install veux

Python Interface

To render a model directly from Python, use the veux.render function:

artist = veux.render(model, canvas=canvas)
  • model: the model parameter can be of several types
    • str (string) variables are treated like file paths. Supported files are .json and .tcl
    • dict variables are treated
    • Model variables from the xara Python package can be passed directly
  • canvas: The canvas parameter is a string which indicates which "backend" technology to use. The options are:
    • "gltf" is the default canvas and produces the highest quality renderings. You can save renderings drawn by this backend to either .html or .glb files. .glb files are preferred as they are a natural format for 3D objects and can be viewed by standard 3D viewing applications.
    • "plotly" is best for model debugging as it is able to embed model details like node/element numbers and properties with hover annotations. However, the renderings produced by this backend dont look quite as good as with gltf.
    • "matplotlib": can be used to programatically create .png files.

Once the artist is created, the rendering can either be displayed or saved to a file. Each canvas supports slightly different options:

  • viewing To view a rendering that is generated either with canvas="gltf" or canvas="plotly", use the veux.serve() function:

    veux.serve(artist)
    

    After running you will see a message like the following printed to your terminal:

        Bottle v0.13.1 server starting up (using WSGIRefServer())...
        Listening on http://localhost:8081/
        Hit Ctrl-C to quit.
    

    Paste the URL from this message (eg, http://localhost:8081) into the address bar of a browser and an interactive rendering will appear.

  • saving Use the artist's save() method to write the rendering to a file. The file type depends on the canvas:

    • with canvas="gltf", files are saved in the glTF format with extension .glb:
      ...
      artist.save("model.glb")
      
    • with canvas="plotly", files are saved in to HTML:
      ...
      artist.save("model.html")
      
    • with canvas="matplotlib", files are saved in as PNGs:
      ...
      artist.save("model.png")
      
      Note, however, that renderings produced by the "matplotlib" canvas are generally very poor quality. For high quality images, use the "gltf" canvas and take screen captures.

Command Line Interface

To create a rendering, execute the following command from the anaconda prompt (after activating the appropriate environment):

python -m veux model.json -o model.html

where model.json is a JSON file generated from executing the following OpenSees command:

print -JSON model.json

If you omit the -o <file.html> portion, it will plot immediately in a new window. You can also use a .png extension to save a static image file, as opposed to the interactive html.

Note Printing depends on the JSON output of a model. Several materials and elements in the OpenSeesPy and upstream OpenSees implementations do not correctly print to JSON. For the most reliable results, use the xara package for interpreting OpenSees.

By default, the rendering treats the $y$ coordinate as vertical. In order to manually control this behavior, pass the option --vert 3 to render model $z$ vertically, or --vert 2 to render model $y$ vertically.

If the opensees package is installed, you can directly render a Tcl script without first printing to JSON, by just passing a Tcl script instead of the JSON file:

python -m veux model.tcl -o model.html

To plot an elevation (elev) plan (plan) or section (sect) view, run:

python -m veux model.json --view elev

and add -o <file.extension> as appropriate.

To see the help page run

python -m veux --help

Related Links

The veux packages was used to generate figures for the following publications:

Gallery

Support

PEER Logo Caltrans Logo STAIRlab Logo

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

veux-0.0.25.tar.gz (381.1 kB view details)

Uploaded Source

Built Distribution

veux-0.0.25-py3-none-any.whl (402.0 kB view details)

Uploaded Python 3

File details

Details for the file veux-0.0.25.tar.gz.

File metadata

  • Download URL: veux-0.0.25.tar.gz
  • Upload date:
  • Size: 381.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for veux-0.0.25.tar.gz
Algorithm Hash digest
SHA256 e62eb5a3d46a83680a969508d6959d883368f7e8b07bcb38bcdbeb2c1543d4c7
MD5 a6ff8c02375bf4df96a72248420d0d9e
BLAKE2b-256 1cd85c3515b3c29525de7e68c74f5c800bb8825c8d85531d97129532349a1b93

See more details on using hashes here.

File details

Details for the file veux-0.0.25-py3-none-any.whl.

File metadata

  • Download URL: veux-0.0.25-py3-none-any.whl
  • Upload date:
  • Size: 402.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for veux-0.0.25-py3-none-any.whl
Algorithm Hash digest
SHA256 6a682f7495de297de68279f4e61160544f9018d69c285a9d25ebce1d91778ea0
MD5 e25a223f6ebdd18b980f8d8a8eb45b2b
BLAKE2b-256 b2ad19cad5215c197d04fa89c1843d284be35c813f1a4fe199d5cf93bc83cb4e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page