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 Distribution

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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8macOS 10.13+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7mmacOS 10.13+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

File metadata

  • Download URL: vpython-7.6.1b2.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.41.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b2.tar.gz
Algorithm Hash digest
SHA256 35b3b798254e01e42788082d0474e8a0ed52299721a5abf2ec5a321643ca7009
MD5 eaa54899fad2f8f9dc13f1ca9c23954b
BLAKE2b-256 52edfe4f87f463b79d25de108c7a79adab24f17aed40c2e9baafc70c6f8f72b7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b2-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.41.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b2-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 ca0a75ca2f12fd08c0343019e0d19475baf93e9ec7ee2aa4e80eac550fc5c9e3
MD5 0b6933c1ec3c6d23d0867b08ef5dccba
BLAKE2b-256 080d17153a7ca76a12c4aacc708e12ed17cfa3db0e44ba031d78801f821a335c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b2-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.41.1 CPython/3.8.1

File hashes

Hashes for vpython-7.6.1b2-cp38-cp38-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 1a7bf5037b549ad51bb701e97c9f6d7834ccf52e71a397c2c956ed0f588d6139
MD5 fcbbfaaf804cb8d39ae92adf1ca7c007
BLAKE2b-256 c5de31bb860503b80779a3457a3a692d13d0268437400ab757442bcee33338a0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b2-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.41.1 CPython/3.7.6

File hashes

Hashes for vpython-7.6.1b2-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 581a952208d80c1f9240808e2400f44eb0384e1c9800ee04a24deb8785ce648c
MD5 aa0f2f39875ffd08503b15c3a0b9bff5
BLAKE2b-256 d782b5c0bea432b259abe44e1ae08e8c6648845e532133efb8317f36b41ce645

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b2-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.41.1 CPython/3.7.6

File hashes

Hashes for vpython-7.6.1b2-cp37-cp37m-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 13324353978042be07701c4528485ed6fc6a83229c0ad0203a6c69f2e98152fd
MD5 63aed719213f1f3f69524e4dc4a326c3
BLAKE2b-256 5c8cca43c4593f0116e9806713ff30eb9e2403dc1cbac3c659fb98529b11ef6b

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b2-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.41.1 CPython/3.6.8

File hashes

Hashes for vpython-7.6.1b2-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 7e0817afb8f1656edc871a4b9f85fb8469187376ecf1d46b8263845b4ef56b2a
MD5 2fa6a672b4a351ba536c88b6752fa803
BLAKE2b-256 353d28a45514e47a0069fa5c9531d97ed2bffe7747b6eb58a6b0370d955de9ff

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.1b2-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.41.1 CPython/3.6.10

File hashes

Hashes for vpython-7.6.1b2-cp36-cp36m-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 803c674db6fc8599245f7c10d6eb560b455895d84ede180c2e1a09c33c372029
MD5 38378dbb56860e7b2c3f24ca8e21154b
BLAKE2b-256 0335f8d9eb21f6b2b12ccc1bb9cee095a9d3ae28fa696d3ec435ced2cb89c5c0

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