Automatic generation of high-level interfaces to collect robot sensor data using the R4A platform
In software engineering, the term automatic programming describes a mechanism that creates a program which in turn allows scientists to code at a higher level of abstraction. Nowadays, robot applications, both in business and home environments are gaining traction, increasing the need for automatic software generation without errors. It is well known that robots are equipped with multitude of sensors, which play a key role in their operation and in accomplishing certain tasks. For this reason, it is often necessary to control the produced data, in order to build software systems. This diploma thesis aspires to take the first steps towards the process of automating the development of ready-to-run interfaces to collect robot sensor data.
Towards this direction, MDE (Model Driven Engineering) is employed. More specifically, once a subtractive model has been defined, a series of transformations takes place, resulting in a fully functional system. This way, the software development process is accelerated and software is produced with greater reliability.
Within the context of this diploma thesis, we have designed and implemented CoRSeDA (Collecting Robot Sensor Data Automatically), a system where the user interacts through a friendly graphical user interface and defines the features for the desired sensors of a robot. Based on the sensors and their parameters, the system generates automatically executable code, based on the R4A platform, to collect data from the specific robot. At the same time, a fully functional interface is generated providing information for the whole system. The data of the system and its sensors are displayed, along with any other information generated, in a web application created for that purpose.
To test and evaluate this system, experiments were performed on the robot NAO, an autonomous, programmable humanoid robot developed by Aldebaran Robotics.
After research and multiple iterations I concluded to the below meta model to represent all concepts in this particular project.
The image below represents a system of eight sensors as designed by a user. The sensors are seperated based on their category and their attributes are already defined.
Based on my model and its implementation the above system generates automatically the following list of APIs once the model is valid.
Once the APIs are generated, they can be used in order to show the collected data in the web application that was designed for this reason.
This is an instance of the web application while collecting data from robot microphones. This is an instance of the web application while collecting data from pressure sensors.
pip install -r requirements.txt
Download Eclipse Modeling Tools here: http://www.eclipse.org/downloads/packages/eclipse-modeling-tools/oxygen1a (newer versions work fine, checked 12/3/20)
Following the Help->Install New Software, choose as a repository the version where you downloaded eclipse and enter 'ATL or Atlas Transformation Language' in the search bar. Then again, following the Help->Install New Software, choose as a repository the version where you downloaded eclipse and enter 'Acceleo' in the search bar. Your setup for Eclipse Modeling Tools is now ready to go.
-
Import as project file the two folders SensorProject, SensorProjectGenerator and SensorProjectGenerator.ui
-
Double click on SensorProject, in the model file right click on sensorProject.genmodel and select GenerateAll
-
Open a new run-time and import as project files the tow folders MySensorSystem and SensorProject.odesing
-
Open the represantations.aird of the MySensorSystem and start designing your system
-
If you have a valid system the right click on MySensorSystem.sensorproject of the MySensorSystem and select "Acceleo Model To Text->Generate Code"
Attention: In order to work locally you must change the path where images and audios will be saved!
Open the AcousticSystemBase.mtl and change the path in line 70 to the path where you have extracted the ...."mythesis-app/public/audios/"
Change also the VisionSystemBase.mtl and chance the path in line 65 to the path where you have extracted the ...."mythesis-app/public/images/"
__________ ___. __ .__ _____ _____ .__ .__
\______ \ ____\_ |__ _____/ |_|__| ____ ______ / | | / _ \ | | | |
| _// _ \| __ \ / _ \ __\ |/ ___\ / ___/ / | |_ / /_\ \| | | |
| | ( <_> ) \_\ ( <_> ) | | \ \___ \___ \ / ^ / / | \ |_| |__
|____|_ /\____/|___ /\____/|__| |__|\___ >____ > \____ | \____|__ /____/____/
\/ \/ \/ \/ |__| \/
R4A Platform @ Aristotle University of Thessaloniki https://github.com/robotics-4-all/r4a-framework
Attention:To run CoRSeDA you must first setup the R4A platform at the same network with the robot NAO.
-
open terminal
-
cd /r4a-framework/
-
source setup.sh
-
r4a-core-init nao
To run the generated code
-
open terminal
-
python main.py (of the files generated)
To run the generated API and the web application
-
open terminal
-
activate the virtual environment 'thesisenv'
-
run the flask app
-
run the react app