Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[smart_device_protocol] add smart_devicE_protocol packages #503

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
54 changes: 54 additions & 0 deletions smart_device_protocol/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
devel/
logs/
build/
bin/
lib/
msg_gen/
srv_gen/
msg/*Action.msg
msg/*ActionFeedback.msg
msg/*ActionGoal.msg
msg/*ActionResult.msg
msg/*Feedback.msg
msg/*Goal.msg
msg/*Result.msg
msg/_*.py
build_isolated/
devel_isolated/

# Generated by dynamic reconfigure
*.cfgc
/cfg/cpp/
/cfg/*.py

# Ignore generated docs
*.dox
*.wikidoc

# eclipse stuff
.project
.cproject

# qcreator stuff
CMakeLists.txt.user

srv/_*.py
*.pcd
*.pyc
qtcreator-*
*.user

/planning/cfg
/planning/docs
/planning/src

*~

# Emacs
.#*

# Catkin custom files
CATKIN_IGNORE

#
*.vscode
47 changes: 47 additions & 0 deletions smart_device_protocol/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
cmake_minimum_required(VERSION 2.8.3)
project(smart_device_protocol)

find_package(catkin REQUIRED COMPONENTS message_generation catkin_virtualenv std_msgs)

catkin_generate_virtualenv(
PYTHON_INTERPRETER python3
CHECK_VENV FALSE
USE_SYSTEM_PACKAGES FALSE
ISOLATE_REQUIREMENTS TRUE
)

catkin_python_setup()

add_message_files(
FILES
Packet.msg
UWBDistance.msg
)

generate_messages(
DEPENDENCIES
std_msgs
)

catkin_package(
CATKIN_DEPENDS message_runtime
)

file(GLOB ${PROJECT_NAME}_node_scripts ${PROJECT_SOURCE_DIR}/node_scripts/*)

catkin_install_python(
PROGRAMS ${${PROJECT_NAME}_node_scripts}
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
)

if (CATKIN_ENABLE_TESTING)
find_package(rostest REQUIRED)

file(GLOB ${PROJECT_NAME}_test_node_scripts ${PROJECT_SOURCE_DIR}/tests/*.py)
catkin_install_python(
PROGRAMS ${${PROJECT_NAME}_test_node_scripts}
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
)

add_rostest(tests/sdp_v2_interface_rostest.test)
endif()
28 changes: 28 additions & 0 deletions smart_device_protocol/LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
BSD 3-Clause License

Copyright (c) 2023, Koki Shinjo

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.

2. Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.

3. Neither the name of the copyright holder nor the names of its
contributors may be used to endorse or promote products derived from
this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
196 changes: 196 additions & 0 deletions smart_device_protocol/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,196 @@
<p align="center">
<img src="./docs/sdp_logo_v1.png" width="300px" />
</p>

<div align="center">

[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Black formatting](https://github.com/sktometometo/smart_device_protocol/actions/workflows/python_black.yml/badge.svg)](https://github.com/sktometometo/smart_device_protocol/actions/workflows/python_black.yml)
[![ROS build workflow](https://github.com/sktometometo/smart_device_protocol/actions/workflows/catkin_build.yml/badge.svg)](https://github.com/sktometometo/smart_device_protocol/actions/workflows/catkin_build.yml)
[![PlatformIO Build Workflow](https://github.com/sktometometo/smart_device_protocol/actions/workflows/platformio.yml/badge.svg)](https://github.com/sktometometo/smart_device_protocol/actions/workflows/platformio.yml)

</div>

# smart_device_protocol

The Smart Device Protocol (SDP) Repository.

## What is this?

Smart Device Protocol (SDP) is a protocol to communicate between smart devices, wearable devices, and robots.
SDP is based on [ESP-NOW](https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-reference/network/esp_now.html) protocol, which is a protocol to communicate between ESP32 devices.

This package provides firmwares and ROS nodes to communicate with ESP32 devices via Smart Device Protocol.

For more details of Smart Device Protocol, please see [Smart Device Protocol Document](./docs/sdp.md)

## How to use

### 0. Prerequisites

This code is developed under environment below. Other environment is not tested.

- Ubuntu 20.04
- ROS Noetic
- Python 3.8

And you have to install `platformio` pip package to your environment.

```bash
pip3 install platformio
```

### 1. Build ROS package

First, clone this repository to your catkin workspace and build it.

```bash
cd ~/catkin_ws/src
git clone https://github.com/sktometometo/smart_device_protocol.git
cd ..
catkin build
```

### 2. Make Smart Device Protocol interface device

Second, you have to make an ESP32 device which is connected to your PC via USB.
This device will be the interface to Smart Device Protocol communication of your PC.
Basically, you can use any ESP32 device, but this package is tested with M5Stack-Fire, M5Stack-Core2, and M5Atom-S3.

We will use [smart_device_protocol_interface](./sketchbooks/smart_device_protocol_interface) project.
This code is developed with [PlatformIO](https://platformio.org/). So you can build and burn firmware with it.

You can execute `pio` command.

```bash
~ $ pio
Usage: pio [OPTIONS] COMMAND [ARGS]...

Options:
--version Show the version and exit.
-c, --caller TEXT Caller ID (service)
--no-ansi Do not print ANSI control characters
-h, --help Show this message and exit.

Commands:
access Manage resource access
account Manage PlatformIO account
boards Board Explorer
check Static Code Analysis
ci Continuous Integration
debug Unified Debugger
device Device manager & Serial/Socket monitor
home GUI to manage PlatformIO
org Manage organizations
pkg Unified Package Manager
project Project Manager
remote Remote Development
run Run project targets (build, upload, clean, etc.)
settings Manage system settings
system Miscellaneous system commands
team Manage organization teams
test Unit Testing
upgrade Upgrade PlatformIO Core to the latest version
```

Then, connect M5Stack-Core2 to your PC. You can check which port is connected to it by

```bash
~ $ pio device list
/dev/ttyACM0
------------
Hardware ID: USB VID:PID=1A86:55D4 SER=54BB013663 LOCATION=7-1:1.0
Description: USB Single Serial
```

So let's build firmware and burn it to M5Stack-Core2

```bash
roscd smart_device_protocol/sketchbooks/smart_device_protocol_interface/
pio run -e m5stack-core2 --target upload --upload-port /dev/ttyACM0
```

### 3. Make an example of Smart Device Protocol device

In this tutorial, you will see your PC can communicate with ESP32 device via Smart Device Protocol. So you have to make another ESP32 Smart Device Protocol device.
We will use [sdp_example](./sketchbooks/sdp_example/).

Connect M5Stack-Fire to your PC and burn firmware to it.

```bash
roscd smart_device_protocol/sketchbooks/sdp_example/
pio run -e m5stack-fire --target upload --upload-port /dev/ttyACM0
```

### 4. Run Smart Device Protocol Interface Device

After step 2, you can run Smart Device Protocol interface node.

```bash
roslaunch smart_device_protocol demo.launch port:=/dev/ttyACM0
```

with this, you can see topics below.

```bash
$ rostopic list
/diagnostics
/smart_device_protocol/recv
/smart_device_protocol/send
/rosout
/rosout_agg
```

You can send a ESP-NOW (which is the bottom of Smart Device Protocol) packet directly by sending ROS a message to `/smart_device_protocol/send` topic.

```bash
rostopic pub -1 /smart_device_protocol/send smart_device_protocol/Packet "mac_address: [255, 255, 255, 255, 255, 255]
data: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]"
```

### 5. Run a ROS Node with Smart Device Protocol Interface

Now you can communicate with smart devices, wearable devices, and robots via Smart Device Protocol.
You can run an example of Smart Device Protocol Interface node.

```bash
rosrun smart_device_protocol sdp_v2_packet_printer.py
```

With this command, you can see Smart Device Protocol packets from other devices.

```bash
TODO
```

You can also send Smart Device Protocol packets to other devices.

```bash
TODO
```

## API for Smart Device Protocol

### Python API (for ROS Node)

You can use Smart Device Protocol API in Python for ROS Node. Please see [this document](./docs/python.md) for more details.

### C++ API (for Arduino)

You can use Smart Device Protocol API in C++ for Arduino. Please see (this document)[./arduino_lib/README.md] for more details.

## Examples of Smart Device Protocol Interface Device

There are some examples of Smart Device Protocol Interface Device. For more details, please see [this directory](./sketchbooks/).

## Notices

### Update of ros_lib for Arduino

If you update ros_lib for Arduino, you have to update `ros_lib` directory in [this directory](./ros_lib/).

```bash
cd ~/catkin_ws/src/smart_device_protocol/ros_lib
rm -rf ros_lib
rosrun rosserial_arduino make_libraries.py .
```
58 changes: 58 additions & 0 deletions smart_device_protocol/arduino_lib/ArduinoAtomS3Hardware.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#include <Arduino.h> // Arduino 1.0

#define SERIAL_CLASS HWCDC

class ArduinoHardware
{
public:
ArduinoHardware(SERIAL_CLASS* io, long baud = 57600)
{
iostream = io;
baud_ = baud;
}
ArduinoHardware()
{
iostream = &Serial;
baud_ = 57600;
}
ArduinoHardware(ArduinoHardware& h)
{
this->iostream = h.iostream;
this->baud_ = h.baud_;
}

void setBaud(long baud)
{
this->baud_ = baud;
}

int getBaud()
{
return baud_;
}

void init()
{
iostream->begin(baud_);
}

int read()
{
return iostream->read();
};
void write(uint8_t* data, int length)
{
for (int i = 0; i < length; i++)
iostream->write(data[i]);
}

unsigned long time()
{
return millis();
}

protected:
SERIAL_CLASS* iostream;
long baud_;
};

9 changes: 9 additions & 0 deletions smart_device_protocol/arduino_lib/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
# C++ API for Smart Device Protocol

## Overview

This is a C++ API for Smart Device Protocol.

## How to use

TBD
Loading
Loading