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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8

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

Uploaded CPython 3.8macOS 10.14+ x86-64

vpython-7.6.2rc3-cp37-cp37m-win_amd64.whl (3.5 MB view details)

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7m

vpython-7.6.2rc3-cp37-cp37m-macosx_10_14_x86_64.whl (3.5 MB view details)

Uploaded CPython 3.7mmacOS 10.14+ x86-64

vpython-7.6.2rc3-cp36-cp36m-win_amd64.whl (3.5 MB view details)

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6m

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

File metadata

  • Download URL: vpython-7.6.2rc3.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for vpython-7.6.2rc3.tar.gz
Algorithm Hash digest
SHA256 8e4df523f8e9fcd93d4385f134fa00b539e3ecebce4b7347754301dc66502ea8
MD5 64b3c8ab0adc1bdf76d279a956d0ce50
BLAKE2b-256 a4ceb555595de3c1c8c8068262b398ffc185e32c5e8836d88b1fa4408037d281

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-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.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for vpython-7.6.2rc3-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 4172ccd6bd588ccd7b4f3d829cf16c1013c47990998429891be452d6871c600f
MD5 8b27ae7d17a9f1726d2815955e34e6a8
BLAKE2b-256 67fdaa4fd04f8c5ebf95c80b87d13fd3f6eb92434849edca88402a48266c0ec0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-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.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for vpython-7.6.2rc3-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 0ee4a1f64f3f6416b5d69e783c5417ba7817b291b0354a8347fb8da3cdc65bd5
MD5 81cde74d64211980dcf7259ba77ef046
BLAKE2b-256 9d9534ebce21ead3a4d48b1e81bba78ab2380ab7649f8d7696fa86bd2935992d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-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.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for vpython-7.6.2rc3-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 5e12b4832df02447aea90b2ca47f6e8c22f75088d529d7164755c460994d9a4f
MD5 a1e5efc98f4aff2dd1941132d6155631
BLAKE2b-256 eca07069c64b2e6e0dd6377c9c9d6052a505cf8cb6fe82aa1eb93f2f1e2271c9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 3.5 MB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9

File hashes

Hashes for vpython-7.6.2rc3-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 1d6172a7eab8fd3cc1b41a57c7a916272c628fd4fa6aa037a0c6a9b722c45cb4
MD5 ab2f8669a23ce0092fc965e1b42b711b
BLAKE2b-256 0cd19796c48c783efc129fc1467a85a6d4c8cb2a1fe3221ae6cb3c4cc9ccb42f

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-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.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for vpython-7.6.2rc3-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 9fc937153a65944c76dcf7d614a5c64b0b067706efc825a3cf6374539194b965
MD5 d7d0b9d8651d11141233244d33dd7d00
BLAKE2b-256 bac60711ab93f79040e4d89affadbb16632e95c6feb2ff0e59c2123896cd1236

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-cp37-cp37m-macosx_10_14_x86_64.whl
  • Upload date:
  • Size: 3.5 MB
  • Tags: CPython 3.7m, macOS 10.14+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9

File hashes

Hashes for vpython-7.6.2rc3-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 b83eb145fffa9dbe35d778d2acac4a4532a05d897e676ef40ad64a953a3530c5
MD5 1e208ce8d0ae1deae2cc508c13c67e13
BLAKE2b-256 20d1c006178d064f73ab493fef8e05dc1af0ae0b58b4339594f17d3a1885c888

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 3.5 MB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.6.8

File hashes

Hashes for vpython-7.6.2rc3-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 61ef9e90600076d3debe4125d72382c65efbcb14913a96ce93967ca45d92deb2
MD5 800a79fe213b4ea4980ee32c8b367c23
BLAKE2b-256 d017398ccfc3479e250c7cd6e12f05a9c3eb9af633b8e8b8eca1696f646f23f6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-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.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for vpython-7.6.2rc3-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 e777e911a17f1eeeb895bc782856a5bb325f06bb2e2537d843e08b97be3a45f9
MD5 8d9a83b577c47f22adb4a716e503e4a5
BLAKE2b-256 0d693fce4668a3b323dc95e7fae3a4d0f4100cbb92bb9d8e41eec8cc3c0e7ff4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc3-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.6.1 requests/2.24.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.6.12

File hashes

Hashes for vpython-7.6.2rc3-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 49f4c3084d561fc3770bd2e68ddcb38c19a359bc0e6c0b0690d37943d3ed1281
MD5 723e1f66345e026770c7610d35b9615a
BLAKE2b-256 079e3ba8ad3ef0cdbf26c32d1efaf1f54dad842f41fdad1cfc3a8ecde947c462

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