Skip to main content

library to implement the Myro API with the Sparki robot

Project description

This project implements libraries for the Sparki robot http://arcbotics.com/products/sparki/ to work through Python over a Bluetooth connection. It is intended to help educators who are teaching using the Sparki and/or Python.

Conceptually, the library which is loaded on the robot is simply an interpreter for commands the Sparki receives over its Serial1 (Bluetooth) port. You could implement a complementary library on any platform that you like to send the commands. In this case, I have implemented a library in Python which makes use of the pyserial library to send those commands. The library on the Sparki does not implement all the commands available on the Sparki. Specifically, there are several LCD commands which I have been unable to fit into the Sparki's memory. As of version 1.1.2 of the Sparki library, it consumes 27,606 bytes of the 28,672 bytes available on the little robot. Perhaps programmers more skilled than I can fit more on there.

The Python part of the library implements much of the IPRE (Institute for Personal Robotics in Education http://www.roboteducation.org/) Myro API (API reference at http://calicoproject.org/Calico_Myro). This API was originally chosen because the original author of this project taught (or teaches, depending on when you read this) a class making use of that program. A free textbook exists to teach that program may be found at http://calicoproject.org/Learning_Computing_With_Robots_Using_Calico_Python. The Python library here does not implement all of that library -- in particular, anything having to do with the camera cannot be implemented on Sparki because Sparki does not have that hardware.

To make use of this library with your Sparki:

  1. Download the latest version of Sparkiduino from Arcbotics: http://arcbotics.com/products/sparki/start/
  2. Make a copy (through git clone or otherwise) on your computer of the sparki_myro.ino file -- it has to be in its own directory called sparki_myro
  3. Load the sparki_myro.ino file in Sparkiduino and upload it to your Sparki (see http://arcbotics.com/lessons/how-to-upload-sparki-code/ for directions)
  4. You're done! At least, you're done with the part that concerns your Sparki. The library on its own won't do much unless you've got a way to talk to it.

To talk to the library using Python:

  1. Pair your Sparki with your computer over Bluetooth.
  2. Download a version of Python 3 -- this was originally developed on Python 3.4, and on subsequent versions of Python 3 (currently tested up to 3.8). The author believes any version of Python 3 will work https://www.python.org/downloads/. In my classroom, we use the Thonny IDE available from https://thonny.org/.
  3. Use pypi, easy_install or pip to install the library (e.g. 'pip install sparki-learning'). It should download everything for you automagically. If you're using Thonny, you can go to Tools -> Manage Packages to download the library. The sparki_learning library presently depends on pyserial (https://pyserial.readthedocs.io/en/latest/pyserial.html) and pysimplegui (https://pysimplegui.readthedocs.io/en/latest/), which should be installed automatically.
  4. Use the sparki_learning library to control your Sparki!

All of the software in this project that I've written is provided under the Apache version 2 license available at http://www.apache.org/licenses/LICENSE-2.0 and is WITHOUT WARRANTY, including implied warranties. I have also included a couple of sample / test programs for you to look at in python to get a feel for how to use the library.

The implementation of the Bresenham line algorithm was adapted from https://github.com/encukou/bresenham, and is provided under the MIT license.

Both libraries were written with the intention of being helpful to students and educators, and are fairly well commented. I have tested them some, but they may not work on all platforms for all people. There may be bugs. There may be problems that cause the destruction of your Sparki (though I don't think there are). You assume all risk in your use of this software.

Finally, I have included an increasingly long "Quick Reference" sheet that documents the libraries. It's also available online at https://sparki-learning.readthedocs.io/en/latest/

If you'd like to support my work, my bitcoin address is bc1q3jndk44fzhtg0m0z95933flm6fhw239yuvwvqd / dogecoin is D6R66NfzPkB2SvjCnjh3vZNz2PVnRkfRnj

Sparki is an excellent little robot, and I hope this proves useful to you in exploring the world. Good luck!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sparki_learning-1.6.9.tar.gz (34.9 kB view hashes)

Uploaded Source

Built Distribution

sparki_learning-1.6.9-py3-none-any.whl (37.5 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page