Smartibot
The world’s first Artificial Intelligence enabled cardboard robot that you build yourself.
Smartibot works with your smartphone, meaning you can use your mobile as a remote control, or by attaching it to your robot, as it’s brain.
Firmware binaries can be found in:
- the Download page - either from the list of firmwares, or a downloadable ZIP.
- the binaries folder (current version)
- the automatic Travis Builds (cutting edge builds)
To update your firmware, follow the instructions below
Contents
Using
Smartibot can be used like any other Espruino Bluetooth LE device, with full access to the NRF class for BLE Functionality.
Check out the Getting Started Guide.
Buttons
There are two built-in variables for buttons, BTN1
(Button A) and BTN2
(Button B).
These can be read using BTN1.read()
or digitalRead(BTN1)
(the two commands
are identical), or you can be notified when a button changes state:
setWatch(function(e) {
if (e.state) print("Button pressed");
else print("Button released");
}, BTN1, {repeat:true, edge:"both"});
The code above will call the function when the button is pressed and
when it is released. You can remove edge:"both"
completely or use edge:"rising"
to be notified only when the button is pressed, or cal use edge:"falling"
to
be notified only when it is released.
NOTE: On the Smartibot build that ships with KickStarter devices,
the value from BTN1.read()
is inverted (true
when released, false
when pressed).
Motors
There are 4 motor outputs which can be controlled using require("Smartibot").setMotor(motor, value)
.
value
is a number between -1
(full reverse) and 1
(full forward).
var smarti = require("Smartibot");
smarti.setMotor(2, 1); // run motor 2 forward at full speed
smarti.setMotor(1, -0.5); // run motor 1 in reverse at half speed
LEDs
There is one blue LED controllable using LED.write(..)
, however
the left and right 'eyes' must be controlled using the require("Smartibot").setLEDs(left, right)
command:
var smarti = require("Smartibot");
// Set left LED to RED, right LED to GREEN
smarti.setLEDs([255,0,0], [0,255,0]);
NOTE: On the Smartibot build that ships with KickStarter devices,
the single blue LED is inverted (true
for off, false
for on).
Servo outputs
To control servos, use the require("Smartibot").setServo(servo, value)
.
value
is a number between 0
and 100
.
var smarti = require("Smartibot");
smarti.setServo(1, 50); // Set servo 1 to midpoint
Display board
Plug the display into E1
. Calling g = require("Smartibot-display").connect(smarti.E1)
will return an instance of Graphics which you can then use. It is 16 pixels wide, 9 pixels high, and 8 bits per pixel.
When you need to display something, call g.flip()
to send it to the screen:
var smarti = require("Smartibot");
var g = require("Smartibot-display").connect(smarti.E1);
// Clear the screen
g.clear();
g.setColor(127); // set brightness - 0..255
// Draw something!
g.drawRect(0,0,15,8);
g.drawString("Hi",2,2);
// Send what we drew to the screen
g.flip();
Check out Graphics for full details on how to use Graphics and add your own images.
Distance board
Plug the board into E1
. Calling require("Smartibot-distance").connect(smarti.E1);
returns an object with the following entries:
dist.getLeft()
returns the distance from the left sensor in millimetersdist.getRight()
returns the distance from the left sensor in millimetersdist.getGesture()
returns"left"
/"right"
/"up"
/"down"
is a gesture was found, orundefined
if not.dist.gesture
is an instance of APDS9960 for direct access to the gesture sensordist.left
/dist.right
are instances of VL53L0X for direct access to the laser sensors
var smarti = require("Smartibot");
var dist = require("Smartibot-distance").connect(smarti.E1);
setInterval(function() {
// try and avoid obstacles if less than 10cm away
if (dist.getLeft() < 100) smarti.setMotor(1,0);
else smarti.setMotor(1,1);
if (dist.getRight() < 100) smarti.setMotor(2,0);
else smarti.setMotor(2,1);
// if a gesture was found, output what it was
var gesture = dist.getGesture();
if (gesture) console.log(gesture);
}, 100);
Reference
// Set LEDs - expects two 3-element arrays with each elemnt between 0 and 255 : [R,G,B], [R,G,B]
exports.setLEDs = function (l, r) { ... }
// Set motors 1..4 with a value between -1 and 1
exports.setMotor = function (M, S) { ... }
// Set servos 1..10 with a value 0..100
exports.setServo = function (num, val) { ... }
Tutorials
First, it's best to check out the Getting Started Guide
Tutorials using just Bluetooth LE:
data:image/s3,"s3://crabby-images/73f76/73f761026b1906216d3f44ce68c04dcbdeda45cb" alt="Pixl.js Bluetooth to Ethernet MQTT Bridge Pixl.js Bluetooth to Ethernet MQTT Bridge"
data:image/s3,"s3://crabby-images/be735/be7354f931ea4a72f540449b07aa801e69159c82" alt="BTHome Library BTHome Library"
data:image/s3,"s3://crabby-images/ad9b5/ad9b51975484e12f1719389153c7af7a6476e816" alt="Bluetooth LE Printers Bluetooth LE Printers"
data:image/s3,"s3://crabby-images/b6881/b688124e4d68d9e837b7174d0f67dd674715b29e" alt="Bluetooth LE Emoji Advertising Bluetooth LE Emoji Advertising"
data:image/s3,"s3://crabby-images/38f27/38f27096a4b20d7938fa2e07c6767afd69a1e51e" alt="Battery Monitor Battery Monitor"
data:image/s3,"s3://crabby-images/31616/31616e536dfc1d03311dfc2fa68d0fcabf95950e" alt="LEGO Power Functions Clone Remote Control (Mould King M-0006 / Kaiyu / Bandra / AKOGD / MayD / etc) LEGO Power Functions Clone Remote Control (Mould King M-0006 / Kaiyu / Bandra / AKOGD / MayD / etc)"
data:image/s3,"s3://crabby-images/4a69b/4a69b1bd38acee5d5fc4f57f6c3a1cf7cd746725" alt="Tilt Hydrometer Repeater Tilt Hydrometer Repeater"
data:image/s3,"s3://crabby-images/4b7cb/4b7cb58e13660f16a93cfc2eb6bc9d9b924f9a67" alt="Quick Start (Bluetooth LE) Quick Start (Bluetooth LE)"
data:image/s3,"s3://crabby-images/9eed1/9eed17234faa8fcda6325eba55773d9baa73d8a8" alt="BLE Advertising with Node.js/Python/C#/Android BLE Advertising with Node.js/Python/C#/Android"
data:image/s3,"s3://crabby-images/c939c/c939ccf1a29f6a110f769389082343a9598b4824" alt="Automatic Data Download Automatic Data Download"
data:image/s3,"s3://crabby-images/130f9/130f9bc6e11c22806cd5a6b5df89aeb5143da6b7" alt="Puck.js to GCP BigQuery & Data Studio Puck.js to GCP BigQuery & Data Studio"
data:image/s3,"s3://crabby-images/ffa61/ffa61ca491e96a273eb2b198cfbe4a52ddba6a71" alt="Stream from Puck.js to AWS IOT Core & SNS Email Stream from Puck.js to AWS IOT Core & SNS Email"
data:image/s3,"s3://crabby-images/e9c5b/e9c5b127cd966b62cd86abbd4a851550954d5410" alt="Bluetooth LE UARTs (NUS) Bluetooth LE UARTs (NUS)"
data:image/s3,"s3://crabby-images/b3109/b31091bc500507fef8f127b5f66db049bfa44d89" alt="Bluetooth LE HID Keyboards Bluetooth LE HID Keyboards"
data:image/s3,"s3://crabby-images/32ed5/32ed54b945d81b5d31309062ae03558a97cedb31" alt="Bluetooth LE Security and Access Control Bluetooth LE Security and Access Control"
data:image/s3,"s3://crabby-images/1f0c3/1f0c34755589101ad02517227b221c0630d7910b" alt="Bluetooth LE MIDI Bluetooth LE MIDI"
data:image/s3,"s3://crabby-images/82f80/82f80f7d72cf1bf9af341d03daff9952ffb50953" alt="Web Bluetooth on Linux Web Bluetooth on Linux"
data:image/s3,"s3://crabby-images/6a9c3/6a9c3fbb1d8f116762786eff85b8d50d7e312331" alt="Bluetooth Time Setter Bluetooth Time Setter"
data:image/s3,"s3://crabby-images/14fa7/14fa7022457705b335118d7789ac58d99e7c8d00" alt="Using Web Bluetooth with Espruino Using Web Bluetooth with Espruino"
data:image/s3,"s3://crabby-images/b1c8d/b1c8d745152cdf49f58f27b2ab67991709c1172b" alt="Bluetooth LE and If This Then That Bluetooth LE and If This Then That"
data:image/s3,"s3://crabby-images/702cf/702cf6d9dd2bdf07de792fe909493d18ef554c06" alt="UART.js Library UART.js Library"
data:image/s3,"s3://crabby-images/70834/7083425cc7604ea1386a856079e0b4e89bdda1cf" alt="iBeacons iBeacons"
data:image/s3,"s3://crabby-images/123de/123de4ed36ea6fb777ca2d49b7b5fd54f58ff276" alt="Eddystone Beacons Eddystone Beacons"
data:image/s3,"s3://crabby-images/ed17c/ed17cd478a971f049e00f7e386b67192f87e7c5f" alt="Bluetooth LE and Node-RED with MQTT Bluetooth LE and Node-RED with MQTT"
data:image/s3,"s3://crabby-images/d13f3/d13f3a1d8e1cc3bec2bbe9ed4a5fe78a382db420" alt="Bluetooth Music Controller Bluetooth Music Controller"
data:image/s3,"s3://crabby-images/8c4ef/8c4efd69e25a4a44f01ba50df50bbc3f8ca7c8eb" alt="Controlling Bluetooth Lights with Puck.js Controlling Bluetooth Lights with Puck.js"
data:image/s3,"s3://crabby-images/0bbcd/0bbcd520593eaee0126a360086c237a7a839bdc2" alt="Bluetooth LE HTTP Proxies Bluetooth LE HTTP Proxies"
data:image/s3,"s3://crabby-images/3f598/3f59837ab4187e9afdd38affcd02345807f8b8a1" alt="Exercise Machine controlled Video Exercise Machine controlled Video"
data:image/s3,"s3://crabby-images/a7b75/a7b75f2c534c59c3c7d87590fd8a92791d826d3a" alt="BLE Communications BLE Communications"
data:image/s3,"s3://crabby-images/8857d/8857d53279cfc8ac2b23b6d2330e7c1d937123ba" alt="About Bluetooth LE (BLE) About Bluetooth LE (BLE)"
data:image/s3,"s3://crabby-images/ab207/ab2077fa1eda376303b20826160caac540fdf08f" alt="Puck.js with SMS control Puck.js with SMS control"
data:image/s3,"s3://crabby-images/15082/15082da1a940849126ed736eb39b87e922b0233b" alt="Pixl.js SMS Remote Monitoring Pixl.js SMS Remote Monitoring"
data:image/s3,"s3://crabby-images/92066/92066ae2ad8e26bfa0c6ac889f85548f7a187486" alt="Web IDE on a Raspberry Pi Web IDE on a Raspberry Pi"
data:image/s3,"s3://crabby-images/25280/25280beb7c2a28141b939f60f2f3eac842c60073" alt="Puck.js Bluetooth with the Graphical Editor Puck.js Bluetooth with the Graphical Editor"
data:image/s3,"s3://crabby-images/16e70/16e706af87fa98a5fc4a3f3469b0142468dcbc0f" alt="Controlling Other BLE Espruino Devices Controlling Other BLE Espruino Devices"
data:image/s3,"s3://crabby-images/4198e/4198e500ffff17897db2dafddc3c53a95b8dbeac" alt="Pixl.js Simple Logger Pixl.js Simple Logger"
data:image/s3,"s3://crabby-images/4d294/4d294c77f3047b04bfb18a4df7bd2d601ad0273f" alt="Pixl.js Multiplayer Pong Game Pixl.js Multiplayer Pong Game"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="BLE Characteristic Scan BLE Characteristic Scan"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="LED BLE Library LED BLE Library"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Bluefruit LE app interface Bluefruit LE app interface"
Tutorials using Bluetooth LE and functionality that may not be part of Smartibot:
data:image/s3,"s3://crabby-images/1f326/1f326f23d21745966b6c1dca5a2a388a92be93f3" alt="Water Level Monitor Water Level Monitor"
data:image/s3,"s3://crabby-images/52d33/52d330238e1949f00872f1ae50a863f356a28fb6" alt="Puck.js Vibration Sensor Puck.js Vibration Sensor"
data:image/s3,"s3://crabby-images/8e199/8e199c99e52f6eb79fe50e2caf891c297f0dcec5" alt="DIY Smart Meter DIY Smart Meter"
data:image/s3,"s3://crabby-images/52a2f/52a2fd04362887edb0908092e887315b97788bd9" alt="BTHome Door Sensor for Home Assistant BTHome Door Sensor for Home Assistant"
data:image/s3,"s3://crabby-images/d642e/d642e612ddc640c18acd2d53f644f39a778ae497" alt="BTHome and Home Assistant Setup BTHome and Home Assistant Setup"
data:image/s3,"s3://crabby-images/c6255/c6255f0627dc83c3b710a16bc61a7d5ccaf46cc5" alt="Pixl.js Wireless Temperature Display Pixl.js Wireless Temperature Display"
data:image/s3,"s3://crabby-images/42287/42287f76b5e839f35f21bd6465b87b1aad3ce0ea" alt="Turning an Espruino Puck.js Into a Universal Presentation Clicker Turning an Espruino Puck.js Into a Universal Presentation Clicker"
data:image/s3,"s3://crabby-images/f07aa/f07aaf7eabbbdc5db2dc436e3c1f312a0abe3e2f" alt="Interfacing to a PC Interfacing to a PC"
data:image/s3,"s3://crabby-images/8ebd9/8ebd9d74a417abb5f8abaa4d29292870bd8f53db" alt="Controlling Espruino from Tensorflow on the Desktop Controlling Espruino from Tensorflow on the Desktop"
data:image/s3,"s3://crabby-images/c5dfa/c5dfaba8d897ea980c038ae307501ebcfa13730a" alt="Bookmarklets with Web Bluetooth Bookmarklets with Web Bluetooth"
data:image/s3,"s3://crabby-images/04bca/04bca813336c121b9218b113dab5c5349ed35289" alt="Bangle.js Data Streaming Bangle.js Data Streaming"
data:image/s3,"s3://crabby-images/3223e/3223e2be616ccf7a07e2203725613cd7909a705c" alt="Puckmote - Universal Remote Control Puckmote - Universal Remote Control"
data:image/s3,"s3://crabby-images/87238/872380342575fad5d3cd7ff8a9044e1db9ae6564" alt="IoT for Kitchen Gardens IoT for Kitchen Gardens"
data:image/s3,"s3://crabby-images/c97ad/c97ad8e935c661adf39a2b01cb17ce9abcb800cb" alt="Time Machine Retro-Inspired Smartwatch Time Machine Retro-Inspired Smartwatch"
data:image/s3,"s3://crabby-images/7ba05/7ba0521117ab56bc97b56a10767a20e48b1140c6" alt="Talos, Keeping You Safe During Your Commute Talos, Keeping You Safe During Your Commute"
data:image/s3,"s3://crabby-images/3a9ed/3a9edcaabb7eac32370db1a35aa5ca1c1a3f9df9" alt="Bluetooth Energy Usage Monitor Bluetooth Energy Usage Monitor"
data:image/s3,"s3://crabby-images/03d3f/03d3f942e46cdc7b6fa892347ebe647803475375" alt="Electric Skateboard Controller Electric Skateboard Controller"
data:image/s3,"s3://crabby-images/f8d95/f8d9533b507efe3615ce5249d1927c2552ff7d9a" alt="Wooden Bluetooth Remote for Lego Duplo Train Wooden Bluetooth Remote for Lego Duplo Train"
data:image/s3,"s3://crabby-images/e185e/e185ef9220dbe537318d2a6ff7fd24c66e6cd715" alt="Puck.js Control from Android using DroidScript Puck.js Control from Android using DroidScript"
data:image/s3,"s3://crabby-images/3daf5/3daf5f902581b6df051b907914ee1dff9e55b474" alt="Ikea Eneby Speaker Controller Ikea Eneby Speaker Controller"
data:image/s3,"s3://crabby-images/e8df4/e8df47287aecb79c64afe8a96ab2b143ce0e6997" alt="Pixl.js Wireless Weather Station Pixl.js Wireless Weather Station"
data:image/s3,"s3://crabby-images/f401b/f401b1a51e56ab99c1a95ce00027630016fc55fd" alt="Temperature Controlled Night Light with Puck.js Temperature Controlled Night Light with Puck.js"
data:image/s3,"s3://crabby-images/14f18/14f1891c721d9bdc0590ba3e3f9b0b1637f97d9b" alt="Infrared Record and Playback with Puck.js Infrared Record and Playback with Puck.js"
data:image/s3,"s3://crabby-images/4c111/4c11195d7157b8b816b38d513b192c402042fcee" alt="Door Controlled Light with Puck.js Door Controlled Light with Puck.js"
data:image/s3,"s3://crabby-images/126e7/126e7b21cc09a46698a12e3875bf7aecb2399b82" alt="Freezer Alarm Freezer Alarm"
Firmware Updates
For this you'll need an Android or Apple phone or tablet.
- Power on your Smartibot, while holding down Button A
- Release Button A less than 2 seconds after power on
- Follow the Puck.js instructions for updating firmware using the NRF Connect app on your phone (download the
smartibot
firmware file, not thepuckjs
one).
This page is auto-generated from GitHub. If you see any mistakes or have suggestions, please let us know.