Skip to main content

PyRoll rolling simulation framework - core library.

Project description

PyRolL Rolling Simulation Framework

PyPI Python Versions License DOI Downloads OpenSSF Best Practices

Welcome to The PyRolL Project!

PyRolL is an OpenSource rolling framework, aimed to provide a fast and extensible base for rolling simulation. The current focus lies on groove rolling in elongation grooves. The core package includes the basic data structures and algorithms. Further functionality is provided via extension packages and model approaches are provided via plugin packages.

Aim and Scope

Publications in the field of groove rolling simulation are, to the authors knowledge, characterized by lack of reproducibility, mainly because often details are missing regarding implementation or numerical solution procedure or the provided equations are erroneous. Very few authors provide their source code alongside their publications. PyRolL aims to change this by providing an open basis for model and methodology development. The PyRolL Core package hosted in this repository is the common base dependency to refer to. Plugins to the core provide model approaches for the partial problems to be described in a rolling simulation, which include mechanical, thermal, material behavior and more. The library of available models is constantly growing and can be extended by everyone. Extensions provide application logic and numerical procedures helping to analyse the subject rolling process regarding its technical feasibility, optimization potential, identity error sources, or, to design a new process. PyRolL is therefore a tool for model developers, either with broad focus or specialists, wishing to try out for example a new physical material model within a real process simulation, as well as for technologists wishing to investigate a concrete process. Currently, there is no click'n'run graphical user interface (GUI) provided, at least basic knowledge of programming in general and Python in particular is needed to use the software. Nevertheless, this is also recommended to leverage the full power of PyRolL.

Documentation

See the documentation to learn about basic concepts and usage. The documentation of version 1.0 can be found here.

Versions

The main branch of this repository contains the code of the version 2.0 of PyRolL. See the backport branch for the code of version 1.0. Version 1.0 is now out of support, as version 2.0 has been released. It is recommended to develop new plugins and extensions only for 2.0.

Principal Changes of Version 2.0 Respective to 1.0

  • Split of old pyroll package into pyroll-core, pyroll-report, pyroll-export and pyroll-cli.
  • Complete reworking of the hook system.
    • Implementation of own hooking framework and removal of pluggy.
    • Simpler user interface for hook definition and implementation.
    • More orthodox default hook implementations, removal of "basic models".
  • Rework of the object model.
    • Stricter hierarchy of unit classes.
    • Extended possibilities of groove definition.
    • Roll passes with three working rolls.
    • New unit classes: Rotator, PassSequence, ThreeRollPass.
    • Introduction of disk elements for incremental modelling in rolling direction.
    • Nestable units (esp. pass sequences and disk elements).

License

The project is licensed under the BSD 3-Clause license.

Contributing

Feel free to open issues, or, fork and open pull requests, if you want to contribute to the core. If you want to implement model approaches for use with PyRolL, create your own plugin package using our plugin template. To learn how to write plugins and extensions, please read the documentation and refer to the numerous existing plugins and extensions available at the organization's GitHub page.

Policy for Inclusion of Hooks in the Core

Since version 2.0 we try to include as many hooks as possible into the core, to tie down the nomenclature. This seems necessary, since for the same concepts, often different terms exist in literature. To avoid collisions and redundancies, it is better to include these hooks in the core, although some of them may come without implementation. This improves the exchangeability of plugins. If you like a hook to be included in the core, open an issue, or preferably, a pull request with the respective changes. Supply your pull request with fallback implementations of the hook, if any meaningful exist.

From this policy we explicitly exclude hooks, that are solely of use for one model approach, namely "coefficients". They are large in number across the whole plugin landscape, but usually named after the model and of no further use to other plugins. So the benefit from including them in the core is small, while the pollution of the core would be exzessive. If another plugin has to make use of them, just add a dependency for the respective source plugin.

A few examples for clarification:

  • The hooks Profile.surface_temperature and Profile.core_temperature may be of interests to many plugins. The core provides fallbacks which just return self.temperature, which is a good first estimate of those. So plugins modelling surface and thermal effects can easily refer to the respective temperatures, without worrying, if there is a model describing the temperature gradient or not.
  • The hook Profile.freiberg_flow_stress_coefficients from the pyroll-freiberg-flow-stress plugin makes no sense without the Freiberg flow stress model, so it is not included in the core.
  • The hook Profile.thermal_conductivity is a material property useful to many plugins, but no meaningful fallback exists, since there is no default material. So the provision of values or implementations is deferred to the user or developers of material databases.

So the core includes several hooks, that are not used by other core functionality, but provide a save ground for plugins.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pyroll_core-3.0.1.tar.gz (49.7 kB view details)

Uploaded Source

Built Distribution

pyroll_core-3.0.1-py3-none-any.whl (80.1 kB view details)

Uploaded Python 3

File details

Details for the file pyroll_core-3.0.1.tar.gz.

File metadata

  • Download URL: pyroll_core-3.0.1.tar.gz
  • Upload date:
  • Size: 49.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for pyroll_core-3.0.1.tar.gz
Algorithm Hash digest
SHA256 79fbc58b9e8426e5855e992747cb7f3c4e1cbed1c283e9ea4f1ec22712a9f58e
MD5 ced9becac2dad3218a8ba62f9e972f6f
BLAKE2b-256 43b68c07f21a1a7b62da6c88575da195adc2571f262922d67943e7d88bdcf639

See more details on using hashes here.

File details

Details for the file pyroll_core-3.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pyroll_core-3.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3fbb25b1e34ac9f306122a9c0dd7544880f7a15b7a57252f7292578d216a8361
MD5 36ffd00b11e2d7d96adf48ee56e0990b
BLAKE2b-256 4420ae57717303d8ee54b3ef80620acb5decf9a646c445df7befff7a8e551d4b

See more details on using hashes here.

Supported by

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