Skip to main content

A library for working with anisotropic elasticity in Python.

Project description

scikit-elasticity

A library for working with anisotropic elasticity in Python

Features

All functionality is implemented in "vectorized" form, i.e. multidimensional arrays are handled without explicit loops in Python. Hence, despited being a pure Python library (if the dependency on NumPy and SciPy is ignored), it is suitable for large scale calculations.

Homogenization

Calculation of effective stiffness

Conversions

Represent 2nd and 4th order tensors in compressed Voigt or Mandel notation. Including support for rotations, which is based on the Python implementation of the conventions by Rowenhorst et al.

Stiffness or Compliance Matrices

Initialize stiffness or compliance matrices for different crystal systems.

Installation

Development

From the base directory run export PYTHONPATH=:$PWD/skel:$PYTHONPATH.

To get the correct version, also run versioningit -w from the root directory of the package. This requires to have versioningit installed.

From source

python -m pip install .

Usage

import skel
import damask
import numpy as np

N = 100000
C_Fe = skel.Hooke.C('cubic',C_11=232.2e9,C_12=136.4e9,C_44=117.0e9)
C_Al = skel.Hooke.C('cubic',C_11=106.9e9,C_12=60.5e9,C_44=28.4e9)
C_Cu = skel.Hooke.C('cubic',C_11=168.9e9,C_12=121.8e9,C_44=75.8e9)
C_Mg = skel.Hooke.C('hexagonal',C_11=59.5e9,C_12=25.6e9,C_44=16.5e9,C_33=61.7e9,C_13=21.5e9)
O = damask.Rotation.from_random(N,rng_seed=20191102)
for label,C in zip(['Fe','Al','Cu','Mg'],[C_Fe,C_Al,C_Cu,C_Mg]):
    print(f'== {label} ==')
    ve = skel.VolumeElement(C,O)
    with np.printoptions(precision=2,suppress=True):
        print('Reuss\n',ve.C_Reuss/1e9)
        print('Voigt\n',ve.C_Voigt/1e9)
        print('Hill\n',ve.C_Hill/1e9)
        print('Self-consistent\n',ve.C_sc/1e9)

# https://www.sciencedirect.com/science/article/abs/pii/0956715195901698 (fig 6)
# https://doi.org/10.1080/02670836.2016.1231746
def texture_Ni(N_grains,rng):
    Eulers = [[[59,37,63],.30], # S
              [[90,35,45],.20], # Cu
              [[35,45,90],.15]] # Brass
    directions = [[[np.pi/4.,0.],[0.,0.],.10]]
    O = damask.Rotation.from_random(N_grains \
                                    - sum(int(N_grains*_[1]) for _ in Eulers)\
                                    - sum(int(N_grains*_[2]) for _ in directions),rng_seed=rng)
    for eu,v in Eulers:
        p = damask.Orientation.from_Euler_angles(phi=eu,degrees=True,lattice='cI')
        O = O.append(damask.Rotation.from_spherical_component(p,50,int(N_grains*v),degrees=True,rng_seed=rng))
    for c,s,v in directions:
        O = O.append(damask.Rotation.from_fiber_component(c,s,np.deg2rad(20),shape=int(N_grains*v),rng_seed=rng))
    return O

C_Ni = skel.Hooke.C('cubic',C_11=251.0e+9,C_12=150.0e+9,C_44=123.7e+9)
ve = skel.VolumeElement(C_Ni,texture_Ni(2000,2))
C = skel.Voigt.to_3x3x3x3_compliance(np.linalg.inv(ve.C_sc))
print('E_x',skel.Hooke.E(C,[1,0,0])/1e9)
print('E_y',skel.Hooke.E(C,[0,1,0])/1e9)
print('E_z',skel.Hooke.E(C,[0,0,1])/1e9)

Contact

Martin Diehl
KU Leuven
martin.diehl@kuleuven.be

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

scikit_elasticity-0.0.1.tar.gz (18.1 kB view details)

Uploaded Source

Built Distribution

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

scikit_elasticity-0.0.1-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file scikit_elasticity-0.0.1.tar.gz.

File metadata

  • Download URL: scikit_elasticity-0.0.1.tar.gz
  • Upload date:
  • Size: 18.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for scikit_elasticity-0.0.1.tar.gz
Algorithm Hash digest
SHA256 b1cb752bfce569036ea9024a6d2006f2e404cf8fc6586129ca5db57f075a3a58
MD5 45925348668c273111dc0707b614894e
BLAKE2b-256 ef71a996b584248cb87a2054273b78104a703460a55c15522fd36ed85decd099

See more details on using hashes here.

File details

Details for the file scikit_elasticity-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for scikit_elasticity-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 520c75979d9eb106d01a249c060ebfd6ba9883fe3c9240bfaf2c505133d11cd9
MD5 dcc3182c19b6241ed44e3d1af91d8b58
BLAKE2b-256 4d6bea25d702d11cdc75d6b5438a2877f36036ba790b586e4edd0de804775f24

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