data:image/s3,"s3://crabby-images/a0a34/a0a34cd8ae99193c29799a6dda8bb6eda5049f93" alt="technology_tut_fat"
What to learn?
Embracing the Magic of Bionic Flowers
Welcome to a fascinating adventure with our AI Blossom kit! Here, you’ll merge the artistry of nature with cutting-edge technology. Inspired by the enchanting movements of water lilies and mimosa plants, these AI-Blossoms mimic nature’s response to stimuli, blending the wonders of biology with mechanical precision.
data:image/s3,"s3://crabby-images/0b87f/0b87f082a9e168ef615dc72a7b16b7a77c31ba61" alt="ai-blossom"
Unleash your creativity and programming skills! Whether you’re a beginner or a seasoned coder, our user-friendly Open Roberta Lab and C++ programming options cater to all levels. The kit provides everything needed to bring these flowers to life – control their movements in real-time through a computer interface or a dedicated phone app. Create mesmerizing flower ballets, sync them with music, or trigger actions with incoming messages, all through a simple transmitter. It’s an enthralling experience that combines nature, technology, and art in one!
How It Works
The AI-Blossoms come to life through signals sent by a dedicated transmitter. It is the brains of the operation. It receives instructions either from a computer through a serial protocol or from a phone via Bluetooth.
data:image/s3,"s3://crabby-images/52340/52340a85d48a70ea66893cfc84aede55e4d6c372" alt="image1"
App Controls and Connection
To utilize the application’s diverse control interfaces, such as a remote-like controller,
pose controls, sound and picture recognition, you need to establish a connection
between your phone and the transmitter. Ensure that both Bluetooth and GPS on
your device are turned on before following these steps:
- Press the top-right icon to view available transmitters nearby.
- Click on any transmitter from the list to initiate the connection process
data:image/s3,"s3://crabby-images/ef7d2/ef7d24ad69bd442e747376f5015098476d7dec09" alt=""
The control interfaces share similar icons, each serving a specific function:
data:image/s3,"s3://crabby-images/80739/80739d774e74784840e3099fbec87a8c672d10ed" alt=""
data:image/s3,"s3://crabby-images/68c6e/68c6e3347464523204d9a28f42fe8b1976418894" alt=""
data:image/s3,"s3://crabby-images/831e3/831e32292f3987763d3425bbdb3fd025133155ad" alt=""
data:image/s3,"s3://crabby-images/f9bac/f9bac0aef116efb9418c61cbfb30aeab4cc1f69a" alt=""
data:image/s3,"s3://crabby-images/4e454/4e454bf735428f23f356581b7e5a35dbef91bb8e" alt=""
Python Library
Discover how to command SkySpirit flowers from your computer using our Python
library. This library acts as a link, allowing your computer to communicate with the
transmitter using a serial protocol. Here, you’ll find examples to easily grasp and
utilize the library’s features.
Step 1:
Install VSCode from this link: https://code.visualstudio.com/download
Step 2:
Go to extensions.
data:image/s3,"s3://crabby-images/43534/43534d139879935cdeb284a7433617ace224a0db" alt="vscode_image1"
Step 3:
Find and install the Python extension from Microsoft.
data:image/s3,"s3://crabby-images/4d9f6/4d9f66f9b8ced8e3c3b2adbd22f09c11e64e0a08" alt="vscode_image5"
Step 4:
Restart VSCode
Step 5:
Go to File → Open Folder.
data:image/s3,"s3://crabby-images/f86a7/f86a7ab8880b832b9cda8859ab9cca5ec266fefd" alt="vscode_image3"
Step 6:
Navigate to the SkySpirit library folder and open it.
Step 7:
Make sure that the controller (esp) is plugged into the computer with a
data cable, and flowers are connected to a power source.
Open any of the four example files and click the play button in the top right
corner.
data:image/s3,"s3://crabby-images/f8c1d/f8c1d43ae161fd6c0182c59316478dc64f00de03" alt="vscode_image6"
Custom Sequences
Now that you have VSCode and Python extension installed you can learn to control SkySpirit AI-Blossoms from your computer using our Python library.
This section gives you clear instructions to make the most of the library’s features
Step 1:
Create a new folder named ”your folder name” and copy ”Skyspirit flower controller” into ”your folder name”.
Create a new file named ”main.py”.
Start the file with:
from Skyspirit_flower_controller import Communicator, list_ports
This will include the Communicator class and the list ports function from the local library Skyspirit flower controller.
Step 2:
Create an instance of the Communicator class. On Linux:
communicator = Communicator(’/dev/ttyACM0’)
Or on Windows:
communicator = Communicator('COMI')
Step 3:
It’s recommended to create a Communicator instance using the list_ports function:
communicator = Communicator(list_ports()[0])
Here, 0 means that we are using the first found port. If you have other serial devices connected or want to use two transmitters simultaneously, you might want to change this 0 to another number:
communicator = Communicator(list_ports()[1])
or
communicator = Communicator(list_ports()[2])
Step 4:
The Communicator class has two functions: send_color
and send_move
. Both of them take a Python list of integers as the first argument. For send_color
, the next arguments are RGB values of the desired color (red, green, blue), ranging from 0 to 255.send_move
takes two integer values: the desired position (from 0 to 120) and the desired_speed
in terms of rotations per minute (from 0 to 4500):
communicator.send_color([9, 8, 6], 0 ,0, 255)
communicator.send_move([1, 2, 3], 120, 4000)
This code will set flowers 9, 8, 6 to bright blue color and fully open flowers 1, 2, 3 fast.
Step 5:
To introduce a delay between the execution of different commands, use the Python time library:
import time
For example, if you want the previous code to first change color and then open flowers 3 seconds later, you will write:
communicator.send_color([9, 8, 6], 0, 0, 255)
time.sleep(3)
communicator.send_move([1, 2, 3], 120, 4000)
Step 6:
Don’t forget to turn off lights and to close the flower at the end of your sequence:
communicator.send_color(list(range(1, 17)), 0, 0, 0)
communicator.send_move(list(range(1, 17)), 0, 500)
This code will turn off the light for all flowers from number 1 to 16 and close them slowly.
The full code will look something like this:
from Skyspirit_flower_controller import Communicator, list_ports
import time
communicator = Communicator(list_ports()[0])
communicator.send_color([9, 8, 6], 0, 0, 255)
time.sleep(3)
communicator.send_move([1, 2, 3], 120, 4000)
time.sleep(5)
communicator.send_color(list(range(1, 17)), 0, 0, 0)
communicator.send_move(list(range(1, 17)), 0, 500)
Step 7:
To run this code, choose File → Save, then click the play button in the top right
corner.
data:image/s3,"s3://crabby-images/3fff4/3fff48d23d3cb479c9997bfe578cd2be044227ad" alt="vscode_image7"
Flashing Code
If, for any reason, you need to reinstall the original code on your flowers or transmitters, follow these instructions:
Step 1:
Install VSCode from this link: https://code.visualstudio.com/download.
Step 2:
Go to extensions.
data:image/s3,"s3://crabby-images/43534/43534d139879935cdeb284a7433617ace224a0db" alt=""
Step 3:
Find and install the PlatformIO extension.
data:image/s3,"s3://crabby-images/2c6ed/2c6ed2090488620e4ea2fc5d7468529245c9b547" alt="vscode_image2"
Step 4:
Restart VSCode.
Step 5:
Go to File → Open Folder.
data:image/s3,"s3://crabby-images/f86a7/f86a7ab8880b832b9cda8859ab9cca5ec266fefd" alt=""
Step 6:
Navigate to controller_flash or flower_flash folder and open it.
Step 7:
Connect the ESP to the computer via a data cable.
Step 8:
Open the PlatformIO extension, go to esp32dev for flower_flash or to
adafruit_qtpy_esp32c3 for controller_flash. Choose Custom and click ”Upload prebuilt code”.
data:image/s3,"s3://crabby-images/68f86/68f8632f410e8638ba0a3fda04bc5eb0f31bdb4e" alt="vscode_image4"