Metadata-Version: 2.4
Name: rational-linkages
Version: 2.6.0
Summary: Rational Linkages
Author-email: Daniel Huczala <daniel.huczala@uibk.ac.at>
License-Expression: GPL-3.0-or-later
Project-URL: Homepage, https://git.uibk.ac.at/geometrie-vermessung/rational-linkages
Project-URL: Documentation, http://rational-linkages.readthedocs.io/
Project-URL: Issues, https://github.com/hucik14/rational-linkages/issues
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Rust
Classifier: Operating System :: OS Independent
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: biquaternion-py>=1.2.0
Requires-Dist: numpy>=1.10.0
Requires-Dist: sympy>=1.10.0
Requires-Dist: PyQt6>=6.2.0
Requires-Dist: pyqtgraph<0.14
Requires-Dist: PyOpenGL>=3.0.0
Requires-Dist: matplotlib>=3.9.0; platform_system == "Windows" and platform_machine == "ARM64"
Provides-Extra: opt
Requires-Dist: ipython>=8.0.0; extra == "opt"
Requires-Dist: scipy>=1.10.0; extra == "opt"
Requires-Dist: matplotlib>=3.9.0; extra == "opt"
Provides-Extra: cad
Requires-Dist: exudyn>=1.9.0; extra == "cad"
Requires-Dist: ngsolve>=6.2.0; extra == "cad"
Requires-Dist: build123d; extra == "cad"
Requires-Dist: trimesh; extra == "cad"
Requires-Dist: manifold3d; extra == "cad"
Provides-Extra: doc
Requires-Dist: sphinx; extra == "doc"
Requires-Dist: sphinx-rtd-theme; extra == "doc"
Requires-Dist: nbsphinx; extra == "doc"
Requires-Dist: sphinxcontrib-bibtex; extra == "doc"
Requires-Dist: toml; extra == "doc"
Requires-Dist: pandoc; extra == "doc"
Requires-Dist: gitpython; extra == "doc"
Provides-Extra: dev
Requires-Dist: build; extra == "dev"
Requires-Dist: cibuildwheel; extra == "dev"
Requires-Dist: coverage; extra == "dev"
Requires-Dist: pytest; extra == "dev"
Requires-Dist: flake8; extra == "dev"
Requires-Dist: flake8-pyproject; extra == "dev"
Requires-Dist: black; extra == "dev"
Requires-Dist: isort; extra == "dev"
Requires-Dist: twine; extra == "dev"
Dynamic: license-file

[![GitHub Mirror](https://img.shields.io/badge/Github-mirror_%26_issues-_?style=social&logo=github)](https://github.com/hucik14/rational-linkages)
[![GitLab (self-managed)](https://img.shields.io/badge/Git_UIBK-repository-_?style=social&logo=gitlab)](https://git.uibk.ac.at/geometrie-vermessung/rational-linkages)
[![PyPI version](https://img.shields.io/pypi/v/rational-linkages.svg)](https://pypi.org/project/rational-linkages/)
[![DOI](https://zenodo.org/badge/DOI/10.1007/978-3-031-64057-5_27.svg)](https://doi.org/10.1007/978-3-031-64057-5_27)

[![build](https://git.uibk.ac.at/geometrie-vermessung/rational-linkages/badges/main/pipeline.svg)](https://git.uibk.ac.at/geometrie-vermessung/rational-linkages/-/jobs)
[![Documentation Status](https://readthedocs.org/projects/rational-linkages/badge/?version=latest)](https://rational-linkages.readthedocs.io/?badge=latest)
[![GitHub issues](https://img.shields.io/github/issues/hucik14/rational-linkages)](https://github.com/hucik14/rational-linkages/issues)
[![coverage](https://git.uibk.ac.at/geometrie-vermessung/rational-linkages/badges/main/coverage.svg?job=test_coverage)](https://git.uibk.ac.at/geometrie-vermessung/rational-linkages/-/jobs)
[![maintenance-status](https://img.shields.io/badge/maintenance-actively--developed-brightgreen.svg)](https://git.uibk.ac.at/geometrie-vermessung/rational-linkages/-/network/main)
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/hucik14/rational-linkages/HEAD?labpath=docs%2Fsource%2Ftutorials%2Fsynthesis_bennett.ipynb)

# Rational Linkages <img src="/docs/source/figures/rl-logo.png" width="5%">

This Python-based package provides a collection of methods for the synthesis, 
analysis, design, and rapid prototyping 
of the single-loop rational linkages, allowing one to create 3D-printable 
collision-free mechanisms synthesised for a given task (set of poses). 

<img src="/docs/source/figures/r4.JPEG" width="24%"> <img src="/docs/source/figures/r6li.JPEG" width="24%"> <img src="/docs/source/figures/r6hp.JPEG" width="24%"> <img src="/docs/source/figures/r6joh.JPEG" width="24%">

The package was originally developed as a part of the research project at the 
Unit of Geometry and Surveying, University of Innsbruck, Austria. 

## Documentation, tutorials, issues

[Rational Linkages Documentation](https://rational-linkages.readthedocs.io/) is 
hosted on Read the Docs, and provides a comprehensive overview of the package with 
[examples and tutorials](https://rational-linkages.readthedocs.io/latest/general/overview.html).

Since the self-hosted repository (Gitlab, University of Innsbruck) does not allow external users to create issues,
please, use the [package mirror](https://github.com/hucik14/rational-linkages) 
hosted on GitHub for submitting **issues** and **feature requests**. Additionally,
you can *"watch/star"* the issue tracker package **to get notified about the updates**
(new releases will be also announced there).

You can test live-example of Jupyter notebook using Binder, by clicking on the 
following badge:
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/hucik14/rational-linkages/HEAD?labpath=docs%2Fsource%2Ftutorials%2Fsynthesis_bennett.ipynb)

In case of other questions or contributions, please, email the author at:
`daniel.huczala@uibk.ac.at`

STL files of some mechanisms may be found as
[models on Printables.com](https://www.printables.com/@hucik14_497869/collections/443601).

The results may look like this Bennett manipulator made by our collaborators from the Department of Robotics, 
VSB -- Technical University
of Ostrava. See [full video on Youtube](https://www.youtube.com/watch?v=T_7lkPjdcCg).

![Bennett mechanism in motion](./docs/source/figures/tombennett.gif)


## Intallation instuctions

Recommended Python version is **3.11**, when it provides the smoothest plotting 
(but 3.10 or higher are supported). Python 3.11 is also the version used for 
development.

### Install from PyPI

Using pip:

<code>pip install rational-linkages</code>

or with optional dependencies:

<code>pip install rational-linkages[opt,exu]</code>

Mac/linux users might need to use backslashes to escape the brackets, e.g.:

<code>pip install rational-linkages\\[opt,exu\\]</code>

for installing also **opt**ional dependencies (scipy - optimization problems solving, ipython - inline plotting,  
matplotlib - alternative engine for 3D plotting, gmpy2 - optimized symbolic computations, trimesh + manifold3d - STL
meshes generation) 
and **cad** dependencies (exudyn - multibody simulations, ngsolve - work with meshes in exudyn,
build123d - generating STEP files of linkages, trimesh + manifold 3d - generating STL files).

On **Linux systems**, to run GUI interactive plotting, 
some additional libraries might be required for plotting with PyQt6. For example, 
on Ubuntu, it can be installed as follows:

   <code>sudo apt install libgl1-mesa-glx libxkbcommon-x11-0 libegl1 libdbus-1-3</code>

or on Ubuntu 24.04 and higher:

   <code>sudo apt install libgl1 libxkbcommon-x11-0 libegl1 libdbus-1-3</code>

On 64-bit platform, <code>gmpy2</code> package for optimized symbolic computations can be useful.


### Install from source

1. Clone the repository (use preferably your client, or clone with the button on top of this page or using the following line)
    
    <code>git clone https://git.uibk.ac.at/geometrie-vermessung/rational-linkages.git </code>

2. Navigate to the repository folder

    <code>cd rational-linkages</code>

3. Install the *editable* version of the package using pip:

    <code>pip install -e .[opt]</code> 

   or 
    
   <code>pip install -e .[opt,dev,doc]</code> including the development and documentation dependencies. 

   Mac/linux users might need to use backslashes to escape the brackets, e.g.: 

   <code>pip install -e .\\[opt\\]</code>


To locally develop, you need to install the [Rust toolchain](https://www.rust-lang.org) and 
build the Rust code yourself. On top of that, on **Windows**, you need to install a 
C++ build toolchain. In `Visual Studio Installer`, select: 

* MSVC v143 - VS 2022 C++ x64/x86 build tools (latest)
* Windows 11 SDK
* C++ CMake tools for Windows

Alternatively, on **Linux**, you need to install:

* build-essential

Then, if adding Rust-based functions, navigate to the `rational_linkages/rust` folder and run:

<code>cargo build --release</code>

## Citing the package

For additional information, see our preprint paper, and in the case of usage, please, 
cite it:

Huczala, D., Siegele, J., Thimm, D.A., Pfurner, M., Schröcker, HP. (2024). 
Rational Linkages: From Poses to 3D-Printed Prototypes. 
In: Lenarčič, J., Husty, M. (eds) Advances in Robot Kinematics 2024. ARK 2024. 
Springer Proceedings in Advanced Robotics, vol 31. Springer, Cham. 
DOI: [10.1007/978-3-031-64057-5_27](https://doi.org/10.1007/978-3-031-64057-5_27).

```bibtex
@inproceedings{huczala2024linkages,
    title={Rational Linkages: From Poses to 3D-printed Prototypes},
    author={Daniel Huczala and Johannes Siegele and Daren A. Thimm and Martin Pfurner and Hans-Peter Schröcker},
    year={2024},
    booktitle={Advances in Robot Kinematics 2024. ARK 2024},
    publisher={Springer International Publishing},
    url={https://doi.org/10.1007/978-3-031-64057-5_27},
    doi={10.1007/978-3-031-64057-5_27},
}
```

### Preprint of the paper

On **arXiv:2403.00558**: [https://arxiv.org/abs/2403.00558](https://arxiv.org/abs/2403.00558).

## Acknowledgements

Funded by the European Union. Views and opinions expressed are however those of 
the author(s) only and do not necessarily reflect those of the European Union 
or the European Research Executive Agency (REA). Neither the European Union 
nor the granting authority can be held responsible for them.

<img src="./docs/source/figures/eu.png" width="250" />
