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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8

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

Uploaded CPython 3.8macOS 10.14+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7m

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

Uploaded CPython 3.7mmacOS 10.14+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6m

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

File metadata

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

File hashes

Hashes for vpython-7.6.2rc2.tar.gz
Algorithm Hash digest
SHA256 fd418ef198c8120623b76774439f5663c6e0266fcbf105e00b8c8cb1a97d1494
MD5 a85ddf2c44908333d8b3466ca73a7841
BLAKE2b-256 ce331b5141c4a00523f27fd5e44259525681443ce83bf4fde21a75e9a0b72077

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for vpython-7.6.2rc2-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 c5a4f0ccb83e240ac1046fe54dd3d856580da3e912cfd5b4af3e1204005f8067
MD5 10e84883de2c59dd216ee0b7cb55604a
BLAKE2b-256 781f7c34946f63f9715f821e4234b7626b40bd8baf278b21fc6334d8c5d0683d

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for vpython-7.6.2rc2-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 75d90ce9954b27b80a0420966a88d1bd1ab3e8bbc9bd02c436c9a0eb94ae7352
MD5 0c40029667f04481488a580a022e084a
BLAKE2b-256 c312f4fb2734d52c5cafd379648b0d9838dbbf71b5d4dc661a8990586a7d6b84

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for vpython-7.6.2rc2-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 7e7f70a5ba1f6221e4e3800297e1a0b5b4f7fcf9ebc54de950aaec965a6380aa
MD5 d4b879fce73c752b01c016849ed9cfb0
BLAKE2b-256 3773d4d3530b65125c5c17e44751716335109a666d05f5f37a2debadf3652f56

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc2-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.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.7.9

File hashes

Hashes for vpython-7.6.2rc2-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 52e529a081c0522895949ca133cba2119626f372d34b9ce1761527645688a7fc
MD5 019ebf895df3a3ba775eefff9e0837d3
BLAKE2b-256 315693ba7b4e9c7e1ac303035c57e5dbc189bd2dd9c5037f3a2394aa76e3f063

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for vpython-7.6.2rc2-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 afe84ed7c8521f5bc3e0a73b97f500e5e11670aeca3cf7157b6028b7d78cf9ee
MD5 e1332974dd5529d56801de6822c5c68f
BLAKE2b-256 4dc056397bea73dabb630bcce88ef178085336f077f04f25590e5f8bd2bf9461

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc2-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.49.0 CPython/3.7.9

File hashes

Hashes for vpython-7.6.2rc2-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 48c8b7bc7c3883ead85863a1c87090f624de22780ea1b7b5101218fc585b1c5a
MD5 1ac052d10c1651dd229c0b588524ce43
BLAKE2b-256 053eb489ee647f492bab830b05d8b5618c3d940237ba91ecccd1b35c59565272

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc2-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.5.0.1 requests/2.24.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.6.8

File hashes

Hashes for vpython-7.6.2rc2-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 c1772dd5f8c7f124eb6ff14e3505284bf4314106c6357deaa59af0c82ac02df1
MD5 d9be43333e5b68a1a97f88df5f0fccf6
BLAKE2b-256 7a203a2acd83fdf35aeb3c4eda84a3e595989c55a232fe9ff199a762f03be0c0

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for vpython-7.6.2rc2-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 8aae9d7272f0d3c09c8097444d6a5ece7bcff38aeec4b257a0f79d7d5142591f
MD5 2637f683c2e335ebd4f4d7a32b724a13
BLAKE2b-256 63b63a22fbeb7ec737b43792393cfdc87929577edc0e91dc3b15ffa238225866

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc2-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.49.0 CPython/3.6.12

File hashes

Hashes for vpython-7.6.2rc2-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 14386ef74e502b39dbf95d9b6ddced0796e61d6a098486b1697012917e61c9c4
MD5 e75c4a28173ab32c32f5dc7b24d2f063
BLAKE2b-256 daf548f2e37f036bb6363b5b4416bf31c678c8ddebe4f9a78dffad1800c86be9

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