Skip to main content

Library for drawing spirographs in Python

Project description

spyrograph: elegant mathematics and geometries

Animation of three geometric, symmetrical shapes being drawn next to one another left to right. The shape on the left is red, the middle green, and the right is blue.

What is it?

spyrograph is a lightweight Python package that provides an expressive and flexible set of tools for drawing beautiful mathematically driven art. With just a few lines of easy-to-read code you can start analyzing, visualizing, and exploring elegant mathematics

Downloads Issues License Version Documentation Status

"Buy Me A Coffee"

Official website

Official docs

Table of Contents


:key: Key features

  • Expressive and consistent syntax
  • Robust underlying mathematics
  • Beginner and expert friendly
  • numpy is the only required third-party installation
  • Clear visualizations and animations
  • Flexible to a wide range of usecases
  • Lightweight, just plug and play

Sample hypotrochoid drawing showing a circle rolling around the interior of another circle drawing a geometric shape


:computer: Installation

pip

Install the latest stable release from PyPI using

$ pip3 install spyrograph

or clone the development version from GitHub with

$ git clone https://github.com/chris-greening/spyrograph.git

:seedling: Quickstart

spyrograph is designed to be expressive and easy-to-use - simply import spyrograph and jump right into drawing elegant, complex shapes in just a few lines of code!

from spyrograph import Hypotrochoid

# Trace a hypotrochoid from 0 to 2pi where
# the fixed circle radius is 300, rolling circle 
# radius is 200, and the distance from the rolling 
# circle is 100
hypotrochoid = Hypotrochoid(
    R=300,
    r=200,
    d=100,
    thetas=np.arange(0, 2*np.pi, .1)
)
hypotrochoid.trace(
    show_circles=True, 
    frame_pause=.05, 
    circle_color="grey"
)

:pray: Contributing

All contributions, bug reports, bug fixes, documentation improvements, enhancements, and ideas are welcome!

Feel free to open an Issue, check out existing Issues, or start a discussion.

Beginners to open source are highly encouraged to participate and ask questions if you're unsure what to do/where to start


:newspaper: Blog posts

Check out the official website for the latest blog posts on the project!


:books: Documentation

The official documentation can be found on Read The Docs


:credit_card: License

This library operates under the MIT license.


:grey_question: Support

Reach out to me if you want to connect or have any questions and I will do my best to get back to you

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

spyrograph-0.29.0.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

spyrograph-0.29.0-py3-none-any.whl (29.4 kB view details)

Uploaded Python 3

File details

Details for the file spyrograph-0.29.0.tar.gz.

File metadata

  • Download URL: spyrograph-0.29.0.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.4

File hashes

Hashes for spyrograph-0.29.0.tar.gz
Algorithm Hash digest
SHA256 72f97f27b0c1b786210345c7bd09a0793fc589076c43930c3471d5b7e40c6d3d
MD5 8331a961db076b45968f1b3fe4e9643c
BLAKE2b-256 56508950a37aec7aa6d1b0d0e209fe469380f6efd1e8237f72be735b30f0a5b7

See more details on using hashes here.

File details

Details for the file spyrograph-0.29.0-py3-none-any.whl.

File metadata

  • Download URL: spyrograph-0.29.0-py3-none-any.whl
  • Upload date:
  • Size: 29.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.4

File hashes

Hashes for spyrograph-0.29.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8083f3c98e5c69a91c173c71fc7e57f761b8e8ad56a055f5e0e866f4988ed1d3
MD5 b357eb28785b5c168005bc11eea5d31b
BLAKE2b-256 e3fe2e20eb53f29cddce6710311a01bb697a9c87eefc96820d5877d51eb72ac1

See more details on using hashes here.

Supported by

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