Skip to content

Latest commit

 

History

History
201 lines (135 loc) · 10 KB

File metadata and controls

201 lines (135 loc) · 10 KB

Wi-Fi - Weather Display

Purpose-Scope

This project demonstrates a weather display powered by the SiWx917 microcontroller. It retrieves real-time weather data from the OpenWeatherMap API, synchronizes the current date and time using the NTP protocol, and monitors indoor temperature and humidity using the Si70xx sensor on the WSTK development kit.

Key Features:

  • External Weather Data: Obtained from OpenWeatherMap API over HTTP, including temperature, humidity, and other meteorological information.

  • Indoor Environment Monitoring: The Si70xx temperature and humidity sensor on the WSTK provides accurate indoor data.

  • NTP Time Synchronization: Displays the current date and time using the network time protocol. This project showcases the SiWx917 platform's capabilities in IoT and smart home applications, integrating both real-time external weather data and local indoor environmental monitoring.

Overview

system_overview

System Overview

  • SiLabs SiWG917 Device

    The SiWx917 SoC is configured to interface with the Si7021 sensor on the WSTK. The device captures sensor data at configured intervals via I2C. It connects to Wi-Fi to access the internet, retrieves weather and air quality data (AQI) via HTTPS, and synchronizes the current date and time using NTP. The data is then displayed on the WSTK's LCD.

Application Overview

The firmware consists of three RTOS tasks:

  • Device Initialization

    Initializes the Wi-Fi interface, Si7021 sensor, and LCD display. It then retrieves weather and AQI data via HTTPS and synchronizes the date and time via NTP.

  • App Process

    Manages display updates and state transitions based on button presses.

  • Data Update

    Periodically updates the weather, AQI, and network time data based on the #define DATA_UPDATE_TIMEOUT value.

Hardware Requirements

Software Requirements

Setup

Create a project based on an example project

  • Create a Wi-Fi HTTP Client (SoC) project for the SiWx917 in Simplicity Studio.

  • Copy the provided app.c, cJSON, HTTP, SNTP, sensor, and display source/header files into the project folder, overwriting the existing app.c.

  • Open the .slcp file. Select the SOFTWARE COMPONENTS tab and install the software components:

    • [WiSeConnect 3 SDK v3.3.4] → [Service] → [SNTP Client] Figure: SNTP Client
    • [Platform] → [Driver] → [GLIB Graphics Library] Figure: GLIB
    • [Platform] → [Driver] → [GLIB driver for Memory LCD] Figure: GLIB driver
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [Hardware] → [Memory LCD SPI driver] Figure: MEMLCD SPI driver
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [peripheral] → [SSI] Figure: SSI
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [Hardware] → [Si70xx Humidity and Temperature Sensor] Figure: Si7021
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [peripheral] → [I2C] (Configure the I2C instance to "i2c2") Figure: I2C Figure: I2C instance 2
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [peripheral] → [ULP Timer] (Configure the ULP timer instance to "timer0") Figure: Timer Figure: Timer 0 instance
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [peripheral] → [Calendar] Figure: Calender
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [MCU] → [Service] → [Sleep Timer for Si91x] Figure: Sleeptimer
    • [WiSeConnect 3 SDK v3.3.4] → [Device] → [Si91x] → [MCU] → [Hardware] → [Button] (Configure the Button instance to "btn0") Figure: Button Figure: Button btn0 instance
  • Copy the cacert.pem.h file to the resources/certificates folder of the WiSeConnect SDK.

  • Build and flash the project onto the board.

Application Configurations

The application can be customized according to user requirements and the development environment.

In the sl_net_default_values.h file located in the config folder, update the following parameters to connect your Silicon Labs Wi-Fi device to a Wi-Fi network:

SSID: Define the network name (SSID) the Si91x module connects to:

  #define DEFAULT_WIFI_CLIENT_PROFILE_SSID               "YOUR_AP_SSID"     

Wi-Fi Credentials: Define the Wi-Fi password if using WPA-PSK/WPA2-PSK security:

  #define DEFAULT_WIFI_CLIENT_CREDENTIAL                 "YOUR_AP_PASSPHRASE" 

Security Type: Specify the Wi-Fi security type:

  #define DEFAULT_WIFI_CLIENT_SECURITY_TYPE              SL_WIFI_WPA2 

Configuring the Weather API

Define your location's latitude, longitude, and the API key from OpenWeatherMap in the app.c file (NOTE: Refer to the end of the readme on how to generate an OpenWeatherMap API key):

 // Define the latitude, longitude, and API key
 char *latitude = "xx.xxx";
 char *longitude = "xx.xxx";
 char *api_key = "xxxxxxxxxxxxxxxxxxxxxxx";  // Replace with your actual API key

Set the time zone offset based on your location:

// Time zone offset
#define HOUR_OFFSET xx
#define MIN_OFFSET xx

How It Works

After flashing the code to the board, the application starts running automatically. Using Putty/Tera Term (or another program) to read the values of the serial output is advised. Note that the Wi-Fi board uses the default baud rate of 115200. First, the device tries to establish connection to the Wi-Fi access point (AP), if the connection is successfully established with the access point, the system performs the following tasks:

  • Retrieves weather and air quality data via HTTP GET requests from OpenWeatherMap.
  • Synchronizes the current date and time via NTP.

Once initialized, the system displays the time (in 24-hour format). Use the btn0 on the WSTK to navigate between different display states:

  • Time: Figure: Time
  • Date: Figure: Date
  • Outdoor Climate: Figure: Outdoor Climate
  • Indoor Climate: Figure: Indoor Climate
  • Weather Report: Figure: Weather Report
  • Air Quality Index (AQI) Report: Figure: AQI
    • The system displays detailed reports with units: Ozone (O3), PM10, PM2.5, and CO are displayed in µg/m³.

There is a periodic timer in the code, which determines the data update period; the default update intervals rate is defined in #define DATA_UPDATE_TIMEOUT 20.

Console Log

The screenshot of the console is shown in the images below (The board uses a baud rate of 115200):

Figure: Console log

Note

If SNTP fetch fails

  • When the application firmware starts and connects to the Wi-Fi access point, it fetches the current timestamp using the SNTP server. If the device failed to fetch the timestamp from the SNTP server within 7 seconds, the device configures a timestamp of "2000-01-01T00:00:00.000Z". It is also possible to reset the device to get a valid current timestamp. The fetched timestamp is visible at the console logs and on the LCD display.

Generating an API key

  • Create a free account on OpenWeatherMap.
  • After logging in, generate an API key under Profile > My API Keys (activation may take up to an hour). Figure: API key generation
  • Subscribe to the Current Weather Data and Air Pollution API from the OpenWeatherMap API portal. Figure: Weather API Figure: AQI API

CA Certificate Information

  • The CA root certificate used in this project is valid until December 31, 2028. When the certificate expires, it will need to be updated to continue using HTTPS. Figure: CA certificate

Report Bugs & Get Support

To report bugs in the Application Examples projects, please create a new "Issue" in the "Issues" section of wifi_applications repo. Please reference the board, project, and source files associated with the bug, and reference line numbers. If you are proposing a fix, also include information on the proposed fix. Since these examples are provided as-is, there is no guarantee that these examples will be updated to fix these issues.

Questions and comments related to these examples should be made by creating a new "Issue" in the "Issues" section of wifi_applications repo.