Skip to main content

A Manim extension for animated statistical visualisations — distributions, regression, probability, inference and more.

Project description

STATANIM — Statistical Animation for Manim

PyPI version PyPI Downloads Python 3.10+ Manim Community License: MIT

A Manim extension for animated statistical visualisations.

Distributions, inference, regression, probability theory, and physical props — all built on Manim Community.


Why statanim?

Manim is extraordinary at animating mathematics — but when it comes to statistics, you're on your own. Want to show a normal distribution shading its tails as sigma changes? A probability tree that builds itself node by node? A deck of cards dealing out to demonstrate hypergeometric sampling? With vanilla Manim, each of these requires hundreds of lines of low-level geometry code before you even start on the actual statistics.

statanim closes that gap. It gives statistics the same treatment Manim gives mathematics: objects that understand what they represent, animations that carry statistical meaning, and a workflow that stays out of your way so you can focus on the idea you're trying to communicate.

Whether you're building lecture slides, making YouTube explainers, or just trying to build intuition for a concept — statanim lets you go from idea to animation in minutes, not days.


Demo

Sample Space

Sample Space

Classical Probability

Classical Probability

Conditional Probability

Conditional Probability

Hypergeometric Distribution

Hypergeometric Distribution

Birthday Paradox

Birthday Paradox


Installation

Prerequisites

pip install manim

LaTeX is required for formula rendering:

# macOS
brew install mactex-no-gui

# Ubuntu / Debian
sudo apt-get install texlive-full

# Windows: install MiKTeX from https://miktex.org/

Install statanim

pip install statanim

Install from source

git clone https://github.com/rishabhbhartiya/statanim.git
cd statanim
pip install -e .

Verify

from manim import *
from statanim.props.card import Card3D
from statanim.distributions.normal3d import NormalCurve3D
from statanim.core.colors import DARK_THEME

Quick Start

Normal distribution with shaded region

from manim import *
from statanim.distributions.normal3d import NormalCurve3D

class NormalDemo(Scene):
    def construct(self):
        axes = Axes(x_range=[-4, 4, 1], y_range=[0, 0.45, 0.1],
                    x_length=8, y_length=4)
        curve = NormalCurve3D(mu=0, sigma=1, axes=axes)

        self.play(Create(axes))
        self.play(Create(curve))
        self.play(curve.shade_region(x_min=-1, x_max=1))
        self.wait(2)

Probability with playing cards

from manim import *
from statanim.props.card import Deck3D, CardFacing, standard_deck

class CardDraw(Scene):
    def construct(self):
        deck = Deck3D(cards=standard_deck(shuffle=True, seed=0),
                      initial_facing=CardFacing.FACE_DOWN)
        deck.move_to(LEFT * 3)
        self.play(FadeIn(deck))
        self.play(deck.deal_one(target=RIGHT * 2, flip=True))
        self.wait(2)

What's Inside

Module What it gives you
distributions Normal, Binomial, Poisson, Hypergeometric, Beta, Gamma, Chi-squared, Student-t, F — all with PDF/PMF/CDF visualisers and shadeable regions
charts BarChart3D, Histogram3D, BoxPlot3D, ViolinPlot3D, HeatMap3D, ScatterPlot3D, LinePlot3D — statistically correct, 3D-aware
probability SampleSpace3D, VennDiagram3D, ProbabilityTree3D, BayesBox3D — builds event regions and conditional flows step by step
inference HypothesisRegion3D, ConfidenceInterval3D, SamplingDistribution3D, Type I/II error visualisation
regression RegressionPlane3D, ScatterCloud3D, residual diagnostics, correlation matrices, CI/PI shells
props Card3D, Deck3D, Coin3D, Die3D (D4–D20), Spinner3D, Urn3D — physical probability objects with built-in logic and animations
animations CLTDemo, DistMorph3D, ParameterSweep3D, BootstrapSampling3D, ScatterToRegression3D
ui Ticker3D, PValueTicker3D, FormulaPanel3D, DataTable3D, AnnotationArrow3D
core 6 built-in themes (DARK, LIGHT, PAPER, and more), diverging colormaps, 50+ LaTeX formula builders

Full class and parameter documentation: API_REFERENCE.md


Camera Orientation Reference

All ThreeDScene subclasses need an explicit camera orientation at the top of construct().

def construct(self):
    self.set_camera_orientation(phi=70*DEGREES, theta=-45*DEGREES)
Scene type phi theta
3D bar chart 65° -55°
Regression plane 70° -45°
Scatter cloud 70° -60°
Card grid (table-top) 60° -45°
Bivariate normal surface 68° -45°

Use Scene (not ThreeDScene) for 2D content: PDF curves, PMF bars, Venn diagrams, histograms, box plots, probability trees, and hypothesis test plots.


Development Setup

git clone https://github.com/rishabhbhartiya/statanim.git
cd statanim
python -m venv .venv
source .venv/bin/activate       # Windows: .venv\Scripts\activate
pip install -e ".[dev]"

Contributing

Issues and pull requests are welcome at github.com/rishabhbhartiya/statanim.

When adding a new distribution, inherit from BaseDistribution3D, implement pdf/pmf, cdf, mean, variance, and add a scene in scenes/demo_distributions.py.


Acknowledgements

Built on Manim Community. Statistical algorithms from SciPy and NumPy. Inspired by the mathematical animation work of 3Blue1Brown.


License

MIT License. See LICENSE for details.

Author: Rishabh Bhartiya — rishabh.bhartiya.in@gmail.com

Project details


Download files

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

Source Distribution

statanim-0.1.3.tar.gz (717.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

statanim-0.1.3-py3-none-any.whl (745.9 kB view details)

Uploaded Python 3

File details

Details for the file statanim-0.1.3.tar.gz.

File metadata

  • Download URL: statanim-0.1.3.tar.gz
  • Upload date:
  • Size: 717.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for statanim-0.1.3.tar.gz
Algorithm Hash digest
SHA256 985d5a59868fad79b3a637f3c7d0a2325a6fe140cbb5e476e8ee2025ce097b47
MD5 45ac59ba0d826e298bfbbd66f5cbf9e1
BLAKE2b-256 efd0eaa4bf366fc8fabddd7fe49bf8a7f4c8316bdcb7383a0a05a43ad3103132

See more details on using hashes here.

File details

Details for the file statanim-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: statanim-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 745.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for statanim-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 26b4270e72a6ae515e6ebc0e18458e6969238aa087e04610243b91af366e5688
MD5 7d1d1a9a8ac68b4e5d3b3c2691665631
BLAKE2b-256 e2a0125d8c7bb9953e88fcb5bc3b97b7ded2b83180980fd669d1d269f751840b

See more details on using hashes here.

Supported by

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