diff --git a/docs/Cloud_Chain/SenseCraft/SenseCraft_AI/Output/xiao_esp32s3_sense/sensecraft_xiao_esp32s3_mqtt.md b/docs/Cloud_Chain/SenseCraft/SenseCraft_AI/Output/xiao_esp32s3_sense/sensecraft_xiao_esp32s3_mqtt.md index faf3ef475faa..19fc60895771 100644 --- a/docs/Cloud_Chain/SenseCraft/SenseCraft_AI/Output/xiao_esp32s3_sense/sensecraft_xiao_esp32s3_mqtt.md +++ b/docs/Cloud_Chain/SenseCraft/SenseCraft_AI/Output/xiao_esp32s3_sense/sensecraft_xiao_esp32s3_mqtt.md @@ -4,17 +4,182 @@ title: Via MQTT output image: https://files.seeedstudio.com/wiki/watcher_getting_started/watcherKS.png slug: /sensecraft_ai_output_mqtt_xiao sidebar_position: 2 -sidebar_class_name: hidden last_update: date: 12/04/2024 author: Citric --- -# Send results via MQTT +# Configuring Model Output via MQTT on SenseCraft AI for XIAO ESP32S3 Sense +This wiki article provides a step-by-step guide on how to configure model output using MQTT (Message Queuing Telemetry Transport) for the XIAO ESP32S3 Sense board on the SenseCraft AI platform. MQTT is a lightweight messaging protocol that enables efficient communication between devices. By following these instructions, you will learn how to set up MQTT communication and retrieve model inference results from your XIAO ESP32S3 Sense. +## Prerequisites +Before you begin, ensure that you have the following: +1. XIAO ESP32S3 Sense board +2. USB-C data cable for connecting the XIAO board to your computer +3. A third-party MQTT client, such as MQTTX, installed on your computer + +
+ + + + + + + + + + +
XIAO ESP32S3 Sense
+
+ +## Step 1. Access the SenseCraft AI Vision Workspace and connect the XIAO ESP32S3 Sense + +Open your web browser and navigate to the SenseCraft AI Vision Workspace page. + +
+ + One-Click Direct 🖱️ + +

+ +Select the XIAO ESP32S3 Sense board from the available devices. + +
+ + +Using the USB-C cable, connect your XIAO ESP32S3 Sense board to your computer. Once connected, click the **Connect** button located in the top-left corner of the SenseCraft AI Vision Workspace page. + +
+ +## Step 2. Ensure a Model is Loaded on the XIAO ESP32S3 Sense + +Before proceeding, make sure that your XIAO ESP32S3 Sense board has a trained model loaded. If you haven't loaded a model yet, refer to the SenseCraft AI documentation on how to train and deploy models to your device. + +- [Using a model for XIAO ESP32S3 Sense](https://wiki.seeedstudio.com/sensecraft_ai_pretrained_models_for_xiao/) + +If you want to use your own trained model, you can refer to the following two Wikis. + +- [Type of training - Classification](https://wiki.seeedstudio.com/sensecraft_ai_training_classification/) +- [Type of training - Object Detection](https://wiki.seeedstudio.com/sensecraft_ai_training_object_detection/) + +## Step 3. Configure MQTT Output + +In the left sidebar of the Vision Workspace page, click on the **Output** option. From the available output options, select **MQTT** to access the MQTT configuration settings. + +
+ +## Step 4. Set Up MQTT Configuration + +Click on the **Configuration** button at the bottom of the MQTT output section. A configuration window will appear, prompting you to enter the following information: + + - **SSID**: Enter the name of your Wi-Fi network. + - **Password**: Provide the password for your Wi-Fi network. + - **Encryption**: Choose the encryption type for your Wi-Fi network (e.g., AUTO). + - **MQTT**: Select "Yes" to enable MQTT communication. + +Fill in the MQTT configuration fields: + + - **Host**: Enter the hostname or IP address of your MQTT broker (e.g., broker.emqx.io). + - **Port**: Specify the port number for MQTT communication (e.g., 1883). + - **Client ID**: Provide a unique client ID for your XIAO ESP32S3 Sense (e.g., xiao_esp32s3). + - **User Name**: Enter your MQTT username, if required by your MQTT broker. + - **Password**: Provide your MQTT password, if required by your MQTT broker. + - **SSL**: Choose whether to enable SSL encryption. If your MQTT broker supports SSL, you can select "Yes" to enhance communication security. + +
+ +Click the **Apply** button to save the configuration. + +:::caution +This step will require a network connection, please connect an antenna for XIAO ESP32S3 Sense. +::: + +If everything is configured smoothly, you should be able to see the following information on the website. + +
+ +## Step 5. Set Up MQTT Client (MQTTX) + +Launch the [MQTTX application](https://mqttx.app/) on your computer. + +Create a new connection with the following settings: + + - Host: Enter the same hostname or IP address used in the SenseCraft AI platform (e.g., broker.emqx.io). + - Port: Specify the port number for MQTT communication (e.g., 1883). + - Client ID: Provide a unique client ID for your MQTTX instance (e.g., seeed_computer). + +
+ +Click the **Connect** button to establish a connection with the MQTT broker. + +## Step 6. Subscribe to MQTT Topic + +In the MQTTX application, click on the **New Subscribe** button to create a new subscription. Enter the topic `sscma/v0/#` and click **Subscribe**. + +
+ +This topic will be used to receive model inference information from your XIAO ESP32S3 Sense. + +## Step 7. Send Command to Retrieve Model Inference Results + +In the MQTTX application, navigate to the device topic channel. You can get it by clicking the **Query device's topic** button on SenseCraft AI's MQTT page. + +
+ +Send the command `AT+INVOKE=-1,0` to trigger the model inference on your XIAO ESP32S3 Sense. + +:::tip +Please make sure you are sending the correct topic. + +
+ +If you find that you still don't have any model recognition related data to report, try sending the command in HEX format. + +
+ +
+::: + +The XIAO ESP32S3 Sense will process the command and publish the model inference results to the subscribed topic. In the MQTTX application, you will receive the inference results under the `sscma/v0/#` topic. + +**Example**: + +Let's say your trained model is designed to detect objects in an image. When you send the 'AT+INVOKE=-1,0' command, the XIAO ESP32S3 Sense will capture an image, run the model inference, and publish the results via MQTT. The inference results may include information such as the detected objects, their bounding boxes, and confidence scores. For instance, the MQTT message payload could be: + +```json +{"type":1,"name":"INVOKE","code":0,"data":{"count":989,"image":"/9j/4AAQSkZJRgABAQEAAAAAAAD...CUxBQAYoAPpQAc0AA/9X/2Q==","boxes":[[208.46,215.41,69.49,48.64,80.60,0]],"perf":[70,470,0],"rotation":0,"width":240,"height":240}} +``` + +For a detailed description of the JSON format read the documentation **[here](https://github.com/Seeed-Studio/SSCMA-Micro/blob/main/docs/protocol/at-protocol-en_US.md#box-type)**. + +:::tip +In the device's firmware, there is a set of established communication protocols that specify the format of the model results output, and what the user can do with the models. Due to space issues, we won't be expanding on the specifics of these protocols in this wiki, we'll be detailing this section through documentation on Github. If you are interested in more in-depth development, please go **[here](https://github.com/Seeed-Studio/SSCMA-Micro/blob/dev/docs/protocol/at_protocol.md)**. +::: + +To decode the base64-encoded image: + +1. Copy the base64-encoded string from the "image" field in the JSON object. + +2. Visit the website `https://base64.guru/converter/decode/image` in your web browser. + +3. Paste the copied base64-encoded string into the "Base64 string" textarea on the website. + +4. Click the **Decode Base64 to Image** button. + +5. The decoded image will appear below the button, and you can view or download it. + +
+ +## Conclusion + +By following this step-by-step guide, you have learned how to configure model output using MQTT on the SenseCraft AI platform for the XIAO ESP32S3 Sense board. You can now retrieve model inference results via MQTT and integrate them into your applications or systems. Remember to ensure a stable Wi-Fi connection and correctly configure your MQTT broker and client settings for seamless communication. ## Tech Support & Product Discussion diff --git a/docs/Sensor/mmWave_radar_sensor/mr60bha2-mmwave-kit/ha_with_mr60bha2.md b/docs/Sensor/mmWave_radar_sensor/mr60bha2-mmwave-kit/ha_with_mr60bha2.md index 95027f056854..e08fbfd5886a 100644 --- a/docs/Sensor/mmWave_radar_sensor/mr60bha2-mmwave-kit/ha_with_mr60bha2.md +++ b/docs/Sensor/mmWave_radar_sensor/mr60bha2-mmwave-kit/ha_with_mr60bha2.md @@ -211,99 +211,103 @@ To get started with ESPHome, follow these steps: 2. **Create a New Configuration**: Click on the device to open its configuration. Here, you can adjust settings such as the sensor's sensitivity, reporting intervals, and output formats. ESPHome uses a YAML configuration format, which is user-friendly and allows you to define various parameters. You can use the following template YAML file as a starting point for your configuration, which is designed specifically for the MR60BHA2 Sensor: - ```yaml showLineNumbers title=example/mr60bha2.yaml - # template from https://github.com/limengdu/MR60BHA2_ESPHome_external_components - - substitutions: - name: "seeedstudio-mr60bha2-kit" - friendly_name: "Seeed Studio MR60BHA2 Kit" - - esphome: - name: "${name}" - friendly_name: "${friendly_name}" - name_add_mac_suffix: true - project: - name: "seeedstudio.mr60bha2_kit" - version: "1.0" - platformio_options: - board_upload.maximum_size: 4194304 - min_version: "2024.3.2" # Fix logger compile error on ESP32-C6 - - esp32: - board: esp32-c6-devkitc-1 - variant: esp32c6 - flash_size: 4MB # upload.flash_size - framework: - type: esp-idf - platform_version: 6.5.0 # Minimum version required for ESP32-C6 - - external_components: - - source: - type: git - url: https://github.com/ssieb/esphome - ref: adc - components: [ adc ] - refresh: 1min - - source: - type: git - url: https://github.com/limengdu/MR60BHA2_ESPHome_external_components - ref: main - components: [ seeed_mr60bha2 ] - refresh: 0s - - logger: - hardware_uart: USB_SERIAL_JTAG - level: DEBUG - - api: - - ota: - - platform: esphome - - wifi: - ap: - ssid: "seeedstudio-mr60bha2" - - light: - - platform: esp32_rmt_led_strip - id: led_ring - name: "Seeed MR60BHA2 RGB Light" - pin: GPIO1 - num_leds: 1 - rmt_channel: 0 - rgb_order: GRB - chipset: ws2812 - - i2c: - sda: GPIO22 - scl: GPIO23 - scan: true - id: bus_a - - uart: - id: uart_bus - baud_rate: 115200 - rx_pin: 17 - tx_pin: 16 - parity: NONE - stop_bits: 1 - - seeed_mr60bha2: - id: my_seeed_mr60bha2 - - sensor: - - platform: bh1750 - name: "Seeed MR60BHA2 Illuminance" - address: 0x23 - update_interval: 1s - - platform: seeed_mr60bha2 - breath_rate: - name: "Real-time respiratory rate" - heart_rate: - name: "Real-time heart rate" - distance: - name: "Distance to detection object" - ``` + ```yaml showLineNumbers title=example/mr60bha2.yaml + # template from https://github.com/limengdu/MR60BHA2_ESPHome_external_components + + substitutions: + name: "seeedstudio-mr60bha2-kit" + friendly_name: "Seeed Studio MR60BHA2 Kit" + + esphome: + name: "${name}" + friendly_name: "${friendly_name}" + name_add_mac_suffix: true + project: + name: "seeedstudio.mr60bha2_kit" + version: "2.0" + platformio_options: + board_upload.maximum_size: 4194304 + min_version: "2024.3.2" # Fix logger compile error on ESP32-C6 esphome#6323 + + esp32: + board: esp32-c6-devkitc-1 + variant: esp32c6 + flash_size: 4MB # upload.flash_size + framework: + type: esp-idf + + external_components: + - source: + type: git + url: https://github.com/limengdu/MR60BHA2_ESPHome_external_components + ref: main + components: [ seeed_mr60bha2 ] + refresh: 0s + + # Enable logging + logger: + hardware_uart: USB_SERIAL_JTAG + level: DEBUG + + # Enable Home Assistant API + api: + + ota: + - platform: esphome + + wifi: + # Enable fallback hotspot (captive portal) in case wifi connection fails + ap: + ssid: "seeedstudio-mr60bha2" + + captive_portal: + + # For XIAO ESP32C6 Onboard LED + # light: + # - platform: status_led + # name: "Switch state" + # pin: GPIO15 + + light: + - platform: esp32_rmt_led_strip + id: led_ring + name: "Seeed MR60BHA2 RGB Light" + pin: GPIO1 + num_leds: 1 + rmt_channel: 0 + rgb_order: GRB + chipset: ws2812 + + i2c: + sda: GPIO22 + scl: GPIO23 + scan: true + id: bus_a + + uart: + id: uart_bus + baud_rate: 115200 + rx_pin: 17 + tx_pin: 16 + parity: NONE + stop_bits: 1 + + seeed_mr60bha2: + id: my_seeed_mr60bha2 + + sensor: + - platform: bh1750 + name: "Seeed MR60BHA2 Illuminance" + address: 0x23 + update_interval: 1s + - platform: seeed_mr60bha2 + breath_rate: + name: "Real-time respiratory rate" + heart_rate: + name: "Real-time heart rate" + distance: + name: "Distance to detection object" + ``` 3. **Customize Functionality**: You can enhance the sensor's capabilities by exploring various features available in ESPHome, allowing for flexible adjustments to suit your specific needs.