Skip to main content

Finite Element (FE) Digital Image/Volume Correlation (DIC/DVC) library for experimental mechanics

Project description

pyxel

python library for experimental mechanics using finite elements

pyxel is an open-source Finite Element (FE) Digital Image/Volume Correlation (DIC/DVC) library for experimental mechanics application. It is freely available for research and teaching.

In its present form, it is restricted to 2D-DIC and 3D-DVC. Stereo (SDIC) will be updated later. The gray level conservation problem is written in the physical space. It relies on camera models (which must be calibrated) and on a dedicated quadrature rule in the FE mesh space. Considering front-parallel camera settings, the implemented camera model is a simplified pinhole model (including only 4 parameters 2D: 2 translations, 1 rotation and the focal length and 7 parameters in 3D: focal length, 3 rotations, 3 translations). More complex camera models (including distorsions) could easily be implemented within this framework (next update?). The library natively includes linear and quadratic triangles, quadrilateral, tetraedral, hexaedral elements. The library also exports the results in different format such that the measurements can be post-processed ether with MatPlotLib or using Paraview.

  1. SCRIPT FILE

    • pyxel is a library. For each testcase, a script file must be written.
    • a set of sample scripts named example_#.py is provided in the ./test folder to understand the main functionnalities of the library.
  2. ABOUT MESHES

    • A Finite Element mesh is required for the displacement measurement. In pyxel, a mesh is entierly defined by two variables:
      (1) a python dictionary for the elements (the key is the element type and the value is a numpy array of size NE * NN (NN being the number of nodes of this element type and NE the number of elements). The element type label (according to gmsh numbering). example:
      e = dict()
      e[3] = np.array([[n0, n1, n2, n3]])
      
      (2) a numpy array n for the node coordinates, example:
      n = np.array([[x0, y0], [x1, y1], ...])
      
    • There is an home made mesher for parallelipedic domains, given the approximate elements size in each direction (see examples). We recommand to use external meshers like, for instance, gmsh
    • To read/write the meshes, we use the usefull library meshio.
  3. MINIMAL SAMPLE CODE

    • to run a simple 2D-DIC analysis:
      f = px.Image('img-0.tif').Load()
      g = px.Image('img-1.tif').Load()
      roi = np.array([[ 100,   100], [ 500,  500]])
      m, cam = px.MeshFromROI(roi, 50, f, typel=3)
      U, res = px.Correlate(f, g, m, cam)
      
    • A multiscale initialization is usually required
      U = px.MultiscaleInit(f, g, m, cam, scales=[3, 2, 1], l0=30)
      
  4. OUTPUT FILES

    • It is possible to post-process the results directly using matplotlib.
      m.PlotContourDispl(U, s=30)
      
    • but a more convenient way (especially in DVC) is to use Paraview www.paraview.org
      m.VTKSol('vtufile', U)
      
  5. TERM OF USE. This program is a free software: you can redistribute it/or modify it. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY. pyxel is distributed under the terms of CeCILL which is a french free software license agreement in the spirit of GNU GPL

  6. DEPENDANCIES numpy, scipy, matplotlib, opencv-python, scikit-image, meshio, gmsh

  7. INSTALL

    • It is possible to clone the git repository, or simply install it using PyPI:
      pip install pyxel-dic
      

References

Jean-Charles Passieux, Robin Bouclier. Classic and Inverse Compositional Gauss-Newton in Global DIC. International Journal for Numerical Methods in Engineering, 119(6), p.453-468, 2019.

Jean-Charles Passieux. pyxel, an open-source FE-DIC library. Zenodo. http://doi.org/10.5281/zenodo.4654018

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

pyxel-dic-3.0.9.tar.gz (77.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyxel_dic-3.0.9-py3-none-any.whl (77.5 kB view details)

Uploaded Python 3

File details

Details for the file pyxel-dic-3.0.9.tar.gz.

File metadata

  • Download URL: pyxel-dic-3.0.9.tar.gz
  • Upload date:
  • Size: 77.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for pyxel-dic-3.0.9.tar.gz
Algorithm Hash digest
SHA256 280e31a26e2d789a0195c42a9dd36d5795e70ed5f8bbc1dc4ef8230c1f2c75e7
MD5 c3b200e049d3c82d61c2d5a46643012f
BLAKE2b-256 c7af279e320192c9f20ccedffc767056254239e0c17ea2bf4c43332f4cfa72fa

See more details on using hashes here.

File details

Details for the file pyxel_dic-3.0.9-py3-none-any.whl.

File metadata

  • Download URL: pyxel_dic-3.0.9-py3-none-any.whl
  • Upload date:
  • Size: 77.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for pyxel_dic-3.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 a71dda8d40e15457e9dd10eec4842f0b6a480b4298130ab492c4a1b4d0cf9bcb
MD5 17dd10a78dd83498db13615e77e21873
BLAKE2b-256 8930ab194b8c9be3adaa9cc5664a0969f8ccc5260181304daeafb83fabcc96fc

See more details on using hashes here.

Supported by

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