Introduction: Humidity Measurement Using HYT939 and Particle Photon

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.

HYT939 is a digital humidity sensor which works on I2C communication protocol. Humidity is a pivotal parameter when it comes to medical systems and laboratories, So in order to accomplish these goals we tried to interface HYT939 with raspberry pi. In this tutorial the interfacing of the HYT939 sensor module with particle photon has been illustrated.

To read the humidity values, we have used particle photon with an I2c adapter.This I2C adapter makes the connection to the sensor module easy and more reliable.Particle photon is a board which facilitates sending and receiving data from website, that is supporting the most basic feature of Internet Of Things(IoT).

Step 1: Hardware Required:

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

1. HYT939

2. Particle Photon

3. I2C Cable

4. I2C Shield For Particle Photon

Step 2: Hardware Hookup:

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

The HYT939 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 Humidity Measurement:

Let's start with the particle code now.

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

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

<p>#include<application.h> </p><p>#include<spark_wiring_i2c.h> </p><p>// HYT939 I2C address is 0x28(40)</p><p>#define Addr 0x28</p><p>double humidity = 0.0, cTemp = 0.0, fTemp = 0.0;</p><p>void setup() </p><p>{    </p><p>// Set variable    </p><p>Particle.variable("i2cdevice", "HYT939");    </p><p>Particle.variable("cTemp", cTemp);    </p><p>Particle.variable("humidity", humidity);      </p><p>// Initialise I2C communication as MASTER     </p><p>Wire.begin();    </p><p>// Initialise Serial Communication    </p><p>Serial.begin(9600);    </p><p>delay(300);</p><p>}
void loop() </p><p>{    </p><p>unsigned int data[4];    </p><p>// Start I2C transmission    </p><p>Wire.beginTransmission(Addr);    </p><p>// Send normal mode command      </p><p>Wire.write(0x80);    </p><p>// Stop I2C transmission    </p><p>Wire.endTransmission();    </p><p>delay(300);      </p><p>// Request 4 bytes of data from the device    </p><p>Wire.requestFrom(Addr, 4);</p><p>// Read 4 bytes of data    </p><p>// humidity msb, humidity lsb, temp msb, temp lsb    </p><p>if(Wire.available() == 4)    </p><p>{        </p><p>data[0] = Wire.read();        </p><p>data[1] = Wire.read();        </p><p>data[2] = Wire.read();        </p><p>data[3] = Wire.read();    </p><p>}            </p><p>// Convert the data to 14-bits    </p><p>humidity = (((data[0] & 0x3F) * 256.0) +  data[1]) * (100.0 / 16383.0);    </p><p>cTemp = (((data[2] * 256.0) + (data[3] & 0xFC)) / 4) * (165.0 / 16383.0) - 40;   </p><p>fTemp = (cTemp * 1.8) + 32;            </p><p>// Output data to dashboard    </p><p>Particle.publish("Relative Humidity is      :  ", String(humidity));    </p><p>delay(1000);    </p><p>Particle.publish("Temperature in Celsius    :  ", String(cTemp));    </p><p>delay(1000);    </p><p>Particle.publish("Temperature in Fahrenheit :  ", String(fTemp));    </p><p>delay(1000);</p><p>}</p>

Particle.variable() function creates the variables to store the output of the sensor and Particle.publish() function displays the output on the dashboard of the site.

The sensor output is shown in the picture above for your reference.

Step 4: Applications:

HYT939 being an efficient digital humidity sensor are employed in Medical systems, Autoclaves. Pressure dew point measurement and Drying systems also find the usage of this sensor module.In various Laboratories where appropriate humidity level is a pivotal parameter for conducting experiments, this sensor can be deployed there for humidity measurements.