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

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 Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

vpython-7.5.2b5-cp37-cp37m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86-64

vpython-7.5.2b5-cp37-cp37m-win32.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86

vpython-7.5.2b5-cp37-cp37m-macosx_10_9_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.7mmacOS 10.9+ x86-64

vpython-7.5.2b5-cp36-cp36m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.6mWindows x86-64

vpython-7.5.2b5-cp36-cp36m-win32.whl (3.6 MB view details)

Uploaded CPython 3.6mWindows x86

vpython-7.5.2b5-cp36-cp36m-macosx_10_7_x86_64.whl (3.6 MB view details)

Uploaded CPython 3.6mmacOS 10.7+ x86-64

File details

Details for the file vpython-7.5.2b5-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.5.2b5-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/2.0.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.1

File hashes

Hashes for vpython-7.5.2b5-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 cb774312acf5e5c1f405b9d4c324c05c86ab03e471866a30565b4e3975563b6f
MD5 744df89fddb1ca674415d212290c891c
BLAKE2b-256 563b3b2064258a79095cb44e0b239d66e532211863825e78fbc2fd8429108a0f

See more details on using hashes here.

File details

Details for the file vpython-7.5.2b5-cp37-cp37m-win32.whl.

File metadata

  • Download URL: vpython-7.5.2b5-cp37-cp37m-win32.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, Windows x86
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.1

File hashes

Hashes for vpython-7.5.2b5-cp37-cp37m-win32.whl
Algorithm Hash digest
SHA256 948ca5cb8bd591c4f9f20513d243f9635f67609684b9d27d87f258260111dd1b
MD5 228abcb3e049ec0101f0cf92df459d52
BLAKE2b-256 80e0ee7ae880267aa60725c5a30433c2cbbfccb3c83ecf9df921b19815d2db4e

See more details on using hashes here.

File details

Details for the file vpython-7.5.2b5-cp37-cp37m-macosx_10_9_x86_64.whl.

File metadata

  • Download URL: vpython-7.5.2b5-cp37-cp37m-macosx_10_9_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.7m, macOS 10.9+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.3

File hashes

Hashes for vpython-7.5.2b5-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 157fb2db5932e9fb72e88b99c92b1b14667bbb5f10e6c9e98e516f0703e6f420
MD5 ca504b65d1fe2693ddbb0b53d28297f9
BLAKE2b-256 b4dbf9dc4f0a26a9a239a2094ec8a4b46c58539670607e70aae79109a6b4db56

See more details on using hashes here.

File details

Details for the file vpython-7.5.2b5-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.5.2b5-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/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/39.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.5

File hashes

Hashes for vpython-7.5.2b5-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 de4cfa685e74d16e0c2ca240fde7804a7c24738be0d0498068bd4152835bad03
MD5 c85d8394853884bb8b0435ed5a56c355
BLAKE2b-256 240adccfa46cff04592ff30af69ede20dc3e35ec31df9216e9c684916a1d9a39

See more details on using hashes here.

File details

Details for the file vpython-7.5.2b5-cp36-cp36m-win32.whl.

File metadata

  • Download URL: vpython-7.5.2b5-cp36-cp36m-win32.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, Windows x86
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/39.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.5

File hashes

Hashes for vpython-7.5.2b5-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 c62beda4c2b57a0035b3e0606ac54bf8b1188f4a527bb7c806e1cee2bfe6979a
MD5 253c3ff8421a3336ef9045d5cdaa7d4f
BLAKE2b-256 96a96c653f32e5231d4d48a6d6a4e4265ac872eb46328a0b77d31d7ace6652f2

See more details on using hashes here.

File details

Details for the file vpython-7.5.2b5-cp36-cp36m-macosx_10_7_x86_64.whl.

File metadata

  • Download URL: vpython-7.5.2b5-cp36-cp36m-macosx_10_7_x86_64.whl
  • Upload date:
  • Size: 3.6 MB
  • Tags: CPython 3.6m, macOS 10.7+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.9

File hashes

Hashes for vpython-7.5.2b5-cp36-cp36m-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 6ed25f926c55eaa442d657095ef2b82c5762730eb06330d163ce3a227b292b69
MD5 2ebd64fd928f1b5281b6eb6728138b78
BLAKE2b-256 47e4b1cf4f5598f2875f5f32669404ccd3d2cf7180bcfaa52aaf71a1410e46df

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