torch-fem


Nametorch-fem JSON
Version 0.3.5 PyPI version JSON
download
home_pageNone
SummaryGPU accelerated differential finite elements for solid mechanics with PyTorch.
upload_time2024-12-07 20:25:16
maintainerNone
docs_urlNone
authorNone
requires_python>=3.10
licenseCopyright 2024 Nils Meyer Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
keywords finite elements automatic differentiation
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/torch-fem)
[![PyPI - Version](https://img.shields.io/pypi/v/torch-fem)](https://pypi.org/project/torch-fem/)
[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/meyer-nils/torch-fem/HEAD)


# torch-fem
Simple GPU accelerated differentiable finite elements for small-deformation solid mechanics with PyTorch. 
PyTorch enables efficient computation of sensitivities via automatic differentiation and using them in optimization tasks.

## Installation
Your may install torch-fem via pip with
```
pip install torch-fem
```

*Optional*: For GPU support, install CUDA and the corresponding CuPy version with
```
pip install cupy-cuda11x # v11.2 - 11.8
pip install cupy-cuda12x # v12.x
```

## Features
- Elements
  - 1D: Bar1, Bar2
  - 2D: Quad1, Quad2, Tria1, Tria2
  - 3D: Hexa1, Hexa2, Tetra1, Tetra2
  - Shell: Flat-facet triangle (linear only)
- Material models (3D, 2D plane stress, 2D plane strain, 1D)
  - Isotropic linear elasticity 
  - Orthotropic linear elasticity
  - Isotropic plasticity
- Utilities
  - Homogenization of orthotropic stiffness
  - I/O to and from other mesh formats via meshio

## Basic examples
The subdirectory `examples->basic` contains a couple of Jupyter Notebooks demonstrating the use of torch-fem for trusses, planar problems, shells and solids. You may click on the examples to check out the notebooks online.

<table>
    <tbody>
        <tr>
            <td style="width: 30%;"><a href="https://meyer-nils.github.io/torch-fem/examples/basic/solid/gyroid.html"><img src="https://meyer-nils.github.io/torch-fem/gyroid.png"></a></td>
            <td style="width: 30%;"><a href="https://meyer-nils.github.io/torch-fem/examples/basic/solid/cubes.html"><img src="https://meyer-nils.github.io/torch-fem/cubes.png"></a></td>
            <td style="width: 30%;"><a href="https://meyer-nils.github.io/torch-fem/examples/basic/planar/cantilever.html"><img src="https://meyer-nils.github.io/torch-fem/cantilever_tria2.png"></a></td>
        </tr>
        <tr>
            <td align="center"><b>Gyroid:</b> Support for voxel meshes and implicit surfaces.</td>
            <td align="center"><b>Solid cubes:</b> There are several examples with different element types rendered in PyVista.</td>
            <td align="center"><b>Planar cantilever beams:</b> There are several examples with different element types rendered in matplotlib.</td>
        </tr>
        <tr>
            <td colspan="3"><a href="https://meyer-nils.github.io/torch-fem/examples/basic/planar/plasticity.html"><img src="https://meyer-nils.github.io/torch-fem/plate_hole_plasticity.png"></a></td>
        </tr>
        <tr>
            <td colspan="3" align="center"><b>Plasticity in a plate with hole:</b> Isotropic linear hardening model for plane-stress or plane-strain.</td>
        </tr>
    </tbody>
</table>

## Optimization examples
The subdirectory `examples->optimization` demonstrates the use of torch-fem for optimization of structures (e.g. topology optimization, composite orientation optimization). You may click on the examples to check out the notebooks online.

<table>
    <tbody>
        <tr>
            <td style="width: 50%;"><a href="https://meyer-nils.github.io/torch-fem/examples/optimization/truss/shape.html"><img src="https://meyer-nils.github.io/torch-fem/bridge.png"></a></td>
            <td style="width: 50%;"><a href="https://meyer-nils.github.io/torch-fem/examples/optimization/planar/shape.html"><img src="https://meyer-nils.github.io/torch-fem/fillet_shape_optimization.png"></a></td>
        </tr>
        <tr>
            <td align="center"><b>Shape optimization of a truss:</b> The top nodes are moved and MMA + autograd is used to minimize the compliance.</td>
            <td align="center"><b>Shape optimization of a fillet:</b> The shape is morphed with shape basis vectors and MMA + autograd is used to minimize the maximum stress.</td>
        </tr>
        <tr>
            <td style="width: 50%;"><a href="https://meyer-nils.github.io/torch-fem/examples/optimization/planar/topology.html"><img src="https://meyer-nils.github.io/torch-fem/topopt_mbb.png"></a></td>
            <td style="width: 50%;"><img src="https://meyer-nils.github.io/torch-fem/topopt_3d.png"></td>
        </tr>
        <tr>
            <td align="center"><b>Topology optimization of a MBB beam:</b> You can switch between analytical and autograd sensitivities.</td>
            <td align="center"><b>Topology optimization of a jet engine bracket:</b> The 3D model is exported to Paraview for visualization.</td>
        </tr>
        <tr>
            <td style="width: 50%;"><a href="https://meyer-nils.github.io/torch-fem/examples/optimization/planar/topology+orientation.html"><img src="https://meyer-nils.github.io/torch-fem/topo+ori.png"></a></td>
            <td style="width: 50%;"><a href="https://meyer-nils.github.io/torch-fem/examples/optimization/planar/orientation.html"><img src="https://meyer-nils.github.io/torch-fem/plate_hole_shape_optimization.png"></a>
            </td>
        </tr>
        <tr>
            <td align="center"><b>Combined topology and orientation optimization:</b> Compliance is minimized by optimizing fiber orientation and density of an anisotropic material using automatic differentiation.</td>
            <td align="center"><b>Fiber orientation optimization of a plate with a hole</b> Compliance is minimized by optimizing the fiber orientation of an anisotropic material using automatic differentiation w.r.t. element-wise fiber angles.</td>
        </tr>
    </tbody>
</table>


## Minimal example
This is a minimal example of how to use torch-fem to solve a very simple planar cantilever problem. 

```python
import torch
from torchfem import Planar
from torchfem.materials import IsotropicElasticityPlaneStress

torch.set_default_dtype(torch.float64)

# Material
material = IsotropicElasticityPlaneStress(E=1000.0, nu=0.3)

# Nodes and elements
nodes = torch.tensor([[0., 0.], [1., 0.], [2., 0.], [0., 1.], [1., 1.], [2., 1.]])
elements = torch.tensor([[0, 1, 4, 3], [1, 2, 5, 4]])

# Create model
cantilever = Planar(nodes, elements, material)

# Load at tip [Node_ID, DOF]
cantilever.forces[5, 1] = -1.0

# Constrained displacement at left end [Node_IDs, DOFs]
cantilever.constraints[[0, 3], :] = True

# Show model
cantilever.plot(node_markers="o", node_labels=True)
```
This creates a minimal planar FEM model:

![minimal](https://meyer-nils.github.io/torch-fem/minimal_example.png)

```python
# Solve
u, f, σ, ε, α = cantilever.solve()

# Plot displacement magnitude on deformed state
cantilever.plot(u, node_property=torch.norm(u, dim=1))
```
This solves the model and plots the result:

![minimal](https://meyer-nils.github.io/torch-fem/minimal_example_solved.png)

If we want to compute gradients through the FEM model, we simply need to define the variables that require gradients. Automatic differentiation is performed through the entire FE solver.
```python 
# Enable automatic differentiation
cantilever.thickness.requires_grad = True
u, f, _, _, _ = cantilever.solve()

# Compute sensitivity of compliance w.r.t. element thicknesses
compliance = torch.inner(f.ravel(), u.ravel())
torch.autograd.grad(compliance, cantilever.thickness)[0]
```

## Benchmarks 
The following benchmarks were performed on a cube subjected to a one-dimensional extension. The cube is discretized with N x N x N linear hexahedral elements, has a side length of 1.0 and is made of a material with Young's modulus of 1000.0 and Poisson's ratio of 0.3. The cube is fixed at one end and a displacement of 0.1 is applied at the other end. The benchmark measures the forward time to assemble the stiffness matrix and the time to solve the linear system. In addition, it measures the backward time to compute the sensitivities of the sum of displacements with respect to forces.

#### Apple M1 Pro (10 cores, 16 GB RAM)
Python 3.10, SciPy 1.14.1, Apple Accelerate

|  N  |     DOFs |  FWD Time |  BWD Time |   Peak RAM |
| --- | -------- | --------- | --------- | ---------- |
|  10 |     3000 |     0.16s |     0.08s |    571.4MB |
|  20 |    24000 |     0.71s |     0.28s |    883.0MB |
|  30 |    81000 |     2.71s |     1.17s |   1453.3MB |
|  40 |   192000 |     7.57s |     3.73s |   2351.0MB |
|  50 |   375000 |    16.20s |     8.94s |   3919.8MB |
|  60 |   648000 |    27.59s |    18.82s |   4855.9MB |
|  70 |  1029000 |    48.86s |    40.32s |   6761.7MB |
|  80 |  1536000 |    85.89s |    68.61s |   7454.9MB |
|  90 |  2187000 |   131.45s |   110.14s |   8457.8MB |
| 100 |  3000000 |   193.44s |   162.16s |   9898.3MB |


#### AMD Ryzen Threadripper PRO 5995WX (64 Cores, 512 GB RAM) and NVIDIA GeForce RTX 4090
Python 3.12, CuPy 13.3.0, CUDA 11.8

|  N  |     DOFs |  FWD Time |  BWD Time |   Peak RAM |
| --- | -------- | --------- | --------- | ---------- |
|  10 |     3000 |     0.66s |     0.15s |   1371.7MB |
|  20 |    24000 |     1.00s |     0.43s |   1358.9MB |
|  30 |    81000 |     1.14s |     0.65s |   1371.1MB |
|  40 |   192000 |     1.37s |     0.83s |   1367.3MB |
|  50 |   375000 |     1.51s |     1.04s |   1356.4MB |
|  60 |   648000 |     1.94s |     1.43s |   1342.1MB |
|  70 |  1029000 |     5.19s |     4.31s |   1366.8MB |
|  80 |  1536000 |     7.48s |    18.88s |   5105.6MB |



            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "torch-fem",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.10",
    "maintainer_email": null,
    "keywords": "finite elements, automatic differentiation",
    "author": null,
    "author_email": "Nils Meyer <nils.meyer@uni-a.de>",
    "download_url": "https://files.pythonhosted.org/packages/06/24/1bf026727fb159c96a492fd10012c00a57b92328a8fb32fe3c35a4657d34/torch_fem-0.3.5.tar.gz",
    "platform": null,
    "description": "[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n![PyPI - Python Version](https://img.shields.io/pypi/pyversions/torch-fem)\n[![PyPI - Version](https://img.shields.io/pypi/v/torch-fem)](https://pypi.org/project/torch-fem/)\n[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/meyer-nils/torch-fem/HEAD)\n\n\n# torch-fem\nSimple GPU accelerated differentiable finite elements for small-deformation solid mechanics with PyTorch. \nPyTorch enables efficient computation of sensitivities via automatic differentiation and using them in optimization tasks.\n\n## Installation\nYour may install torch-fem via pip with\n```\npip install torch-fem\n```\n\n*Optional*: For GPU support, install CUDA and the corresponding CuPy version with\n```\npip install cupy-cuda11x # v11.2 - 11.8\npip install cupy-cuda12x # v12.x\n```\n\n## Features\n- Elements\n  - 1D: Bar1, Bar2\n  - 2D: Quad1, Quad2, Tria1, Tria2\n  - 3D: Hexa1, Hexa2, Tetra1, Tetra2\n  - Shell: Flat-facet triangle (linear only)\n- Material models (3D, 2D plane stress, 2D plane strain, 1D)\n  - Isotropic linear elasticity \n  - Orthotropic linear elasticity\n  - Isotropic plasticity\n- Utilities\n  - Homogenization of orthotropic stiffness\n  - I/O to and from other mesh formats via meshio\n\n## Basic examples\nThe subdirectory `examples->basic` contains a couple of Jupyter Notebooks demonstrating the use of torch-fem for trusses, planar problems, shells and solids. You may click on the examples to check out the notebooks online.\n\n<table>\n    <tbody>\n        <tr>\n            <td style=\"width: 30%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/basic/solid/gyroid.html\"><img src=\"https://meyer-nils.github.io/torch-fem/gyroid.png\"></a></td>\n            <td style=\"width: 30%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/basic/solid/cubes.html\"><img src=\"https://meyer-nils.github.io/torch-fem/cubes.png\"></a></td>\n            <td style=\"width: 30%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/basic/planar/cantilever.html\"><img src=\"https://meyer-nils.github.io/torch-fem/cantilever_tria2.png\"></a></td>\n        </tr>\n        <tr>\n            <td align=\"center\"><b>Gyroid:</b> Support for voxel meshes and implicit surfaces.</td>\n            <td align=\"center\"><b>Solid cubes:</b> There are several examples with different element types rendered in PyVista.</td>\n            <td align=\"center\"><b>Planar cantilever beams:</b> There are several examples with different element types rendered in matplotlib.</td>\n        </tr>\n        <tr>\n            <td colspan=\"3\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/basic/planar/plasticity.html\"><img src=\"https://meyer-nils.github.io/torch-fem/plate_hole_plasticity.png\"></a></td>\n        </tr>\n        <tr>\n            <td colspan=\"3\" align=\"center\"><b>Plasticity in a plate with hole:</b> Isotropic linear hardening model for plane-stress or plane-strain.</td>\n        </tr>\n    </tbody>\n</table>\n\n## Optimization examples\nThe subdirectory `examples->optimization` demonstrates the use of torch-fem for optimization of structures (e.g. topology optimization, composite orientation optimization). You may click on the examples to check out the notebooks online.\n\n<table>\n    <tbody>\n        <tr>\n            <td style=\"width: 50%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/optimization/truss/shape.html\"><img src=\"https://meyer-nils.github.io/torch-fem/bridge.png\"></a></td>\n            <td style=\"width: 50%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/optimization/planar/shape.html\"><img src=\"https://meyer-nils.github.io/torch-fem/fillet_shape_optimization.png\"></a></td>\n        </tr>\n        <tr>\n            <td align=\"center\"><b>Shape optimization of a truss:</b> The top nodes are moved and MMA + autograd is used to minimize the compliance.</td>\n            <td align=\"center\"><b>Shape optimization of a fillet:</b> The shape is morphed with shape basis vectors and MMA + autograd is used to minimize the maximum stress.</td>\n        </tr>\n        <tr>\n            <td style=\"width: 50%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/optimization/planar/topology.html\"><img src=\"https://meyer-nils.github.io/torch-fem/topopt_mbb.png\"></a></td>\n            <td style=\"width: 50%;\"><img src=\"https://meyer-nils.github.io/torch-fem/topopt_3d.png\"></td>\n        </tr>\n        <tr>\n            <td align=\"center\"><b>Topology optimization of a MBB beam:</b> You can switch between analytical and autograd sensitivities.</td>\n            <td align=\"center\"><b>Topology optimization of a jet engine bracket:</b> The 3D model is exported to Paraview for visualization.</td>\n        </tr>\n        <tr>\n            <td style=\"width: 50%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/optimization/planar/topology+orientation.html\"><img src=\"https://meyer-nils.github.io/torch-fem/topo+ori.png\"></a></td>\n            <td style=\"width: 50%;\"><a href=\"https://meyer-nils.github.io/torch-fem/examples/optimization/planar/orientation.html\"><img src=\"https://meyer-nils.github.io/torch-fem/plate_hole_shape_optimization.png\"></a>\n            </td>\n        </tr>\n        <tr>\n            <td align=\"center\"><b>Combined topology and orientation optimization:</b> Compliance is minimized by optimizing fiber orientation and density of an anisotropic material using automatic differentiation.</td>\n            <td align=\"center\"><b>Fiber orientation optimization of a plate with a hole</b> Compliance is minimized by optimizing the fiber orientation of an anisotropic material using automatic differentiation w.r.t. element-wise fiber angles.</td>\n        </tr>\n    </tbody>\n</table>\n\n\n## Minimal example\nThis is a minimal example of how to use torch-fem to solve a very simple planar cantilever problem. \n\n```python\nimport torch\nfrom torchfem import Planar\nfrom torchfem.materials import IsotropicElasticityPlaneStress\n\ntorch.set_default_dtype(torch.float64)\n\n# Material\nmaterial = IsotropicElasticityPlaneStress(E=1000.0, nu=0.3)\n\n# Nodes and elements\nnodes = torch.tensor([[0., 0.], [1., 0.], [2., 0.], [0., 1.], [1., 1.], [2., 1.]])\nelements = torch.tensor([[0, 1, 4, 3], [1, 2, 5, 4]])\n\n# Create model\ncantilever = Planar(nodes, elements, material)\n\n# Load at tip [Node_ID, DOF]\ncantilever.forces[5, 1] = -1.0\n\n# Constrained displacement at left end [Node_IDs, DOFs]\ncantilever.constraints[[0, 3], :] = True\n\n# Show model\ncantilever.plot(node_markers=\"o\", node_labels=True)\n```\nThis creates a minimal planar FEM model:\n\n![minimal](https://meyer-nils.github.io/torch-fem/minimal_example.png)\n\n```python\n# Solve\nu, f, \u03c3, \u03b5, \u03b1 = cantilever.solve()\n\n# Plot displacement magnitude on deformed state\ncantilever.plot(u, node_property=torch.norm(u, dim=1))\n```\nThis solves the model and plots the result:\n\n![minimal](https://meyer-nils.github.io/torch-fem/minimal_example_solved.png)\n\nIf we want to compute gradients through the FEM model, we simply need to define the variables that require gradients. Automatic differentiation is performed through the entire FE solver.\n```python \n# Enable automatic differentiation\ncantilever.thickness.requires_grad = True\nu, f, _, _, _ = cantilever.solve()\n\n# Compute sensitivity of compliance w.r.t. element thicknesses\ncompliance = torch.inner(f.ravel(), u.ravel())\ntorch.autograd.grad(compliance, cantilever.thickness)[0]\n```\n\n## Benchmarks \nThe following benchmarks were performed on a cube subjected to a one-dimensional extension. The cube is discretized with N x N x N linear hexahedral elements, has a side length of 1.0 and is made of a material with Young's modulus of 1000.0 and Poisson's ratio of 0.3. The cube is fixed at one end and a displacement of 0.1 is applied at the other end. The benchmark measures the forward time to assemble the stiffness matrix and the time to solve the linear system. In addition, it measures the backward time to compute the sensitivities of the sum of displacements with respect to forces.\n\n#### Apple M1 Pro (10 cores, 16 GB RAM)\nPython 3.10, SciPy 1.14.1, Apple Accelerate\n\n|  N  |     DOFs |  FWD Time |  BWD Time |   Peak RAM |\n| --- | -------- | --------- | --------- | ---------- |\n|  10 |     3000 |     0.16s |     0.08s |    571.4MB |\n|  20 |    24000 |     0.71s |     0.28s |    883.0MB |\n|  30 |    81000 |     2.71s |     1.17s |   1453.3MB |\n|  40 |   192000 |     7.57s |     3.73s |   2351.0MB |\n|  50 |   375000 |    16.20s |     8.94s |   3919.8MB |\n|  60 |   648000 |    27.59s |    18.82s |   4855.9MB |\n|  70 |  1029000 |    48.86s |    40.32s |   6761.7MB |\n|  80 |  1536000 |    85.89s |    68.61s |   7454.9MB |\n|  90 |  2187000 |   131.45s |   110.14s |   8457.8MB |\n| 100 |  3000000 |   193.44s |   162.16s |   9898.3MB |\n\n\n#### AMD Ryzen Threadripper PRO 5995WX (64 Cores, 512 GB RAM) and NVIDIA GeForce RTX 4090\nPython 3.12, CuPy 13.3.0, CUDA 11.8\n\n|  N  |     DOFs |  FWD Time |  BWD Time |   Peak RAM |\n| --- | -------- | --------- | --------- | ---------- |\n|  10 |     3000 |     0.66s |     0.15s |   1371.7MB |\n|  20 |    24000 |     1.00s |     0.43s |   1358.9MB |\n|  30 |    81000 |     1.14s |     0.65s |   1371.1MB |\n|  40 |   192000 |     1.37s |     0.83s |   1367.3MB |\n|  50 |   375000 |     1.51s |     1.04s |   1356.4MB |\n|  60 |   648000 |     1.94s |     1.43s |   1342.1MB |\n|  70 |  1029000 |     5.19s |     4.31s |   1366.8MB |\n|  80 |  1536000 |     7.48s |    18.88s |   5105.6MB |\n\n\n",
    "bugtrack_url": null,
    "license": "Copyright 2024 Nils Meyer  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \u201cSoftware\u201d), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:  The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED \u201cAS IS\u201d, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.",
    "summary": "GPU accelerated differential finite elements for solid mechanics with PyTorch.",
    "version": "0.3.5",
    "project_urls": {
        "source": "https://github.com/meyer-nils/torch-fem"
    },
    "split_keywords": [
        "finite elements",
        " automatic differentiation"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8edc498870dbc5ea538db53059a34a412b7b69e5598f05788bbcb6bd6fe2b8c0",
                "md5": "a8e44b37385e766a630ed69e6435edd6",
                "sha256": "e19ee25eff6c88a3fb5eb28467aca7a2356a4fc65072d02bb0a0d3cb88c77541"
            },
            "downloads": -1,
            "filename": "torch_fem-0.3.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "a8e44b37385e766a630ed69e6435edd6",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.10",
            "size": 2697819,
            "upload_time": "2024-12-07T20:25:14",
            "upload_time_iso_8601": "2024-12-07T20:25:14.425380Z",
            "url": "https://files.pythonhosted.org/packages/8e/dc/498870dbc5ea538db53059a34a412b7b69e5598f05788bbcb6bd6fe2b8c0/torch_fem-0.3.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "06241bf026727fb159c96a492fd10012c00a57b92328a8fb32fe3c35a4657d34",
                "md5": "061e05c82547d868441e5029babf3d61",
                "sha256": "4599bf447407cee3cf27a1e1506c93002cd140dc0298d2888065faa795c060b7"
            },
            "downloads": -1,
            "filename": "torch_fem-0.3.5.tar.gz",
            "has_sig": false,
            "md5_digest": "061e05c82547d868441e5029babf3d61",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.10",
            "size": 2696636,
            "upload_time": "2024-12-07T20:25:16",
            "upload_time_iso_8601": "2024-12-07T20:25:16.100547Z",
            "url": "https://files.pythonhosted.org/packages/06/24/1bf026727fb159c96a492fd10012c00a57b92328a8fb32fe3c35a4657d34/torch_fem-0.3.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-07 20:25:16",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "meyer-nils",
    "github_project": "torch-fem",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "torch-fem"
}
        
Elapsed time: 0.36287s