Tthere is a special offer on SONOFF module on Banggood from today until 10th of January. You can buy the module for under $6, $5.99 ( 5.79 if you order it from mobile application).
The SONOFF module is produced by Itead.cc and can be used with their mobile app eWeLink or you can write your own software.
The core of the module is the ESP8266 and is connected to a 5V relay capable of 10A ( I will not bet on that)
I already ordered few of them and I am planning to put my own software so in the end I can :
-on/off the relay from my mobile app
-give a vocal command to trigger it on/off with Amazons echo dot 2 help
-set cron task for relay.
The promotion will end in January so if you are reading this post after this date it may be outdated ,but you can check the Itead.cc site.
Esp8266 blog. Learn how to compile, how to work with the wireless chip esp8266. ESP-01 ESP-03, ESP-07, ESP-12, ESP201 all are here
Friday, December 23, 2016
Monday, December 19, 2016
Amazon's Echo DOT 2 controls ESP8266
Since Amazon's Echo Dot 2 can control the Belkin's WeMos why not emulate it with this Esp8266 .
ESP after is connected to the WiFi network will start an UDP server on address 239.255.255.250 port 1900 and an HTTP server on its own IP address and port 80. Alexa on "Alexa, discover my devices " will send UDP on multicast address/port and the ESP will reply with its configuration (IP/PORT).
Echo Dot 2 will get the setup.xml from ESP on provided IP and Port.
From now on the Echo cand send SendBinaryState command that will end up in trigger a GPIO.
SSDP protocol is used in the discovery part.
And a video controlling 2 GPIOs with on one ESP8266.
Thursday, December 1, 2016
BMP280 and ESP8266
The BMP280 is the next generation sensor from Bosch and follows its predecessors BMP085 - BMP180. Price for it is now under $2 with free shipping.
Key parameters
Typical applications
Key parameters
- Pressure range 300 … 1100 hPa (equiv. to +9000…-500 m above/below sea level)
- Package 8-pin LGA metal-lid
- Footprint : 2.0 × 2.5 mm², height: 0.95 mm
- Relative accuracy ±0.12 hPa, equiv. to ±1 m
- (950 … 1050hPa @25°C)
- Absolute accuracy typ. ±1 hPa (950 ...1050 hPa, 0 ...+40 °C)
- Temperature coefficient offset 1.5 Pa/K, equiv. to 12.6 cm/K (25 ... 40°C @900hPa)
- Digital interfaces I²C (up to 3.4 MHz) SPI (3 and 4 wire, up to 10 MHz)
- Current consumption 2.7µA @ 1 Hz sampling rate
- Temperature range -40 … +85 °C
Typical applications
- Enhancement of GPS navigation
- (e.g. time-to-first-fix improvement, dead-reckoning, slope detection)
- Indoor navigation (floor detection, elevator detection)
- Outdoor navigation, leisure and sports applications
- Weather forecast
- Health care applications (e.g. spirometry)
- Vertical velocity indication (e.g. rise/sink speed)
For connecting the BMP280 to ESP8266 the following pins need to be connected:
BMP280
|
NodeMCU / WeMos
D1 mini
|
Other ESP8266
|
VCC
|
3V3
|
|
GND
|
GND
|
|
SCL
|
D1
|
GPIO 5
|
SDA
|
D2
|
GPIO 4
|
CSB
|
3V3
|
|
SDO
|
3V3
|
The BMP280 supports the I²C and SPI digital interfaces; it acts as a slave for both protocols.
The I²C interface supports the Standard, Fast and High Speed modes.
The SPI interface
supports both SPI mode ‘00’ (CPOL = CPHA = ‘0’) and mode ‘11’ (CPOL = CPHA = ‘1’) in 4-
wire and 3-wire configuration.
The following transactions are supported: Single byte write multiple byte write (using pairs of register addresses and register data) single byte read multiple byte read (using a single register address which is auto-incremented)
Connect the CSB pin to GND to have SPI and to VCC(3V3) for I2C.
The 7-bit device address is 111011x. The 6 MSB bits are fixed. The last bit is changeable by
SDO value and can be changed during operation.
Connecting SDO to GND results in slave
address 1110110 (0x76), connecting it to VCC results in slave address 1110111 (0x77), which is the same as BMP180’s I²C address.
The SDO pin cannot be left floating, if left floating, the
I²C address will be undefined.
In my setup I've connected CSB and SDO to VCC to have I2C and 0x77 as address.
To run a quick test I've installed the Adafruit Sensor library and Adafruit BMP280 library .
The code to test the BMP280 is the example code from library.
This code assume that the SDA and SCL are connected on GPIO 4 and GPIO 5. If you need to assign new pins to your BMP280 use the Wire.begin(2,0) where the GPIO 2 is connected to SDA and GPIO 0 is connected to SCL.
Now its time to add some code to read the temperature and pressure, post them to the thingspeak.com and also update the temperature gauge on this blog.
/**********************************************
* Catalin Batrinu bcatalin@gmail.com
* Read temperature and pressure from BMP280
* and send it to thingspeaks.com
**********************************************/
#include <Wire.h>
#include <SPI.h>
#include <Adafruit_Sensor.h>
#include <Adafruit_BMP280.h>
#include <ESP8266WiFi.h>
#define BMP_SCK 13
#define BMP_MISO 12
#define BMP_MOSI 11
#define BMP_CS 10
Adafruit_BMP280 bme; // I2C
// replace with your channel’s thingspeak API key,
String apiKey = "YOUR-API-KEY";
const char* ssid = "YOUR-SSID";
const char* password = "YOUR-ROUTER-PASSWORD";
const char* server = "api.thingspeak.com";
WiFiClient client;
/**************************
* S E T U P
**************************/
void setup() {
Serial.begin(9600);
Serial.println(F("BMP280 test"));
if (!bme.begin()) {
Serial.println("Could not find a valid BMP280 sensor, check wiring!");
while (1);
}
WiFi.begin(ssid, password);
Serial.println();
Serial.println();
Serial.print("Connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED)
{
delay(500);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected");
}
/**************************
* L O O P
**************************/
void loop() {
Serial.print("T=");
Serial.print(bme.readTemperature());
Serial.print(" *C");
Serial.print(" P=");
Serial.print(bme.readPressure());
Serial.print(" Pa");
Serial.print(" A= ");
Serial.print(bme.readAltitude(1013.25)); // this should be adjusted to your local forcase
Serial.println(" m");
if (client.connect(server,80)) // "184.106.153.149" or api.thingspeak.com
{
String postStr = apiKey;
postStr +="&field1=";
postStr += String(bme.readTemperature());
postStr +="&field2=";
postStr += String(bme.readPressure());
postStr += "\r\n\r\n";
client.print("POST /update HTTP/1.1\n");
client.print("Host: api.thingspeak.com\n");
client.print("Connection: close\n");
client.print("X-THINGSPEAKAPIKEY: "+apiKey+"\n");
client.print("Content-Type: application/x-www-form-urlencoded\n");
client.print("Content-Length: ");
client.print(postStr.length());
client.print("\n\n");
client.print(postStr);
}
client.stop();
//every 20 sec
delay(20000);
}
A post about BMP180 attached to a battery shield can be found here.
Sunday, November 20, 2016
ESP8266 adapter module fits LoRa Dorji module
Soldering the Dorji LoRa module is not so easy if you don't have soldering skills. But you can borrow this adapter board ($2.60 per 10pcs) from ESP8266 and its fits very well. Same pads distance, just few modification ( remove components) and a short on the back where the AMS1117 should be and that's it, we have a more practical module to work with. Don't forget to add a curly antenna.
Don't forget to relabel the edges with the Dorji's module values, since the labels will not be visible anymore.
Don't forget to relabel the edges with the Dorji's module values, since the labels will not be visible anymore.
Dorji's LoRa module on ESP8266 adapter plate |
ESP8266 adapter plate |
Back of ESP8266 adapter plate |
Monday, November 14, 2016
ESP8266-ESP201 Step-by-step Guide
This is a step-by-step guide to ESP8266-ESP201.
1.
Buy ESP8266-ESP201 with its hardware development
kit from eBay, click
here:
The development board is shown in photo
below as well. You have a relay, buzzer, switches, LEDs, etc. to play with and
test your code and to learn input/output functions of ESP8266:
2.
Connect the USB cable between your computer and
the development board.
3.
Push the power button to check if power led is
working and the board shows sign of life.
4.
Complete schematic of the development board is
as follows:
5.
On the PCB near the DIP switch these are the
values:
·
R - should be the RED led from the RGB connected
to the IO15 pin. Putting the R DIP to ON will light RED if the GPIO15 is HIGH.
·
G - GREEN led from RGB led is connected to IO13.
Putting the G DIP to ON will light GREEN if the GPIO13 is HIGH.
·
B - BLUE led from RGB led is connected to IO12.
Putting the B DIP to ON will light BLUE if the GPIO12 is HIGH.
·
W - WHITE led located almost under RGB led is
connected to the IO14 pin. Putting HIGH on GPIO14 and DIP switch ON will light
the WHITE led.
·
J - relay pin connected to IO16 (which is always
HIGH - I have no idea why. This behavior and the RED led that is not working
can be because I have a bad board or the design for all the boards is wrong.
Connecting the IO16 to GND (not recommended) will stop the relay, otherwise it
will be ON all the time the J DIP pin is ON.
·
B - BUZZER connected to IO5 pin through B DIP
switch. Having GPIO5 HIGH and B on DIP switch ON will prove that the buzzer is
working.
·
K1 - I assume is connected to S2.
·
K2 - I assume is connected to S3.
6.
A schematic on a napkin will look like this one:
7.
ESP8266 comes with pre-installed AT commands, so
you can check these to see if you get any response. The list of AT commands can
be found
here:
To test the AT commands, you need to have a
program like “Hyper Terminal”. The easiest and recommended way is to install
Arduino from here which
has a built-in serial monitor through which you can send and receive data.
Once you have downloaded and installed
Arduino, you can now run it and it will look like this:
Now click File menu and then select Preferences.
It will look like this:
Now add the link below in the “Additional
Boards Manager URLs” because ESP8266 board is not included in Arduino by
default.
Click OK button.
Now click Tools menu and select Board. Our board in this case will Generic ESP8266 Module. Your screen should look
like this:
Now click Tools menu again and select Port
from the list of available ports. Your screen should look like this:
Now if you have set everything corrected
(i.e. (a) USB connection between ESP8266 development board and computer, (b)
Settings in Arduino software) then you are ready to type AT and send AT
commands to your ESP8266 and be excited to see “OK” response from your chip.
When you send AT to your ESP8266, it will respond you with OK.
Click Tools
menu and select Serial Monitor or
press on your keyboard Ctrl+Shift+M
to open serial monitor where you can send and receive AT commands from serial
interface. Make sure you select (a) “both NL and CR” for both new line and
carriage return, (b) correct baud rate (e.g. 115200 baud). Your screen should
look like this when you ready to send AT commands:
8.
If you have been successful so far, you can be
sure that your ESP8266 and its development board and communication between your
computer and development board – all is working fine!
9.
Now you want to know how to control GPIO pins by
yourself. For that, click File menu,
select Examples, select ESP8266WiFi, and then select WiFi WebServer. Your screen
should look like this:
A new window with WiFi webserver example
will open (as shown above in left screenshot). Now edit this file by typing in
your WiFi SSID and password. Save the example with another filename and then
press upload button to start code compilation and upload to the ESP8266. This
will fail. To be successful you need to perform a few more steps.
10.
Turn the board off; Ground the IO0 pin; Set K2
to Ground (ON); Power on the board; and Set K2 to OFF.
11.
Now press Ctrl+Shift+M to open Serial Monitor
and then click upload button again, if it fails or shows error close Arduino
and open Arduino again and press upload button. It will upload successfully –
at least it did it for me! J
12.
Now you will see in Serial Monitor window that your
ESP8266 is now connected to your WiFi network and shows an IP address from
where you can control IO2 to be 1 or 0.
13.
Connect LED to IO2 and Ground. Go to the given
IP address in Serial Monitor (say, 192.168.0.140) and turn on/off LED like
this:
14.
The
pinouts of ESP8266-ESP201 look like this:
Helpful resources:
s
Guest post by: Ahmed Hussain
Friday, November 11, 2016
LoRa Gateway has new antenna
Finally the new 7dB antenna arrived. Since the new antenna has a 3cm magnetic mount I will try to put it on top of the car for better coverage.
Specs:
Antenna gain: 7dB
Magnetic mount: 3cm
Cable length: 150 cm
Connector: SMA male
I can connected it to the gateway or to the ESP8266 Lora module from Dorji.com.
New 868Mhz 7dB LoRa antenna |
Specs:
Antenna gain: 7dB
Magnetic mount: 3cm
Cable length: 150 cm
Connector: SMA male
I can connected it to the gateway or to the ESP8266 Lora module from Dorji.com.
Wednesday, November 9, 2016
ESP32 - How to increase the maximum number of sockets
Still didn't found an ESP32 with a decent delivery price so today I've tested the environment provided by EspressIf looking on the maximum number of sockets. On ESP8266 I've managed to have more then 20 sockets opened and carrying MQTT packets ( see https://myesp8266.blogspot.co.uk/2016/11/mqtt-broker-on-esp8266-5.html)
I've noticed that the maximum number of sockets that you can setup from make menuconfig is 16.
All the values that you are setting from make menuconfig are ending in a file named sdkconfig in the root of you app directory. This sdkconfig file will be converted to sdkconfig.h located in app/build/include/sdkconfig.h.
Even you are modifying a value direct in the sdkconfig on the compile time you will be invited to enter a value 1..16 for maximum number of sockets.
Solution #1. (Safest one)
Change the sdkconfig.h file overwrite the desired value and recompile
#define CONFIG_LWIP_MAX_SOCKETS 20
Solution #2. (not recommended but possible )
Modify directly the file:
esp-idf/components/lwip/include/lwip/port/lwipopts.h
#define MEMP_NUM_NETCONN 20 //CONFIG_LWIP_MAX_SOCKETS
If you modified values in make menuconfig and you don't know what was before don't worry just do a diff between the app/sdkconfig and app/sdkconfig.old file.
Obs: this post can be found also on this link.
I've noticed that the maximum number of sockets that you can setup from make menuconfig is 16.
All the values that you are setting from make menuconfig are ending in a file named sdkconfig in the root of you app directory. This sdkconfig file will be converted to sdkconfig.h located in app/build/include/sdkconfig.h.
Even you are modifying a value direct in the sdkconfig on the compile time you will be invited to enter a value 1..16 for maximum number of sockets.
Solution #1. (Safest one)
Change the sdkconfig.h file overwrite the desired value and recompile
#define CONFIG_LWIP_MAX_SOCKETS 20
Solution #2. (not recommended but possible )
Modify directly the file:
esp-idf/components/lwip/include/lwip/port/lwipopts.h
#define MEMP_NUM_NETCONN 20 //CONFIG_LWIP_MAX_SOCKETS
If you modified values in make menuconfig and you don't know what was before don't worry just do a diff between the app/sdkconfig and app/sdkconfig.old file.
Obs: this post can be found also on this link.
Sunday, November 6, 2016
Mqtt broker on ESP8266 #5
[Later edit]. On iotcentral.eu you will find instructions on how to install the ESP8266 MQTT broker on your EPS8266 and how to use the MQTT service provided by iotcentral.eu
I've accepted Anthony's challenge to squeeze more from the ESP8266 as MQTT broker so I managed to increase the maximum number of simultaneous subscribers on a single ESP8266.
Now instead of 9 like I had before ( plus bridge to/from cloud and websockets to connect my mobile app to ESP8266 MQTT broker) I have 20 stable subscribers.
Top was 30 but the heap memory was too low to have flawless connections to all subscribers.
Also a good news is that this is not limiting the number of topics a device can subscribe to the broker ( in a reasonable number of 4 or 5 topics per device).
A picture with 25 connections and one with websocket.
At the beginning I have 35Kb and after 25+1+1 connections I am ending with 11 to 12 Kb of heap memory which is plenty even for bigger payloads.
Related links:
Mqtt broker on ESP8266 #4
Mqtt broker on ESP8266 #3
Mqtt broker on ESP8266 #2
Mqtt broker on ESP8266 #1
I've accepted Anthony's challenge to squeeze more from the ESP8266 as MQTT broker so I managed to increase the maximum number of simultaneous subscribers on a single ESP8266.
Now instead of 9 like I had before ( plus bridge to/from cloud and websockets to connect my mobile app to ESP8266 MQTT broker) I have 20 stable subscribers.
Top was 30 but the heap memory was too low to have flawless connections to all subscribers.
Also a good news is that this is not limiting the number of topics a device can subscribe to the broker ( in a reasonable number of 4 or 5 topics per device).
A picture with 25 connections and one with websocket.
ESP8266 as MQTTbroker |
At the beginning I have 35Kb and after 25+1+1 connections I am ending with 11 to 12 Kb of heap memory which is plenty even for bigger payloads.
Related links:
Mqtt broker on ESP8266 #4
Mqtt broker on ESP8266 #3
Mqtt broker on ESP8266 #2
Mqtt broker on ESP8266 #1