Introduction: Temperature Measurement Using STS21 and Arduino Nano

About: We are a group of makers. We work in IoT, IOS app, android app, embedded design, sensor design, raspberry pi, arduino, beaglebone, particle electron, particle photon, Bluetooth.

STS21 Digital Temperature Sensor offers superior performance and a space saving footprint. It provides calibrated, linearized signals in digital, I2C format. Fabrication of this sensor is based on CMOSens technology, which attributes to the superior performance and reliability of STS21. The resolution of STS21 can be changed by command, low battery can be detected and a checksum helps to improve communication reliability.

In this tutorial the interfacing of the STS21 sensor module with arduino nano has been illustrated. To read the temperature values, we have used arduino with an I2c adapter.This I2C adapter makes the connection to the sensor module easy and more reliable.

Step 1: Hardware Required:

The materials that we need for accomplishing our goal includes the following hardware components:

1. STS21

2. Arduino Nano

3. I2C Cable

4. I2C shield for arduino nano

Step 2: Hardware Hookup:

The hardware hookup section basically explains the wiring connections required between the sensor and the arduino nano. Ensuring correct connections is the basic necessity while working on any system for the desired output. So, the requisite connections are as follows:

The STS21 will work over I2C . Here is the example wiring diagram, demonstrating how to wire up each interface of the sensor.

Out-of-the-box, the board is configured for an I2C interface, as such we recommend using this hookup if you’re otherwise agnostic. All you need is four wires!

Only four connections are required Vcc, Gnd, SCL and SDA pins and these are connected with the help of I2C cable.

These connections are demonstrated in the pictures above.

Step 3: Code for Temperature Measurement:

Let's start with the Arduino code now.

While using the sensor module with the Arduino, we include Wire.h library. "Wire" library contains the functions which facilitate the i2c communication between the sensor and the Arduino board.

The entire Arduino code is given below for the convenience of the user:

<p>#include<Wire.h> </p><p>// STS21 I2C address is 0x4A(74)</p><p>#define addr 0x4A</p><p>void setup()</p><p>{  </p><p>// Initialise I2C communication as MASTER  </p><p>Wire.begin();  </p><p>// Start serial communication, set baud rate = 9600  </p><p>Serial.begin(9600);  </p><p>delay(300);</p><p>}
</p><p>void loop()</p><p>{  </p><p>unsigned int data[2];</p><p>// Start I2C Transmission  </p><p>Wire.beginTransmission(addr);  </p><p>// Select no hold master  </p><p>Wire.write(0xF3);  </p><p>// End I2C Transmission  </p><p>Wire.endTransmission();  </p><p>delay(300);</p><p>// Request 2 bytes of data  </p><p>Wire.requestFrom(addr, 2);</p><p>// Read 2 bytes of data  </p><p>if (Wire.available() == 2)  </p><p>{    </p><p>data[0] =;    </p><p>data[1] =;  </p><p>}</p><p>// Convert the data  </p><p>int rawtmp = data[0] * 256 + data[1];  </p><p>int value = rawtmp & 0xFFFC;  </p><p>double cTemp = -46.85 + (175.72 * (value / 65536.0));  </p><p>double fTemp = cTemp * 1.8 + 32;</p><p>// Output data to serial monitor  </p><p>Serial.print("Temperature in Celsius:  ");  </p><p>Serial.print(cTemp);  </p><p>Serial.println(" C");  </p><p>Serial.print("Temperature in Fahrenheit:  ");  </p><p>Serial.print(fTemp);  </p><p>Serial.println(" F");  </p><p>delay(300);</p><p>}</p>

In wire library Wire.write() and is used to write the commands and read the sensor output.

Serial.print() and Serial.println() is used to display the output of the sensor on the serial monitor of the Arduino IDE.

The output of the sensor is shown in the picture above.

Step 4: Applications:

STS21 Digital Temperature Sensor can be employed in systems which require high accuracy temperature monitoring. It can be incorporated in various computer equipments, medical equipments and industrial control systems with the requisite of temperature measurement with proficient accuracy.