Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yu9824/ternary_diagram
This package makes it easier for you to draw beautiful ternary diagram without pymatgen.
https://github.com/yu9824/ternary_diagram
chemistry materials-informatics matplotlib python ternary-diagrams visualization
Last synced: 4 months ago
JSON representation
This package makes it easier for you to draw beautiful ternary diagram without pymatgen.
- Host: GitHub
- URL: https://github.com/yu9824/ternary_diagram
- Owner: yu9824
- License: mit
- Created: 2020-09-06T07:04:21.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2023-09-16T13:02:55.000Z (over 1 year ago)
- Last Synced: 2024-08-08T20:39:57.770Z (7 months ago)
- Topics: chemistry, materials-informatics, matplotlib, python, ternary-diagrams, visualization
- Language: Python
- Homepage: https://yu9824.github.io/ternary_diagram/
- Size: 17.4 MB
- Stars: 15
- Watchers: 1
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Ternary Diagram
[data:image/s3,"s3://crabby-images/68d8b/68d8b56c51d7145641530a0db142d93dfb6d096b" alt="python_badge"](https://pypi.org/project/ternary-diagram/)
[data:image/s3,"s3://crabby-images/0e7e6/0e7e6f22e09d5c1ac452694e3af60f62ad56ff22" alt="license_badge"](https://pypi.org/project/ternary-diagram/)
[data:image/s3,"s3://crabby-images/f64b1/f64b17d58695448e5b48e707dff88e72406f783c" alt="PyPI version"](https://pypi.org/project/ternary-diagram/)
[data:image/s3,"s3://crabby-images/811a9/811a9b5b2887f8b009345347e99e6215802a7a0a" alt="Downloads"](https://pepy.tech/project/ternary-diagram)[data:image/s3,"s3://crabby-images/76db7/76db714fcb2514a492933acfd50bba9b20d2e2c7" alt="Test on each version"](https://github.com/yu9824/ternary_diagram/actions/workflows/pytest-on-each-version.yaml)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/psf/black)
[data:image/s3,"s3://crabby-images/bcce6/bcce6d561dcffb5422e6b3edc0560defd0d20d0e" alt="conda_badge"](https://anaconda.org/conda-forge/ternary-diagram/)
[data:image/s3,"s3://crabby-images/dec83/dec831df648c7e9ff7ec8f7b3ce2879752410595" alt="arch_badge"](https://anaconda.org/conda-forge/ternary-diagram)This package makes it easier for you to draw beautiful ternary diagram **without** [pymatgen](https://pymatgen.org).
Meaningly, only need `numpy` and `matplotlib`.
## What you will be able to do with this package
- Create beautiful contour maps easily
- Creating a scatter plot
- Draw tie lines
- Automatically format chemical composition using subscripts
- Most of the matplotlib options are availabledata:image/s3,"s3://crabby-images/66051/66051b9711d22e5db1036c4269e7581fa25cebf8" alt="/example/contour/example_contour.png"
## How to install
### PyPI
```bash
pip install ternary-diagram
```PyPI project is [here](https://pypi.org/project/ternary-diagram/).
### Anaconda
```bash
conda install -c conda-forge ternary-diagram
```Anaconda (conda-forge) package site is [here](https://anaconda.org/conda-forge/ternary-diagram).
## Usage
See [Examples](#examples) and the [documentation](https://yu9824.github.io/ternary_diagram/).
### Examples
An easy example is here.
```python
import matplotlib.pyplot as plt
from ternary_diagram import TernaryDiagram# You can set `ax` to select which axes to draw. If not, the current axes will be used.
td = TernaryDiagram(["Li2O", "La2O3", "TiO2"])# scatter
td.scatter(vector=[[1, 1, 1], [1, 2, 3]], z=[0, 1])
# You can set some options in `plt.scatter` like `marker`, `c` etc.
td.scatter(vector=[[2, 1, 3], [3, 2, 1]], marker="s", c="#022c5e", s=30)# line plot
# You can set some options in `plt.plot` like `lw`, `c`, and so on.
td.plot([[1, 1, 1], [1, 2, 3]], color="black")# save figure
td.fig.savefig("figure.png", dpi=144)```
data:image/s3,"s3://crabby-images/27645/27645985feb3c604db0df007d6c2df1eef643ee1" alt="/example/example_on_readme/figure.png"
It can be written like this.
```python
# The background color is sometimes transparent in jupyter notebooks, so set facecolor 'white'.
fig, ax = plt.subplots(facecolor="w")# You can set `ax` to select which axes to draw. If not, the current axes will be used.
td = TernaryDiagram(["Li2O", "La2O3", "TiO2"], ax=ax)# scatter
td.scatter(vector=[[1, 1, 1], [1, 2, 3]], z=[0, 1])
# You can set some options in `plt.scatter` like `marker`, `c` etc.
td.scatter(vector=[[2, 1, 3], [3, 2, 1]], marker="s", c="#022c5e", s=30)# line plot
# You can set some options in `plt.plot` like `lw`, `c`, and so on.
td.plot([[1, 1, 1], [1, 2, 3]], color="black")# save figure
fig.savefig("figure.png", dpi=144)```
It means that you can draw multiple figures in one figure object.
See also the [example](https://github.com/yu9824/ternary_diagram/tree/main/example) folder.
## Histories
### v3.1.0
- Delete `.utils._BasePlotter.get_x_y` (we should access directly).
- Resolve #10 (Create `fill` argument in `TernaryDiagram.contour`).
- Resolve #11 (Create `auto_latex_notation` argument in `TernaryDiagram`).
- Update documentation.
- Update docstrings and typings.## LICENSE
See [LICENSE](https://github.com/yu9824/ternary_diagram/tree/main/LICENSE).
MIT Licence
Copyright (c) 2021 yu9824