LGPL library for small arms ballistic calculations based on point-mass (3 DoF) plus spin drift.
This repo offers py_ballisticcalc under the more convenient name pyballistic.
pip install pyballistic
# Using precompiled backend (improves performance)
pip install "pyballistic[exts]"
# Using matplotlib and pandas uses additional dependencies
pip install "pyballistic[charts]"
# Get everything, including the SciPy-powered calculation engine
pip install "pyballistic[exts,charts,scipy]"Work in your preferred terms with easy conversions for the following dimensions and units:
- Angular: radian, degree, MOA, mil, mrad, thousandth, inch/100yd, cm/100m, o'clock
- Distance: inch, foot, yard, mile, nautical mile, mm, cm, m, km, line
- Energy: foot-pound, joule
- Pressure: mmHg, inHg, bar, hPa, PSI
- Temperature: Fahrenheit, Celsius, Kelvin, Rankine
- Time: second, minute, millisecond, microsecond, nanosecond, picosecond
- Velocity: m/s, km/h, ft/s, mph, knots
- Weight: grain, ounce, gram, pound, kilogram, newton
Choose between different calculation engines, or build your own. Included engines:
| Engine Name | Speed | Dependencies | Description |
|---|---|---|---|
rk4_engine |
Baseline (1x) | None, default | Runge-Kutta 4th-order integration |
euler_engine |
0.5x (slower) | None | Euler 1st-order integration |
verlet_engine |
0.7x (slower) | None | Verlet 2nd-order integration |
cythonized_rk4_engine |
50x (faster) | [exts] |
Compiled Runge-Kutta 4th-order |
cythonized_euler_engine |
40x (faster) | [exts] |
Compiled Euler integration |
scipy_engine |
10x (faster) | scipy |
Advanced numerical methods |
This repository tracks the upstream project py-ballisticcalc while preserving a few local differences (package name, URLs, and select docs like this README).
- Sync locally:
python scripts/sync_upstream.pyto sync latestmasterfrom upstream.python scripts/sync_upstream.py --ref pull/219/headto sync a specific PR.- Add
--cleanto remove files deleted upstream (excluded paths remain).
- Automation:
- GitHub Action
Sync Upstreamruns on-demand, opening a PR with changes. It can also be scheduled to run regularly (uncomment thescheduleblock).
- GitHub Action
- Configuration:
- See
sync_config.jsonfor upstream repo/branch, text/path replacements, and excluded files. Adjustexclude_pathsif you want additional files to remain customized here.
- See
The library performs numerical approximations of complex physical processes. The calculation results MUST NOT be considered as completely and reliably reflecting real-world behavior of projectiles. While these results may be used for educational purpose, they must NOT be considered as reliable for the areas where incorrect calculation may cause making a wrong decision, financial harm, or can put a human life at risk.
THE CODE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.