-
Notifications
You must be signed in to change notification settings - Fork 75
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #47 from kssgarcia/2.0_merge
2.0 merge master changes
- Loading branch information
Showing
10 changed files
with
501 additions
and
142 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
# This CITATION.cff file was generated with cffinit. | ||
# Visit https://bit.ly/cffinit to generate yours today! | ||
|
||
cff-version: 1.1.0 | ||
title: 'SolidsPy: 2D-Finite Element Analysis with Python' | ||
message: >- | ||
If you use this software, please cite it using the | ||
metadata from this file. | ||
type: software | ||
authors: | ||
- given-names: Nicolás | ||
family-names: Guarín-Zapata | ||
email: nguarinz@eafit.edu.co | ||
affiliation: Universidad EAFIT | ||
orcid: 'https://orcid.org/0000-0002-9435-1914' | ||
- given-names: Juan David | ||
family-names: Gómez | ||
email: jgomezc1@eafit.edu.co | ||
affiliation: Universidad EAFIT | ||
identifiers: | ||
- type: doi | ||
value: 10.5281/zenodo.4029270 | ||
url: 'https://github.com/AppliedMechanics-EAFIT/SolidsPy' | ||
abstract: >- | ||
SolidsPy is a simple finite element analysis code | ||
for 2D elasticity problems. The code uses as input | ||
simple-to-create text files defining a model in | ||
terms of nodal, element, material, and load data. | ||
keywords: | ||
- finite element method | ||
- scientific computing | ||
- computational mechanics | ||
- elasticity | ||
- python | ||
license: MIT |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,142 @@ | ||
# SolidsPy: 2D-Finite Element Analysis with Python | ||
|
||
![](https://raw.githubusercontent.com/AppliedMechanics-EAFIT/SolidsPy/master/docs/img/wrench.png) | ||
[![PyPI download](https://img.shields.io/pypi/v/solidspy.svg)](https://pypi.python.org/pypi/continuum_mechanics) | ||
[![Documentation Status](https://readthedocs.org/projects/solidspy/badge/?version=latest)](https://solidspy.readthedocs.io/en/latest/) | ||
[![Downloads frequency](https://img.shields.io/pypi/dm/solidspy)](https://pypistats.org/packages/solidspy) | ||
[![image](https://zenodo.org/badge/48294591.svg)](https://zenodo.org/badge/latestdoi/48294591) | ||
|
||
A simple finite element analysis code for 2D elasticity problems. The code uses | ||
as input simple-to-create text files defining a model in terms of nodal, | ||
element, material and load data. | ||
|
||
- Documentation: <http://solidspy.readthedocs.io> | ||
- GitHub: <https://github.com/AppliedMechanics-EAFIT/SolidsPy> | ||
- PyPI: <https://pypi.org/project/solidspy/> | ||
- Free and open source software: [MIT license](http://en.wikipedia.org/wiki/MIT_License) | ||
|
||
## Features | ||
|
||
- It is based on an open-source environment. | ||
- It is easy to use. | ||
- The code allows to find displacement, strain and stress solutions | ||
for arbitrary two-dimensional domains discretized into finite | ||
elements and subject to point loads. | ||
- The code is organized in independent modules for pre-processing, | ||
assembly and post-processing allowing the user to easily modify it | ||
or add features like new elements or analyses pipelines. | ||
- It was created with academic and research purposes. | ||
- It has been used to tech the following courses: | ||
- Introduction to Solid Mechanics. | ||
- Computational Modeling. | ||
- Introduction to the Finite Element Methods. | ||
- Introduction to Soil Mechanics. | ||
|
||
## Installation | ||
|
||
The code is written in Python and it depends on `numpy`, and `scipy` and. It | ||
has been tested under Windows, Mac, Linux and Android. | ||
|
||
To install *SolidsPy* open a terminal and type: | ||
|
||
pip install solidspy | ||
|
||
To specify through a GUI the folder where the input files are stored you will | ||
need to install [easygui](http://easygui.readthedocs.org/en/master/). | ||
|
||
To easily generate the required SolidsPy text files out of a | ||
[Gmsh](http://gmsh.info/) model you will need [meshio](https://github.com/nschloe/meshio). | ||
|
||
These two can be installed with: | ||
|
||
pip install easygui | ||
pip install meshio | ||
|
||
## How to run a simple model | ||
|
||
For further explanation check the [docs](http://solidspy.readthedocs.io/en/latest/). | ||
|
||
Let's suppose that we have a simple model represented by the following files | ||
(see [tutorials/square example](http://solidspy.readthedocs.io/en/latest/tutorials/square_example.html) | ||
for further explanation). | ||
|
||
- `nodes.txt` | ||
|
||
``` | ||
0 0.00 0.00 0 -1 | ||
1 2.00 0.00 0 -1 | ||
2 2.00 2.00 0 0 | ||
3 0.00 2.00 0 0 | ||
4 1.00 0.00 -1 -1 | ||
5 2.00 1.00 0 0 | ||
6 1.00 2.00 0 0 | ||
7 0.00 1.00 0 0 | ||
8 1.00 1.00 0 0 | ||
``` | ||
|
||
|
||
- `eles.txt` | ||
|
||
``` | ||
0 1 0 0 4 8 7 | ||
1 1 0 4 1 5 8 | ||
2 1 0 7 8 6 3 | ||
3 1 0 8 5 2 6 | ||
``` | ||
|
||
|
||
- `mater.txt` | ||
|
||
``` | ||
1.0 0.3 | ||
``` | ||
|
||
|
||
- `loads.txt` | ||
|
||
``` | ||
3 0.0 1.0 | ||
6 0.0 2.0 | ||
2 0.0 1.0 | ||
``` | ||
|
||
|
||
Run it in Python as follows: | ||
|
||
``` python | ||
import matplotlib.pyplot as plt # load matplotlib | ||
from solidspy import solids_GUI # import our package | ||
disp = solids_GUI() # run the Finite Element Analysis | ||
plt.show() # plot contours | ||
``` | ||
|
||
For Mac users it is suggested to use an IPython console to run the example. | ||
|
||
## License | ||
|
||
This project is licensed under the [MIT license](http://en.wikipedia.org/wiki/MIT_License). | ||
The documents are licensed under [Creative Commons Attribution License](http://creativecommons.org/licenses/by/4.0/). | ||
|
||
## Citation | ||
|
||
To cite SolidsPy in publications use | ||
|
||
> Nicolás Guarín-Zapata, Juan Gomez (2023). SolidsPy: Version 1.1.0 | ||
> (Version v1.1.0). Zenodo. <https://doi.org/10.5281/zenodo.7694030> | ||
A BibTeX entry for LaTeX users is | ||
|
||
```bibtex | ||
@software{solidspy, | ||
title = {SolidsPy: 2D-Finite Element Analysis with Python}, | ||
version = {1.1.0}, | ||
author = {Guarín-Zapata, Nicolás and Gómez, Juan}, | ||
year = 2023, | ||
keywords = {Python, Finite elements, Scientific computing, Computational mechanics}, | ||
abstract = {SolidsPy is a simple finite element analysis code for 2D elasticity | ||
problems. The code uses as input simple-to-create text files defining a model | ||
in terms of nodal, element, material and load data.}, | ||
url = {https://github.com/AppliedMechanics-EAFIT/SolidsPy}, | ||
doi = {https://doi.org/10.5281/zenodo.7694030} | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.