Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: sensor_library_test sensor_library_test
Revision 0:0c2c06ab8e72, committed 2016-07-25
- Comitter:
- aolgu003
- Date:
- Mon Jul 25 00:19:52 2016 +0000
- Commit message:
- Nothing was changed
Changed in this revision
| MS5837.cpp | Show annotated file Show diff for this revision Revisions of this file |
| MS5837.h | Show annotated file Show diff for this revision Revisions of this file |
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/MS5837.cpp Mon Jul 25 00:19:52 2016 +0000
@@ -0,0 +1,108 @@
+#include <stdlib.h>
+#include "MS5837.h"
+
+
+/*
+ * Sensor operating function according data sheet
+ */
+
+void MS5837::MS5837Init(void)
+{
+ MS5837Reset();
+ MS5837ReadProm();
+ return;
+}
+
+/* Send soft reset to the sensor */
+void MS5837::MS5837Reset(void)
+{
+ /* transmit out 1 byte reset command */
+ ms5837_tx_data[0] = ms5837_reset;
+ if ( i2c.write( device_address, ms5837_tx_data, 1 ) );
+ printf("send soft reset\n");
+ wait_ms(20);
+}
+
+/* read the sensor calibration data from rom */
+void MS5837::MS5837ReadProm(void)
+{
+ uint8_t i,j;
+ for (i=0; i<8; i++) {
+ j = i;
+ ms5837_tx_data[0] = ms5837_PROMread + (j<<1);
+ if ( i2c.write( device_address, ms5837_tx_data, 1 ) );
+ if ( i2c.read( device_address, ms5837_rx_data, 2 ) );
+ C[i] = ms5837_rx_data[1] + (ms5837_rx_data[0]<<8);
+ }
+}
+
+/* Start the sensor pressure conversion */
+void MS5837::MS5837ConvertD1(void)
+{
+ ms5837_tx_data[0] = ms5837_convD1;
+ if ( i2c.write( device_address, ms5837_tx_data, 1 ) );
+}
+
+/* Start the sensor temperature conversion */
+void MS5837:: MS5837ConvertD2(void)
+{
+ ms5837_tx_data[0] = ms5837_convD2;
+ if ( i2c.write( device_address, ms5837_tx_data, 1 ) );
+}
+
+/* Read the previous started conversion results */
+int32_t MS5837::MS5837ReadADC(void)
+{
+ int32_t adc;
+ wait_ms(150);
+ ms5837_tx_data[0] = ms5837_ADCread;
+ if ( i2c.write( device_address, ms5837_tx_data, 1 ) );
+ if ( i2c.read( device_address, ms5837_rx_data, 3 ) );
+ adc = ms5837_rx_data[2] + (ms5837_rx_data[1]<<8) + (ms5837_rx_data[0]<<16);
+ //printf("ADC value: %x\n", adc);
+ return (adc);
+}
+
+/* return the results */
+float MS5837::MS5837_Pressure (void)
+{
+ return P_MS5837;
+}
+float MS5837::MS5837_Temperature (void)
+{
+ return T_MS5837;
+}
+
+/* Sensor reading and calculation procedure */
+void MS5837::Barometer_MS5837(void)
+{
+ int32_t dT, temp;
+ int64_t OFF, SENS, press;
+
+ //no need to do this everytime!
+
+
+ MS5837ConvertD1(); // start pressure conversion
+ D1 = MS5837ReadADC(); // read the pressure value
+ MS5837ConvertD2(); // start temperature conversion
+ D2 = MS5837ReadADC(); // read the temperature value
+ //printf("D1 = %d\n", D1);
+ /* calculation according MS5837-01BA data sheet DA5837-01BA_006 */
+ dT = D2 - (C[5]* 256);
+ OFF = (int64_t)C[2] * (1<<16) + ((int64_t)dT * (int64_t)C[4]) / (1<<7);
+ SENS = (int64_t)C[1] * (1<<15) + ((int64_t)dT * (int64_t)C[3]) / (1<<8);
+
+ temp = 2000 + (dT * C[6]) / (1<<23);
+ T_MS5837 = (float) temp / 100.0f; // result of temperature in deg C in this var
+ press = (((int64_t)D1 * SENS) / (1<<21) - OFF) / (1<<13);
+ P_MS5837 = (float) press / 10.0f; // result of pressure in mBar in this var
+
+ if (P_MS5837 < 900 || P_MS5837 > 3000) {
+ MS5837Reset(); // reset the sensor
+ MS5837ReadProm(); // read the calibration values
+ }
+}
+
+float MS5837::depth(void) {
+ return (P_MS5837/100)*1.019716;
+}
\ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/MS5837.h Mon Jul 25 00:19:52 2016 +0000
@@ -0,0 +1,64 @@
+#include "mbed.h"
+
+#ifndef MS5837_H
+#define MS5837_H
+
+#define MS5837_RX_DEPTH 3 //
+#define MS5837_TX_DEPTH 2 //
+
+// choose your connection here
+#define ms5837_addr_no_CS 0x76 //0b1110110
+
+#define ms5837_reset 0x1E // Sensor Reset
+
+#define ms5837_convD1_256 0x40 // Convert D1 OSR 256
+#define ms5837_convD1_512 0x42 // Convert D1 OSR 512
+#define ms5837_convD1_1024 0x44 // Convert D1 OSR 1024
+#define ms5837_convD1_2048 0x46 // Convert D1 OSR 2048
+#define ms5837_convD1_4096 0x48 // Convert D1 OSR 4096
+#define ms5837_convD1_8192 0x4A // Convert D1 OSR 8192
+
+#define ms5837_convD1 ms5837_convD1_4096 // choose your sampling rate here
+
+#define ms5837_convD2_256 0x50 // Convert D2 OSR 256
+#define ms5837_convD2_512 0x52 // Convert D2 OSR 512
+#define ms5837_convD2_1024 0x54 // Convert D2 OSR 1024
+#define ms5837_convD2_2048 0x56 // Convert D2 OSR 2048
+#define ms5837_convD2_4096 0x58 // Convert D2 OSR 4096
+#define ms5837_convD2_8192 0x5A // Convert D2 OSR 8192
+
+#define ms5837_convD2 ms5837_convD2_4096 // choose your sampling rate here
+
+#define ms5837_ADCread 0x00 // read ADC command
+#define ms5837_PROMread 0xA0 // read PROM command base address
+
+class MS5837{
+private:
+ int D1, D2, Temp, C[8];
+ float T_MS5837, P_MS5837;
+ /* Data buffers */
+ char ms5837_rx_data[MS5837_RX_DEPTH];
+ char ms5837_tx_data[MS5837_TX_DEPTH];
+
+public:
+ MS5837 (PinName sda, PinName scl,
+ char ms5837_addr = ms5837_addr_no_CS )
+ : i2c( sda, scl ), device_address( ms5837_addr << 1 ) {
+ }
+ void MS5837Init(void);
+ void MS5837Reset(void);
+ void MS5837ReadProm(void);
+ void MS5837ConvertD1(void);
+ void MS5837ConvertD2(void);
+ int32_t MS5837ReadADC(void);
+ float MS5837_Pressure (void);
+ float MS5837_Temperature (void);
+ void Barometer_MS5837(void);
+ float depth(void);
+
+private:
+ I2C i2c;
+ char device_address;
+
+};
+#endif