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

Uploaded Source

Built Distributions

vpython-7.6.2rc7-cp38-cp38-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.8Windows x86-64

vpython-7.6.2rc7-cp38-cp38-macosx_10_14_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.8macOS 10.14+ x86-64

vpython-7.6.2rc7-cp37-cp37m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86-64

vpython-7.6.2rc7-cp37-cp37m-macosx_10_14_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.7mmacOS 10.14+ x86-64

vpython-7.6.2rc7-cp36-cp36m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.6mWindows x86-64

vpython-7.6.2rc7-cp36-cp36m-macosx_10_14_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.6mmacOS 10.14+ x86-64

File details

Details for the file vpython-7.6.2rc7.tar.gz.

File metadata

  • Download URL: vpython-7.6.2rc7.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for vpython-7.6.2rc7.tar.gz
Algorithm Hash digest
SHA256 adfc0bb5e3abb9670f2b8813bc806d0d16d19e4360df116693885603cb24eb8d
MD5 2e5e7df05de97bddbf0cf9dd5ba77df7
BLAKE2b-256 7e7ae94656610f5beef9946303ab8cdac1ba8cc4cc5f4552860ea9b45dd26df6

See more details on using hashes here.

File details

Details for the file vpython-7.6.2rc7-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: vpython-7.6.2rc7-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.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for vpython-7.6.2rc7-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 a7350ec0fc36c25c4a4a517bb3dc0753d22c79c41712c89e3e99a17e52e28ab1
MD5 d1ab6313b6dcc11c03d523def68770c5
BLAKE2b-256 41d3d8d9969022ac7ab43428104ec4bfeeb5a224d701b2de56965486dbcd2784

See more details on using hashes here.

File details

Details for the file vpython-7.6.2rc7-cp38-cp38-macosx_10_14_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.2rc7-cp38-cp38-macosx_10_14_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.8, macOS 10.14+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for vpython-7.6.2rc7-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 0115f07885290f979d111a37d663361230eb32fecd2ff3025d83cd569eecdb5b
MD5 9cd127be711fa717585126c8c8a8eec9
BLAKE2b-256 067cbe16c1777acaaf24796bc56838245d9fe784107332eec0f0d3c034b129fe

See more details on using hashes here.

File details

Details for the file vpython-7.6.2rc7-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.6.2rc7-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.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.7.9

File hashes

Hashes for vpython-7.6.2rc7-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 0f7b6ed1598ce82b85514564fd68979b5af393108cb28e2cc92a2fb39064526e
MD5 a493675f4f8edf98772bc4ce0f59bf4d
BLAKE2b-256 64e3adcbbbccde517b7ef167e5001e1dc6dfa34288e3ba8ed9323edd8da5b7b8

See more details on using hashes here.

File details

Details for the file vpython-7.6.2rc7-cp37-cp37m-macosx_10_14_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.2rc7-cp37-cp37m-macosx_10_14_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, macOS 10.14+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.7.10

File hashes

Hashes for vpython-7.6.2rc7-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 6843b99461634243b6eea3b34b7bff9c762b469777f4d86b226ede4491af0dae
MD5 373081011a4a8a735bfeee9c5eb091dc
BLAKE2b-256 4f7e054bf797a91d25cb44cb3bbb800b58e5c20ff4f24fc699869fceb83291df

See more details on using hashes here.

File details

Details for the file vpython-7.6.2rc7-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.6.2rc7-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.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.6.8

File hashes

Hashes for vpython-7.6.2rc7-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 6ffe955926822fb6a6956deb5167e4d817aeabbb750c7f3dcbf74021b57cf569
MD5 9ebeec6ce7fd62e82024cf9144afbe6a
BLAKE2b-256 ec956e21d4c34a91132f496dabd104796b3d79b03058443719d9a7223ab1bd2c

See more details on using hashes here.

File details

Details for the file vpython-7.6.2rc7-cp36-cp36m-macosx_10_14_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.2rc7-cp36-cp36m-macosx_10_14_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, macOS 10.14+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.6.13

File hashes

Hashes for vpython-7.6.2rc7-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 6a7d0b93138011a60bd68967740ace62e8ac324fc8a226244d00dabeef39f293
MD5 597913bcc22ad5a97428047dfe26484b
BLAKE2b-256 09743c76bec1e17671ffeab331b1839aba4fd58d3fca96372c4825ac86bdff38

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