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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

vpython-7.6.2b3-cp38-cp38-manylinux1_x86_64.whl (3.7 MB view details)

Uploaded CPython 3.8

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

Uploaded CPython 3.8macOS 10.14+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

vpython-7.6.2b3-cp37-cp37m-manylinux1_x86_64.whl (3.7 MB view details)

Uploaded CPython 3.7m

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

Uploaded CPython 3.7mmacOS 10.14+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

vpython-7.6.2b3-cp36-cp36m-manylinux1_x86_64.whl (3.7 MB view details)

Uploaded CPython 3.6m

vpython-7.6.2b3-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.2b3.tar.gz.

File metadata

  • Download URL: vpython-7.6.2b3.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b3.tar.gz
Algorithm Hash digest
SHA256 f2455e1f067bc084f371542c452e99865f3c792722cc09c427ed00b2a710458d
MD5 e259888a3dcd10e941ef0c18c393e42a
BLAKE2b-256 4e60ae79959b1d656f37fb2cc2e0dca9ea6b21d506ed9493aed21467dc707213

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b3-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 f28990d52f2e6018ad24e4344ac60787df922d20e21188934f226aeadf7a1f70
MD5 68c638e901f0892037a1ce57fb268cfb
BLAKE2b-256 86655624561ac266bfcaf52f71051a745df99f16bb2fff014829cb957e72ee1a

See more details on using hashes here.

File details

Details for the file vpython-7.6.2b3-cp38-cp38-manylinux1_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b3-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 1564f42b27638a7b4f4c69d8119044a3ea305bafce904f9a9a0cb3a6b263e5e0
MD5 4653c5b6b58ce03cdde93fa886ab371b
BLAKE2b-256 c4499fba96500a373e9cc817afb9a3d2193a8837f5bf449f75c2ba9692b6f9a2

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b3-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 889b729464bf7f14ffff1c7898c0686a35ab522b371b23565e75e9e4720c4024
MD5 bc086ef2767fdd780a3623cd97432449
BLAKE2b-256 3299d049938c34045d8e80c728758401d165955edc51293fde8f1a152a6c526d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.8

File hashes

Hashes for vpython-7.6.2b3-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 9379ebdce6d8e233caebe5f3268d496e30af0f06c460573fe3eefdb453bc9adc
MD5 b92fb3b770740de8f57523db1f5ae8d3
BLAKE2b-256 3bb5fc874bd91a691628fd418b53e1a5860997ef1e7195a9cfa58a2a08cd80e2

See more details on using hashes here.

File details

Details for the file vpython-7.6.2b3-cp37-cp37m-manylinux1_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b3-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 f00ab8c3a9f4910bc4cb23c09568cf4780de4db8e5371ca352a10f8b2999a7f3
MD5 c00c3f3369d4497dd5786757f14705dd
BLAKE2b-256 7a17c0a6aed39b78bfc99a4cd1533aa391e3d3e07c75a728316af01b95251b55

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.8

File hashes

Hashes for vpython-7.6.2b3-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 9d58bdee3a02c4023c5d609d0ac2423911061cf41a65d8182998bd7996c09be7
MD5 b21193dc8636bb12a2446294898b131a
BLAKE2b-256 099ae2fe79b400d8b9ce325c9302211b66469278ecb9d9db937a027382c22b54

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.6.8

File hashes

Hashes for vpython-7.6.2b3-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 35ac264d2963f18ee5643d78abfacf1a629211b2251706174f15a001dd773f1a
MD5 a7c4ecfaa4ad71143c70bb16689b4af2
BLAKE2b-256 be06d3de804bcbf535cdbca3d3599fae6d5c4c0facb7c12892f386bbffc0fc99

See more details on using hashes here.

File details

Details for the file vpython-7.6.2b3-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b3-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 973daba7256766a0ff74c6395389b770a222300818d071614842745379ea578e
MD5 86cc46434899f56428fa987897194df9
BLAKE2b-256 789a5a218be0fcd8e7fc46a41be11334312386c88a6c4d8cb7d630fb3f37d869

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b3-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.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.6.11

File hashes

Hashes for vpython-7.6.2b3-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 2a977d59859d7a16b4c823d95a2c5175b77975c1f84f14298cef33323dcd937f
MD5 a16aea756fad4c6790cf313756009975
BLAKE2b-256 92a28a863362a6472ac73429564f54f857e453d08d9b5800bbbcf0ad8acf9a36

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