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.1b8.tar.gz (3.6 MB view details)

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8

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

Uploaded CPython 3.8macOS 10.13+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7m

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

Uploaded CPython 3.7mmacOS 10.13+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6m

vpython-7.6.1b8-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.1b8.tar.gz.

File metadata

  • Download URL: vpython-7.6.1b8.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.1b8.tar.gz
Algorithm Hash digest
SHA256 e44dc0ee946604dc614d62fb2e7a78b9aa047e6b3ffb9df2f3ec5f242a573389
MD5 794d7f96070d4ff3c989837b4385cc2b
BLAKE2b-256 2399a9120f6e33c86d7003676c7333db3a03a618de6ecc75cf4d80ef7c59f659

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 374dd66803ea3b0ed72465cc660bf3d291018c64609c5dc4e4df7f141689828b
MD5 62392f0ac9c08ceb95581ff2b49c1b8b
BLAKE2b-256 43fdb7b83791a37db19b73f62cfbaf7cd913b67240e564541ea80612ecbb99f4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 287f7745068b4717e3ba0b8764f46f77ffb7c27181b4e9df75499556254232f2
MD5 52360c1b88de6c0c1b6264f432c55051
BLAKE2b-256 9529f304fb92470ea2b21ef05cb740c1af739949530c006390f104f195162c14

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp38-cp38-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 5533a6ced87b22d8a444420f186b26673a4f318fa5606d1e2ef240911076f0a5
MD5 451e201f9b6d2b41d32012f0277745a0
BLAKE2b-256 c84b0588aa41a1042e7f38ad79fb9dabf165257769ab7343f85d2f8fa6b4b90c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 4ad46b64d96096cbfef2b5a6fbe4896c00ffdd70f09d2f1092651960a646d7fe
MD5 8546587dedb1ffcfc2ff1792fdfacde9
BLAKE2b-256 1b54203ccc4f3a3ead9eefc3a0c5282498314c3b1db0d56176f3c38e21b7e38e

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 5ee578b29cd58bd6b28125e79e77a757d69990f9bd219dbda625fa0492a406ac
MD5 b41ee2b2995ee298f4f5232ec77ac31d
BLAKE2b-256 48cfcd82d0a4bdf70797934539993317d342087a816f54dba0deeab2b63c76aa

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp37-cp37m-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 73c696533d7b44de7d81371526617b69c29a3f5359936acd29a8710a70a24efe
MD5 134c599be480404d7e3d5719cfb15452
BLAKE2b-256 b2e58d871e021372e69acdfa00d3d5f3534029ac2efef6178dd3d9507882fb4a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 7f27648fbb4680462c410b8de36d6e129a3eecfdfc1574f28f433a48ed129bb3
MD5 2c4ee07c38c6e9cd88f93a0648ce04e0
BLAKE2b-256 e78c97ff056003850c6a148892191275b95285b5946905d60598fe6c10d580f3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 c93c417f0a11b27a369948980d9e9adbc6af5ca612dc74df1913b43a2bc456ac
MD5 f65c0ee3f95af8c3a450cd51c4f11571
BLAKE2b-256 24ae529b9ba848ed31e1f1dabe54299bd15609e9f1cefb1ea0006742b6499e0e

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b8-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.1b8-cp36-cp36m-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 0be77c2ad983ecf87c8045f4edfc25eebfb61f6afd68a5749ef01b39c66dbd78
MD5 738a7ce6ec05f5ba54b5fe6fda7a4137
BLAKE2b-256 d3514361d3ea85bd8d7b33648cd31459bbab45b1871ef9b599f40455fa35e99c

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