Metadata-Version: 2.3
Name: pooltool-billiards
Version: 0.5.0a2
Summary: A sandbox billiards game that emphasizes realistic physics.
License: Apache-2.0
Keywords: simulation,physics,pool,billiards,panda3d,snooker,eight-ball
Author: Evan Kiefl
Author-email: kiefl.evan@gmail.com
Maintainer: Evan Kiefl
Maintainer-email: kiefl.evan@gmail.com
Requires-Python: >=3.10,<3.14
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Games/Entertainment :: Simulation
Classifier: Topic :: Scientific/Engineering :: Physics
Classifier: Topic :: Scientific/Engineering :: Visualization
Requires-Dist: Pillow (>=6.2.0)
Requires-Dist: attrs (>=21.3.0)
Requires-Dist: cattrs (>=22.1.0)
Requires-Dist: click (>=8.0.0)
Requires-Dist: h11 (>=0.16.0)
Requires-Dist: h5py (>=3.10)
Requires-Dist: llvmlite (>=0.44.0)
Requires-Dist: msgpack (>=1.0.0)
Requires-Dist: msgpack-numpy (>=0.4.8)
Requires-Dist: numba (>=0.59.0)
Requires-Dist: numpy (>=1.26.0)
Requires-Dist: panda3d (==1.11.0.dev3702) ; sys_platform == "linux"
Requires-Dist: panda3d (==1.11.0.dev3702) ; sys_platform == "win32"
Requires-Dist: panda3d (>=1.10.13,<1.11) ; sys_platform == "darwin"
Requires-Dist: panda3d-gltf (>=1.2.0)
Requires-Dist: panda3d-simplepbr (>=0.12.0)
Requires-Dist: pyyaml (>=5.2)
Requires-Dist: rich (>=14.0.0,<15.0.0)
Requires-Dist: scipy (>=1.12.0)
Project-URL: Documentation, https://pooltool.readthedocs.io/en/latest/
Project-URL: Homepage, https://pooltool.readthedocs.io/en/latest/
Project-URL: Repository, https://github.com/ekiefl/pooltool
Description-Content-Type: text/markdown

<img src="https://github.com/ekiefl/pooltool/blob/main/pooltool/logo/logo.png" width="600" />

[![Project Status: Active – The project has reached a stable, usable state and is being actively developed.](https://www.repostatus.org/badges/latest/active.svg)](https://www.repostatus.org/#active)
[![GitHub license](https://img.shields.io/github/license/ekiefl/pooltool)](https://github.com/ekiefl/pooltool/blob/master/LICENSE.txt)
[![Documentation Status](https://readthedocs.org/projects/pooltool/badge/?version=latest)](https://pooltool.readthedocs.io/en/latest/?badge=latest)
![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/ekiefl/pooltool/test.yml)

![PyPI - Version](https://img.shields.io/pypi/v/pooltool-billiards)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/pooltool-billiards)
[![codecov](https://codecov.io/gh/ekiefl/pooltool/graph/badge.svg)](https://codecov.io/gh/ekiefl/pooltool)

[![Discord](https://img.shields.io/badge/Discord-Join%20Server-7289da?style=for-the-badge&logo=discord&logoColor=white)](https://discord.gg/8Y8qUgzZhz)

# Description

*Pooltool* is a general purpose billiards simulator crafted specifically for science and engineering.

Its core design principles focus on speed, flexibility, and the ease of visualization and analysis. With an interactive 3D interface, a robust API, and extensive documentation, pooltool aims to be a systemic tool in billiards-related research. Continuously evolving through active maintenance and bolstered by a growing community, this vision for pooltool emphasizes not just its current capabilities, but also its potential for growth and adaptation within billiards simulation.

Pooltool is peer-reviewed and published in the **Journal of Open Source Software** (JOSS) and **pyOpenSci**.

[![DOI](https://joss.theoj.org/papers/10.21105/joss.07301/status.svg)](https://doi.org/10.21105/joss.07301)
[![pyOpenSci Peer-Reviewed](https://pyopensci.org/badges/peer-reviewed.svg)](https://github.com/pyOpenSci/software-review/issues/173)

# Gallery

<img src="https://ekiefl.github.io/images/pooltool/pooltool-graphics/gallery_1.png" width="350" /><img src="https://ekiefl.github.io/images/pooltool/pooltool-graphics/gallery_2.png" width="350" /><img src="https://ekiefl.github.io/images/pooltool/pooltool-graphics/gallery_3.png" width="350" /><img src="https://ekiefl.github.io/images/pooltool/pooltool-graphics/gallery_5.png" width="350" /><img src="https://ekiefl.github.io/images/pooltool/pooltool-graphics/gallery_6.png" width="350" /><img src="https://ekiefl.github.io/images/pooltool/pooltool-graphics/gallery_7.png" width="350" />

# Installation & Documentation

<a href="https://pooltool.readthedocs.io">
  <img src="https://github.com/ekiefl/pooltool/assets/8688665/744fcd33-2e6a-4b8d-a727-634bb8295124" width="200" alt="rtd">
</a>

All resources are hosted at [https://pooltool.readthedocs.io](https://pooltool.readthedocs.io).

Quick links:

1. [🛠️ **Installation**](https://pooltool.readthedocs.io/en/latest/getting_started/install.html)
1. [📚 Examples](https://pooltool.readthedocs.io/en/latest/examples/index.html)
1. [🔌 API Reference](https://pooltool.readthedocs.io/en/latest/autoapi/pooltool/index.html)

# Join the community

[![Discord](https://img.shields.io/badge/Discord-Join%20Server-7289da?style=for-the-badge&logo=discord&logoColor=white)](https://discord.gg/8Y8qUgzZhz)

If you want to ask questions, get help, or contribute to the codebase, please join the Discord and introduce yourself.

If the Discord link is expired, please make an issue in this repo.

# Contributing

See the [Contributing page](https://pooltool.readthedocs.io/en/latest/meta/contributing.html) in the documentation.

# Blog

Many aspects of this project have been blogged about. Read the detailed account [here](https://ekiefl.github.io/projects/pooltool/).

# Citation

If you use pooltool in your research/project/product, please cite the JOSS publication:

[![DOI](https://joss.theoj.org/papers/10.21105/joss.07301/status.svg)](https://doi.org/10.21105/joss.07301)

```
@article{Kiefl2024,
    doi = {10.21105/joss.07301},
    url = {https://doi.org/10.21105/joss.07301},
    year = {2024},
    publisher = {The Open Journal},
    volume = {9},
    number = {101},
    pages = {7301},
    author = {Evan Kiefl},
    title = {Pooltool: A Python package for realistic billiards simulation},
    journal = {Journal of Open Source Software}
}
```

