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

Uploaded Source

Built Distributions

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

Uploaded CPython 3.8Windows x86-64

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

Uploaded CPython 3.8macOS 10.14+ x86-64

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

Uploaded CPython 3.7mWindows x86-64

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

Uploaded CPython 3.7mmacOS 10.14+ x86-64

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

Uploaded CPython 3.6mWindows x86-64

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

File metadata

  • Download URL: vpython-7.6.2rc8.tar.gz
  • Upload date:
  • Size: 3.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.4.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for vpython-7.6.2rc8.tar.gz
Algorithm Hash digest
SHA256 91f69578ccb25f1419b090505eb363de0add89de81b99ac9359e505cdb4c8a49
MD5 7d8d1954a05cf07c1430603667ff344f
BLAKE2b-256 5516b4ee0a9ea719ac7c700bffe5148fdc2360561049474078250fda4f51a381

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc8-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.4.1 importlib_metadata/4.4.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for vpython-7.6.2rc8-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 5f35f97e9bcfb1a67f617e60bf1ee519a21f6fa1411291f5a6f1199827771cd0
MD5 da2ddcbcaef03c6c8bf8820d71459e99
BLAKE2b-256 8d3f486cf8a19083965325096e731de6f58a5f87d5d21e12f87993dc449158bb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc8-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.4.1 importlib_metadata/4.4.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for vpython-7.6.2rc8-cp38-cp38-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 981c18764550524bddf23378398ad2b6bccd475f91986a222998d1506132bc2e
MD5 9d71476f00dccc057a7402ef69fa32f3
BLAKE2b-256 146b092470823cfc58615099d8de4eed4470581a4e24b7ad0de7e355cf630fed

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc8-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.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.7.9

File hashes

Hashes for vpython-7.6.2rc8-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 98ec22ab3cc707226fd280d8f94f37199f46c8dd2cbd5d8c1f1d73690ae535ce
MD5 5f535807578dbcb7a53f1b05b1ba4011
BLAKE2b-256 da2fbb1e404243dfce1f75659f794424a26ac7ae232aa86d25dc8ed4e5f9f3a3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc8-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.4.1 importlib_metadata/4.4.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.7.10

File hashes

Hashes for vpython-7.6.2rc8-cp37-cp37m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 f1433c3f432e288b35b3b5dfdc5341019bdc995cee061caf48e8bce29173436f
MD5 1eb41d98f2a1e4d4679e315b1349059f
BLAKE2b-256 19a075c687f5d046f9066d02de2e78e17df92f0b78ac6f6fb759258bb50953f3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc8-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.4.1 importlib_metadata/4.4.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.6.8

File hashes

Hashes for vpython-7.6.2rc8-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 868dec9282c23848d923a0d7f25d1c79e6e905b200fb3d6aa7533a8cd58374f0
MD5 34d3273f49fb10b3e91680053a5f09bc
BLAKE2b-256 d9788e60a38b9d39ed293a001c9c779625256b2dd2033d5f1b1e4ba4f6c15a0c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vpython-7.6.2rc8-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.4.1 importlib_metadata/4.4.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.6.13

File hashes

Hashes for vpython-7.6.2rc8-cp36-cp36m-macosx_10_14_x86_64.whl
Algorithm Hash digest
SHA256 3011a9f9503b5caa0c67ebad5299f33351898f3b454788734a37f3970fcbf10a
MD5 bfb209e234637e0490eace3c1473c3d8
BLAKE2b-256 d694935b017a7b3fd5722a6c0d729cc124528588a6e9efbd132e896b79609146

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