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.2b4-cp37-cp37m-win_amd64.whl (3.6 MB view details)

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7mWindows x86

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

Uploaded CPython 3.7mmacOS 10.9+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6mWindows x86

vpython-7.5.2b4-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.2b4-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: vpython-7.5.2b4-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.2b4-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 9425c42edfdf794cbd18fe7b636cb5aa7b7fcc858f26073cf2830a65decaa051
MD5 7ade715adc34791a1855676ad0661930
BLAKE2b-256 87a69ed6dfe0e3eeae6156673d395efe9f9711cc14dc85ed20bbbd0586164842

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.5.2b4-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.2b4-cp37-cp37m-win32.whl
Algorithm Hash digest
SHA256 99be26d150d3dd814180f739be274672937d1296820e7c97496b4388fa17afae
MD5 ae3f921c9478971ee52f64da316e100a
BLAKE2b-256 166e556f052e6b65b8082aa8539615fb2313ec1422d8a9a86ba431ce5dab96fb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.5.2b4-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.2b4-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 5c59f2c70ca31e0861d2fe3ad7ef8fbff2d0304485866bb76e6b86e65026ca95
MD5 53cefb33afb7e8160a3b04e9472bcf02
BLAKE2b-256 3af654af27173f2852a45415fc28ce6720bb275a9f5b98fd86d549394923ee51

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.5.2b4-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.2b4-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 555162732eb0b08ec5d0b5c3b7b72299fb0c5eb3926b0b3fffa0e1f9fd834ebd
MD5 4e17021b05717b3bdf58ae53ecd6bb1b
BLAKE2b-256 912547eb6293b1e1a7badeb026d47eb39ee40b2927dcbf48122fff443ea1b9f9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.5.2b4-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.2b4-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 c308c6e8c6b06e57528c25dbf30776c60e329de7a9b530053097bc313810463b
MD5 c3b1c64f777047e1f271d444813d302b
BLAKE2b-256 3538f43593363eabb9135c08aadf096eaac3d8c94af3c2ae277d90f0d242dcc7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.5.2b4-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.7.3

File hashes

Hashes for vpython-7.5.2b4-cp36-cp36m-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 aa4b0b4ac5f00ff049af8f5c41a12c5c9de55a39c8423f0bd9eedd60df5c26d5
MD5 8b40445a6ed528ff088007cbe8bded16
BLAKE2b-256 59d8992542787a8ea93c6247cb001c9bb61b3a0aad54675d40fe999ab8fcae33

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