201 lines
6.4 KiB
Markdown
Raw Normal View History

2021-11-26 09:30:38 +01:00
[![Arduino CI](https://github.com/RobTillaart/pressure/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
[![Arduino-lint](https://github.com/RobTillaart/pressure/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/pressure/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/pressure/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/pressure/actions/workflows/jsoncheck.yml)
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/pressure/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/pressure.svg?maxAge=3600)](https://github.com/RobTillaart/pressure/releases)
# pressure
Arduino library for pressure conversion.
## Description
2023-02-24 12:53:57 +01:00
Arduino library to convert between several pressure units (formats).
The class consists of a number of setters and getters and internally it uses millibar.
In fact the class just hides all conversion constants to and frm millibar.
2021-11-26 09:30:38 +01:00
Pressure is implemented as a float so this limits the precision of the value.
2022-11-22 14:57:22 +01:00
If other constants / conversions are needed please open an issue on GitHub.
Note: as a conversion uses two steps the conversion error might be (bit) larger
than in a single conversion step as there are two multiplications involved.
2021-11-26 09:30:38 +01:00
Note: constants need to be verified.
2023-02-24 12:53:57 +01:00
#### Related
- https://github.com/RobTillaart/temperature (a bit)
2021-11-26 09:30:38 +01:00
## Interface
2023-02-24 12:53:57 +01:00
```cpp
#include "pressure.h"
```
2021-11-26 09:30:38 +01:00
#### Constructor
- **pressure(float value = 0.0)** Constructor, with optional initial value.
2022-11-22 14:57:22 +01:00
#### Setters
2021-11-26 09:30:38 +01:00
- **void setMilliBar(float value)** sets pressure in milliBar.
- **void setBar(float value)** sets pressure in bar.
- **void setPSI(float value)** sets pressure in PSI = Pounds per Square Inch.
- **void setATM(float value)** sets pressure in Atmosphere.
- **void setDynes(float value)** sets pressure in Dynes.
- **void setInchHg(float value)** sets pressure in inches mercury.
- **void setInchH2O(float value)** sets pressure in inches water.
- **void setPascal(float value)** sets pressure in Pascal. Note this is the **SI** unit.
- **void setTORR(float value)** sets pressure in TORR.
- **void setCmHg(float value)** sets pressure in centimetre mercury.
- **void setCmH2O(float value)** sets pressure in centimetre water.
- **void setMSW(float value)** sets pressure in Meters of Sea Water. (under water pressure unit).
2022-11-22 14:57:22 +01:00
#### Getters
2021-11-26 09:30:38 +01:00
- **float getMilliBar()** returns pressure in milliBar.
- **float getBar()** returns pressure in bar.
- **float getPSI()** returns pressure in PSI = Pounds per Square Inch.
- **float getATM()** returns pressure in Atmosphere.
- **float getDynes()** returns pressure in Dynes.
- **float getInchHg()** returns pressure in inches mercury.
- **float getInchH2O()** returns pressure in inches water.
- **float getPascal()** returns pressure in Pascal. Note this is the **SI** unit.
- **float getTORR()** returns pressure in TORR.
- **float getCmHg()** returns pressure in centimetre mercury.
- **float getCmH2O()** returns pressure in centimetre water.
- **float getMSW()** returns pressure in Meters of Sea Water. (under water pressure unit).
2021-12-23 22:50:26 +01:00
#### Gas law (experimental see below)
2022-11-22 14:57:22 +01:00
The **change()** function is applied to the current internal pressure.
2023-02-24 12:53:57 +01:00
All these functions return pressure in milliBar.
2022-11-22 14:57:22 +01:00
2023-02-24 12:53:57 +01:00
- **float change(float T1, float T2, float V1, float V2, float N1, float N2)**
2022-11-22 14:57:22 +01:00
- apply changing temperature (**Kelvin**),
- volume (m3) and moles.
- If an parameter does not change fill in 1 for both before (T1,V1, N1) and after (T2,V2,n2).
2023-02-24 12:53:57 +01:00
- **float changeTemperature(float T1, float T2)** only change temperature. T in **Kelvin**.
- **float changeVolume(float V1, float V2)** only change volume.
- **float changeMole(float N1, float N2)** only change moles.
2021-12-23 22:50:26 +01:00
2022-11-22 14:57:22 +01:00
#### Constants
2021-11-26 11:22:33 +01:00
2022-11-22 14:57:22 +01:00
The library has a number of constants to convert units. See the pressure.h file.
2021-11-26 11:22:33 +01:00
These constants can be used to write specific convertors or define specific constants.
A dedicated conversion is faster as it has only one float multiplication runtime.
2023-02-24 12:53:57 +01:00
The constants will multiply compile time!
2021-11-26 11:22:33 +01:00
```cpp
inline float PSI2MSW(float value)
{
return value * (PSI2MILLIBAR * MILLIBAR2MSW);
}
```
or
```cpp
#define PSI2MSW (PSI2MILLIBAR * MILLIBAR2MSW)
...
2023-02-24 12:53:57 +01:00
float out = in * PSI2MSW;
2021-11-26 11:22:33 +01:00
```
2021-11-26 09:30:38 +01:00
## Operation
```cpp
pressure P;
...
P.setDynes(1000);
Serial.print("mBar: ");
Serial.println(P.getMilliBar()); // 1000 Dynes in mBar
Serial.print("TORR: ");
Serial.println(P.getTORR()); // 1000 Dynes in Torr
```
2023-02-24 12:53:57 +01:00
#### Experimental
2021-11-26 11:22:33 +01:00
2023-02-24 12:53:57 +01:00
Note: names changed in 0.3.0
2021-11-26 11:22:33 +01:00
2021-11-26 09:30:38 +01:00
2023-02-24 12:53:57 +01:00
Apply the ideal gas law : **(P x V) / (n x T) = Constant**
2021-12-23 22:50:26 +01:00
2023-02-24 12:53:57 +01:00
- **float change(float T1, float T2, float V1, float V2, float N1, float N2)**
2021-12-23 22:50:26 +01:00
- T (temperature) in Kelvin,
- V (volume) in identical units,
- N (# atoms) in mole
2023-02-24 12:53:57 +01:00
- wrapper around next three.
- **float changeTemperature(float T1, float T2)** only change temperature. T in Kelvin.
- **float changeVolume(float V1, float V2)** only change volume.
- **float changeMole(float N1, float N2)** only change moles.
2021-12-23 22:50:26 +01:00
in code
```cpp
2023-02-24 12:53:57 +01:00
pressure P;
2021-12-23 22:50:26 +01:00
P.setPressure(...);
2023-02-24 12:53:57 +01:00
P.change(T1, T2, V1, V2, N1, N2); // apply all changes.
2021-12-23 22:50:26 +01:00
x = P.getPressure()
```
2023-02-24 12:53:57 +01:00
Some temperature converters
2021-12-23 22:50:26 +01:00
2022-11-22 14:57:22 +01:00
```cpp
2021-12-23 22:50:26 +01:00
Kelvin = Celsius + 273.15;
Kelvin = (Fahrenheit - 32) \* 5 / 9 + 273.15;
Kelvin = Fahrenheit \* 5 / 9 + 290.93; // one operator less.
2022-11-22 14:57:22 +01:00
```
2021-12-23 22:50:26 +01:00
2021-11-26 09:30:38 +01:00
## Future
2023-02-24 12:53:57 +01:00
#### Must
2021-11-26 09:30:38 +01:00
- update documentation
2023-02-24 12:53:57 +01:00
- find a good reference for conversion constants.
- https://www.semicore.com/reference/pressure-conversion-reference
2022-11-22 14:57:22 +01:00
2023-02-24 12:53:57 +01:00
#### Should
2022-11-22 14:57:22 +01:00
2021-12-23 22:50:26 +01:00
- test with gas law.
2023-02-24 12:53:57 +01:00
#### Could
- **float AddMillibar(float value)** simple math with all units (12x)
- ```return _pressure += value * factor;```
- does **subtractMillibar()** make more sense?
- **float setMillibar(float value)** return pressure in millibar all setters
- ```return _pressure = value * factor;```
#### Wont (unless requested)
- **float changeTC(float T1, float T2)** only change temperature, T in Celsius.
- **float changeTF(float T1, float T2)** only change temperature, T in Fahrenheit.
- move code to .cpp file
- rename parameters so they make more sense? (simple enough)
2022-11-22 14:57:22 +01:00
```
void setMilliBar(float milliBar ) { _pressure = milliBar; };
void setBar(float Bar) { _pressure = Bar * BAR2MILLIBAR; };
void setPSI(float PSI) { _pressure = PSI * PSI2MILLIBAR; };
```
2023-02-24 12:53:57 +01:00
- defaults for functions?
- none <<<<<<<<<<<<<<<<<<<<<<<<<<<
- 0 like constructor?
- 1 to get conversion constant?