NDEVR
API Documentation
TemperatureSensor.h
1/*--------------------------------------------------------------------------------------------
2Copyright (c) 2019, NDEVR LLC
3tyler.parke@ndevr.org
4 __ __ ____ _____ __ __ _______
5 | \ | | | __ \ | ___|\ \ / / | __ \
6 | \ | | | | \ \ | |___ \ \ / / | |__) |
7 | . \| | | |__/ / | |___ \ V / | _ /
8 | |\ |_|_____/__|_____|___\_/____| | \ \
9 |__| \__________________________________| \__\
10
11Subject to the terms of the Enterprise+ Agreement, NDEVR hereby grants
12Licensee a limited, non-exclusive, non-transferable, royalty-free license
13(without the right to sublicense) to use the API solely for the purpose of
14Licensee's internal development efforts to develop applications for which
15the API was provided.
16
17The above copyright notice and this permission notice shall be included in all
18copies or substantial portions of the Software.
19
20THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
21INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
22PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
23FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
24OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
25DEALINGS IN THE SOFTWARE.
26
27Library: Hardware
28File: TemperatureSensor
29Included in API: True
30Author(s): Tyler Parke
31 *-----------------------------------------------------------------------------------------**/
32#pragma once
33#include <NDEVR/Device.h>
34namespace NDEVR
35{
97}
A specification of upper and lower bounds in N-dimensions.
Definition Bounds.hpp:54
Device(const Model &model, LogPtr log, QObject *parent=nullptr)
Constructs a Device from a Model with the given log and optional Qt parent.
A light-weight wrapper that will be a no-op if there is not a valid log reference,...
A core class that represents a node on model hierarchy.
Definition Model.h:292
TemperatureSensor(const Model &name, LogPtr log, QObject *parent=nullptr)
Constructs a TemperatureSensor with the given model, log, and optional parent.
void setNoWarningRange(const Bounds< 1, fltp08 > &range)
Sets the temperature range within which no warning is raised.
virtual TemperatureState temperatureState(fltp08 temp) const
Returns the temperature state for a given temperature value.
fltp08 temperature() const
Returns the current temperature reading.
Bounds< 1, fltp08 > noCriticalRange()
Returns the no-critical temperature range.
fltp08 m_temperature
The current temperature reading.
virtual TemperatureState temperatureState() const
Returns the current temperature state based on the last reading and configured ranges.
Bounds< 1, fltp08 > validRange()
Returns the valid temperature range.
Bounds< 1, fltp08 > m_no_critical_range
The temperature range within which no critical alert is raised.
void setTemperature(fltp08 temperature)
Sets the current temperature reading.
void setValidRange(const Bounds< 1, fltp08 > &range)
Sets the valid temperature range.
Bounds< 1, fltp08 > m_valid_range
The valid temperature range; readings outside are invalid.
Bounds< 1, fltp08 > noWarningRange()
Returns the no-warning temperature range.
void setNoCriticalRange(const Bounds< 1, fltp08 > &range)
Sets the temperature range within which no critical alert is raised.
Bounds< 1, fltp08 > m_no_warning_range
The temperature range within which no warning is raised.
TemperatureState
Describes the current temperature state relative to configured thresholds.
@ e_temperature_critical
The temperature has exceeded the critical threshold.
@ e_temperature_warning
The temperature is approaching a critical threshold.
@ e_temperature_invalid
The temperature reading is outside the valid range.
@ e_temperature_unknown
The temperature has not been read or is unavailable.
@ e_temperature_good
The temperature is within acceptable operating limits.
The primary namespace for the NDEVR SDK.
double fltp08
Defines an alias representing an 8 byte floating-point number.