Skip to main content

A highly interactive visual programming language

Project description

Image

pip install grapycal grapycal-builtin PyPI - Downloads License

Discord PRs Welcome GitHub contributors

Grapycal is a general-purpose visual programming language based on Python. It provides a web-based editor for writing and running programs as a graph.

The goal of this project is to make a programming language align with human perception at best, while being powerful with the help of Python, its backend.

Compatibility:

  • Python 3.11
  • Chrome browser (Grapycal is laggy on Safari; FireFox is not tested.)

Documentation

The full documentaition can be found here.

Get Started

# Requires python 3.11
pip install grapycal grapycal-builtin
grapycal # Grapycal will open at localhost:9001

If you have any questions or ideas to share, feel free to join the Discord server.

Contribute

Grapycal is still in its early stage. Any contribution is welcome! Currently, most of our efforts are on the backend (the core of Grapycal) and extensions (nodes with various functionalities), but it's also helpful to improve the frontend and the documentation.

To contribute, please refer to the Contribution Guide to get started. The Project Board contains the current plans for Grapycal and is a good place to start.

Feel free to join the Discord Server to discuss with us.

Features

Image

  • Interactive: On the GUI, users can run different parts of the graph in arbitrary order, watch variables in real-time, and easily track the active node while the program runs.

  • Dynamic: Grapycal allows users to modify the running graph for instant changes in its behavior. That includes adjusting parameters, adding or removing nodes from a workflow, and terminating a loop.

  • Extendable: Grapycal provides a set of API for creating custom nodes for arbitary domain, such as deep learning, robotics, or music synthesis.

  • Collaborative: Custom nodes definitions can be shared as Python packages. Thus, nodes for various domains can be mixed in a graph to form a powerful tool or a creative artwork (I’ll create some examples when I have time). What’s more, Grapycal supports real-time collaboration, allowing a group of people to work on the same graph over the Internet.

Grapycal is not (yet):

  • Fast: Grapycal is yet another layer of abstraction on top of Python. Some overhead is introduced for its interactivity and dynamics. However, the overhead would be relatively small if the graph doesn’t run at a high frequency ( less than ~1000 node runs per second ). For example, if your program mainly computes with C extensions (such as NumPy) or uses GPU heavily (such as deep learning tasks), there will be little impact on performance.

  • Stable: Grapycal is not heavily tested to ensure the graph always runs as expected.

Motivation

In our daily lives, countless ideas emerge in our minds, only to be dismissed because the perceived cost of realizing them is too high. Over time, sadly, we tend to forget our inherent creativity.

The mission of Grapycal is to push more ideas over the line to be worthy of trying out.

Grapycal is helpful for conducting experiments, including training AI, physical simulations, data analysis, computer art, and more. These experiments require repeated parameter adjustments, swapping certain components of models, while simultaneously observing the phenomena generated by different parameters. We then use human judgment combined with domain knowledge to deduce the best model or other conclusions.

In this back-and-forth process between humans and machines, using traditional Python execution methods or Jupyter notebooks can be cumbersome. Therefore, we need the higher interactivity provided by Grapycal.

Dependencies

Grapycal and its dependences consist of the following 6 packages:

Acknowledgement

Grapycal is inspired by these amazing projects. Also take a look at them

These tools or libraries help Grapycal a lot:

Star History

Star History Chart

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

grapycal-0.11.3.tar.gz (872.2 kB view details)

Uploaded Source

Built Distribution

grapycal-0.11.3-py3-none-any.whl (908.4 kB view details)

Uploaded Python 3

File details

Details for the file grapycal-0.11.3.tar.gz.

File metadata

  • Download URL: grapycal-0.11.3.tar.gz
  • Upload date:
  • Size: 872.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.3 Windows/10

File hashes

Hashes for grapycal-0.11.3.tar.gz
Algorithm Hash digest
SHA256 8373930d97db19da0bde5d8a67f5eb9c37a74d3bec3d248f8403e9a0c8e75bb8
MD5 acfbfab4b3818ba3c18e8a5bec029eef
BLAKE2b-256 3c290c675765679f1fb5be8180048706e6ffe1c4b86c1a449555ffd029f59205

See more details on using hashes here.

File details

Details for the file grapycal-0.11.3-py3-none-any.whl.

File metadata

  • Download URL: grapycal-0.11.3-py3-none-any.whl
  • Upload date:
  • Size: 908.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.3 Windows/10

File hashes

Hashes for grapycal-0.11.3-py3-none-any.whl
Algorithm Hash digest
SHA256 cb9d8cc1c7ddde77e8e2754d8c549aabd2234541956175bbcbdab20138c783d8
MD5 4d80d9033462496383088c5aac7fbc94
BLAKE2b-256 0dbd9bbe30358733e244d1acfd64e33c872672fcbbe4bf7710041d0db3b5e591

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