Skip to main content

VPython for Jupyter Notebook

Project description

VPython

This package enables one to run VPython in a browser, using the GlowScript VPython API, documented in the Help at https://www.glowscript.org. If the code is in a cell in a Jupyter notebook, the 3D scene appears in the Jupyter notebook. If the code is launched outside a notebook (e.g. from the command line), a browser window will open displaying the scene.

VPython makes it unusually easy to create navigable real-time 3D animations. The one-line program "sphere()" produces a 3D sphere with appropriate lighting and with the camera positioned so that the scene fills the view. It also activates mouse interactions to zoom and rotate the camera view. This implementation of VPython was begun by John Coady in May 2014. Ruth Chabay, Matt Craig, and Bruce Sherwood are assisting in its further development.

Installation

For more detailed instructions on how to install vpython, see https://vpython.org, where you will also find a link to the VPython forum, which is a good place to report issues and to request assistance.

Briefly:

  • If you use the anaconda python distribution, install like this: conda install -c vpython vpython
  • If you use any other python distribution, install this way: pip install vpython

Sample program

Here is a simple example:

from vpython import *
sphere()

This will create a canvas containing a 3D sphere, with mouse and touch controls available to zoom and rotate the camera:

Right button drag or Ctrl-drag to rotate "camera" to view scene.
To zoom, drag with middle button or Alt/Option depressed, or use scroll wheel.
     On a two-button mouse, middle is left + right.
Shift-drag to pan left/right and up/down.
Touch screen: pinch/extend to zoom, swipe or two-finger rotate.

Currently, to re-run a VPython program in a Jupyter notebook you need to click the circular arrow icon to "restart the kernel" and then click the red-highlighted button, then click in the first cell, then click the run icon. Alternatively, if you insert `scene = canvas()`` at the start of your program, you can rerun the program without restarting the kernel.

Run example VPython programs: Binder

Installation for developers from package source

You should install Cython (conda install cython or pip install cython) so that the fast version of the vector class can be generated and compiled. You may also need to install a compiler (command line tools on Mac, community edition on Visual Studio on Windows).

If you don't have a compilier vpython should still work, but code that generates a lot of vectors may run a little slower.

To install vpython from source run this command from the source directory after you have downloaded it:

pip install -e .

The -e option installs the code with symbolic links so that change you make show up without needing to reinstall.

If you also need the JupyterLab extension, please see the instructions in the labextension folder.

vpython build status (for the vpython developers)

Build Status Build status

Working with the source code

Here is an overview of the software architecture:

https://vpython.org/contents/VPythonArchitecture.pdf

The vpython module uses the GlowScript library (vpython/vpython_libraries/glow.min.js). The GlowScript repository is here:

https://github.com/vpython/glowscript

In the GlowScript repository's docs folder, GlowScriptOverview.txt provides more details on the GlowScript architecture.

Here is information on how to run GlowScript VPython locally, which makes possible testing changes to the GlowScript library:

https://www.glowscript.org/docs/GlowScriptDocs/local.html

If you execute build_original_no_overload.py, and change the statement "if True:" to "if False", you will generate into the ForInstalledPython folder an un-minified glow.min.js which can be copied to site-packages/vpython/vpython_libraries and tested by running your test in (say) idle or spyder. (Running in Jupyter notebook or Jupyterlab requires additional fiddling.)

Note that in site-packages/vpython/vpython_libraries it is glowcomm.html that is used by launchers such as idle or spyder; glowcomm.js is used with Jupyter notebook (and a modified version is used in Jupyterlab).

Placing console.log(....) statements in the GlowScript code or in the JavaScript section of glowcomm.html can be useful in debugging. You may also need to put debugging statements into site-packages/vpython/vpython.py.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

vpython-7.6.1b12.tar.gz (3.6 MB view details)

Uploaded Source

Built Distributions

vpython-7.6.1b12-cp38-cp38-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.8Windows x86-64

vpython-7.6.1b12-cp38-cp38-manylinux1_x86_64.whl (3.7 MB view details)

Uploaded CPython 3.8

vpython-7.6.1b12-cp38-cp38-macosx_10_13_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.8macOS 10.13+ x86-64

vpython-7.6.1b12-cp37-cp37m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86-64

vpython-7.6.1b12-cp37-cp37m-manylinux1_x86_64.whl (3.7 MB view details)

Uploaded CPython 3.7m

vpython-7.6.1b12-cp37-cp37m-macosx_10_13_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.7mmacOS 10.13+ x86-64

vpython-7.6.1b12-cp36-cp36m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.6mWindows x86-64

vpython-7.6.1b12-cp36-cp36m-manylinux1_x86_64.whl (3.7 MB view details)

Uploaded CPython 3.6m

vpython-7.6.1b12-cp36-cp36m-macosx_10_13_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.6mmacOS 10.13+ x86-64

File details

Details for the file vpython-7.6.1b12.tar.gz.

File metadata

  • Download URL: vpython-7.6.1b12.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b12.tar.gz
Algorithm Hash digest
SHA256 399e2718a58da7a7e43c3c7dedc48218d80764f6ca7c4afb62b3873aad5c4cb9
MD5 5e6a510d36bd05a5a8548082324a640d
BLAKE2b-256 b85c7c514b918f4723bc925794217d0a75872f8ffc1d4f696353150836e1c246

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b12-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 2e49f2553384e13704666b225bf9982ee7d03e49656f0bd12d78923a9efeb686
MD5 67133b531bdc2f43e5a90f1f28a83e8f
BLAKE2b-256 0293200ad614cd77a2c97929082e51a29e851652735c12c665770f1399663a70

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp38-cp38-manylinux1_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp38-cp38-manylinux1_x86_64.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: CPython 3.8
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b12-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 687d20fbca65bd946bcade157baf5218e68915ba4ac0315f80845ccd176f3062
MD5 e20376aceda671845e70acfb6f2e2a89
BLAKE2b-256 d26931aaabb907f4c2faf96c2dc7a3415b39c50b634b146ad2eabb2799b39d85

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp38-cp38-macosx_10_13_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp38-cp38-macosx_10_13_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.8, macOS 10.13+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b12-cp38-cp38-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 f7e26ac630ac0dd841407db1c2738230004d02577010dcd9778d31073c07c2a9
MD5 4e90af5df5ead2266280c7d853c3c6b0
BLAKE2b-256 c868c74009f749ce72246184ee48509155f1af2513c277a9ea80d8e93ab97fa6

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.6

File hashes

Hashes for vpython-7.6.1b12-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 483157cba258ec6bf197f83406512c9c7e15fa7b68e5bbd51b70a5d222d6aaa8
MD5 a9dcc6dc6a369aea6aef20a30ce45318
BLAKE2b-256 cf7633e7d8ce68761f8e23cb4c6b6f9fbbe44e753f29c2d26965601dfed1c34f

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp37-cp37m-manylinux1_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp37-cp37m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: CPython 3.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b12-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 2a22449d614da2e8109763cf077682d040e0c8ccfe08069a90a399850828fcdd
MD5 3b10ce09158a0c2bf709f129d183e7c5
BLAKE2b-256 c252e9fb5acaaa1c82f00c4baadb1a265b5b2bc91115c04528c1cffe33c36f56

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp37-cp37m-macosx_10_13_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp37-cp37m-macosx_10_13_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, macOS 10.13+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.6

File hashes

Hashes for vpython-7.6.1b12-cp37-cp37m-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 748fb512cae9ae674ea4cb1783688d2377caf07898abeb8afd64a623631ef64c
MD5 77f83662ff935109a013a1f68e510495
BLAKE2b-256 177f91ace817926aa43e8d982f68562d9a123dd2321ea0daef1c5a98977f1333

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.6.8

File hashes

Hashes for vpython-7.6.1b12-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 fbfcb1e85f43a52712b115f112d6c97582b27be68688b996d6cc05c42ae39b9f
MD5 9ccd3caae4cfbbfcc1d5188a03f69da5
BLAKE2b-256 bdbcd44a1e646ea7b464f801cc8597172ea990f0b0298e7acf8272c20e2d5dca

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp36-cp36m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: CPython 3.6m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b12-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 c17ae7ca687b13855a9ac79c0336e88e1110f851dd888df785ec610ca6c8fb0e
MD5 d088a582c0495f61d000f037031d064a
BLAKE2b-256 a4864d5fd271f06564d4301ff859d0d4717174081c42609ecc1372525c57f7bc

See more details on using hashes here.

File details

Details for the file vpython-7.6.1b12-cp36-cp36m-macosx_10_13_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.1b12-cp36-cp36m-macosx_10_13_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, macOS 10.13+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.6.10

File hashes

Hashes for vpython-7.6.1b12-cp36-cp36m-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 32ea94a5f6ff8076daae4cb93de194f4fda59a6b3d4f9c697f4f08efb57907b4
MD5 b0e4f178fc953d30d05e89ef47f6bb57
BLAKE2b-256 a7b07fcd5689e74768cd11bcf2f827f582e4e905496d2d4be870a2918216fc06

See more details on using hashes here.

Supported by

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