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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8

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

Uploaded CPython 3.8macOS 10.14+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7m

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

Uploaded CPython 3.7mmacOS 10.14+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

Uploaded CPython 3.6m

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

File metadata

  • Download URL: vpython-7.6.2rc4.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.25.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.2rc4.tar.gz
Algorithm Hash digest
SHA256 4867cf8a71a8d26d154f5a51dfd4e7546cdbc5f6744756c517a9bed531496d7c
MD5 02fa6e74f714be9c3d75615f3bb37db6
BLAKE2b-256 49be959a92792acbe63040b4501bdb09d7b04649e22624db695aebe67dcec3a3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.25.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.2rc4-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 ab3db8c366e03dd7c168b97b8ef3888c15b948d536d007759b1d535f939da953
MD5 3778979fd4143242d87eaaedacedc0f8
BLAKE2b-256 4363084915450a98692f1bf26f03cec6965d53c3453d06c874c2e18c59d27ff9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.25.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.2rc4-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 6f04030f8e2ed58e18f0a630d2e342d7c1afe558f9bdd7afb4f19ddc406bc6d6
MD5 fa720ffd2f2f0bf42be9faf71483b26f
BLAKE2b-256 238c2d29bd43b29e23c416e6ea24690bbb3a38e35a3aa880d17080009574ccbe

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.25.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.2rc4-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 5377eea18c2a79c42c822cf2471ce0b7f66ef8f72dfacf7bf82a665ed10567f0
MD5 78453506755939e736564259e0bebb52
BLAKE2b-256 656f1e27101e1c154b61967ce750708b6dd591fc0c05a76af438372900bb4725

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.6.1 requests/2.25.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.2rc4-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 e59c1de96c2ee1e265d502f49d8f148c37bf2671d90b5d2f793f69236d99a9b2
MD5 236071a430a3a9b5fac9d0bde89e1d86
BLAKE2b-256 553f59bf071491fde774e1225e6276ada021f61688010bb138d3a9cd9f294bdb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.25.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.2rc4-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 5dda01cd0c856ff3f4a06987c0dd245777dd0402f59405f9594bb5cf9f47640b
MD5 ee4f4ef91403b1067b0b362d608bf509
BLAKE2b-256 f0fa9abe34943847169e537556859afe85b056f946ce34754fc184126b2a33ae

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.6.1 requests/2.25.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.2rc4-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 97a042d25650e7b6e257b32244e33eeafbd8421829342943e27337c42dc4a27d
MD5 19744aa6e54067d595be9565cae0ba27
BLAKE2b-256 e47b4200937a57aaa00d2424c6f2406218d2978e74beba0761b9af3997294780

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.6.1 requests/2.25.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.2rc4-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 11ad37e6f04eff1c868c1cdd006f41b50828b8e41cb84f448d0ffc7a8a1113c6
MD5 ca88e697c7afe04c958546b357398e62
BLAKE2b-256 426f33be152c499ecd4ef800b95fcddcb93113ff4711abfc1a7522c0dbf7c9d6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.25.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.2rc4-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 befd5856594efae7898d2cccdf1f2cd6c15007d5f1c3eec3c48a09fad1c691fe
MD5 56c7dffa228dd2bab317cf8be590a233
BLAKE2b-256 6be50e69071722cdd9fadf3dd9b478b5863155a71080b9e5699e1d858cac8fcf

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc4-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.25.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.2rc4-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 bfcea300a795688842e95322a6fee1c4c93ecea8a5ab2f4df761bd312c63f7b0
MD5 2453a1cfef5bba90c64cba9b3376731e
BLAKE2b-256 03e1d6a63d6d859aee40cb8279f2b7e301b458c5c857118a809557fc6bd82857

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