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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8

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

Uploaded CPython 3.8macOS 10.14+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7m

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

Uploaded CPython 3.7mmacOS 10.14+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6m

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

File metadata

  • Download URL: vpython-7.6.2b2.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.0 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b2.tar.gz
Algorithm Hash digest
SHA256 226845601dfcef8e41da2440e3716c1135ca1abbd305cdc8965cff99305684fe
MD5 242f4d5127e55e18d5d6bc389a588be5
BLAKE2b-256 1ac4e29999fec1daad5c01619b500f26d92dca9556a19524afa8b748221131ea

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b2-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 84cc5234cfe9ceff451db82d2bc68cb7e35a4dd68a9b8078e4ec2f2f3fab71cc
MD5 d43f9aead43b421a180af567f10f31d3
BLAKE2b-256 3e218d55f5535c30b18c720c42e1d435e523da0104a779d2b99dd1d769841080

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b2-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 39938b25c8769e024f1f3b0c68c194c334b1a113312dbb6241f200aabf9a96e4
MD5 bb308b219f31afd8c1d0cc71129e3b1b
BLAKE2b-256 8a0ec902a0a05a150ccbd25aac65d4cc780dfedc4cf044af73eeb6115f959d27

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b2-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 c2347e9ff3d33dd3d88448dba9c886fddc3e562f44d874ab71a7e2538ee00bbb
MD5 31290888090e3016fec0cd3c40dcb1e7
BLAKE2b-256 1c1e220c2bb02ac2a3e1a5caa3d72886c426ff4217a39b28a4f701d9a2b648bb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.7.8

File hashes

Hashes for vpython-7.6.2b2-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 473297b74269f510df0d744d2ad16fb8f727fd5d81096f8c1c48ef4e0acfb793
MD5 88d60e09fe21ba17bd30b7f6f738d7a3
BLAKE2b-256 eb6d2fa2677b4f0865a1ad2f09688ad7549e44159ab7e48b54a5bc6c4dee9739

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b2-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 655cfe0969fb420db69d9434bbeadb9cd5c6e513aff445f5b9e4b4d4aa7a4cb5
MD5 e1fc15f8539e054157925cc799dd8cb8
BLAKE2b-256 f60dae879b761424b629bd33f4c8fd91ceddc70c5f4e64e86cd99e5b5378cc7d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.7.8

File hashes

Hashes for vpython-7.6.2b2-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 e665c8b5d0a032547e4a793d2f84757d61358d2b90fba03b514e1b239aa44f12
MD5 3fc59387ef1f54b4ab45618a2d85663d
BLAKE2b-256 4c23704ab5b4e78b91f8f85381fb9d1cc4b3fc1b3ff576564817cfa5daf443cb

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for vpython-7.6.2b2-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 a7898abf2244a2c774e8ce104dedb4a3666fdb2bc6d456cfbc0e986ab30b9958
MD5 4c87dbb401e7d981913f937a399cff18
BLAKE2b-256 16b9c966c136870d45ae5273f8819176a03b85d203953976cbf1377b1901f0a4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.8.5

File hashes

Hashes for vpython-7.6.2b2-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 745805c975e106864930cf1ee40b1f6688f494672bafbddcb3a9443e500c9a5c
MD5 ba57256d546719799bdd00d8ad2a0017
BLAKE2b-256 c96672603580eae9713acd966d94c846bd22e71b06852311c1f3b49c40ac9a38

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2b2-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.0 CPython/3.6.11

File hashes

Hashes for vpython-7.6.2b2-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 0bca318ee2a4eeb4719cc2beeff84c729b8c9e2c444a01bee9170912823e17d4
MD5 234949cfa753cd032afeec19f4c84dad
BLAKE2b-256 98394b065b1d8a0fe0d144901a16fff52e4bc1ddf7088fdcb0e75e137cf18b27

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