ESPHome 2026.1.0-dev
Loading...
Searching...
No Matches
sensor.cpp
Go to the documentation of this file.
1#include "sensor.h"
4#include "esphome/core/log.h"
5
6namespace esphome {
7namespace sensor {
8
9static const char *const TAG = "sensor";
10
11// Function implementation of LOG_SENSOR macro to reduce code size
12void log_sensor(const char *tag, const char *prefix, const char *type, Sensor *obj) {
13 if (obj == nullptr) {
14 return;
15 }
16
17 ESP_LOGCONFIG(tag,
18 "%s%s '%s'\n"
19 "%s State Class: '%s'\n"
20 "%s Unit of Measurement: '%s'\n"
21 "%s Accuracy Decimals: %d",
22 prefix, type, obj->get_name().c_str(), prefix,
23 LOG_STR_ARG(state_class_to_string(obj->get_state_class())), prefix,
25
26 if (!obj->get_device_class_ref().empty()) {
27 ESP_LOGCONFIG(tag, "%s Device Class: '%s'", prefix, obj->get_device_class_ref().c_str());
28 }
29
30 if (!obj->get_icon_ref().empty()) {
31 ESP_LOGCONFIG(tag, "%s Icon: '%s'", prefix, obj->get_icon_ref().c_str());
32 }
33
34 if (obj->get_force_update()) {
35 ESP_LOGV(tag, "%s Force Update: YES", prefix);
36 }
37}
38
39const LogString *state_class_to_string(StateClass state_class) {
40 switch (state_class) {
42 return LOG_STR("measurement");
44 return LOG_STR("total_increasing");
46 return LOG_STR("total");
48 return LOG_STR("measurement_angle");
50 default:
51 return LOG_STR("");
52 }
53}
54
55Sensor::Sensor() : state(NAN), raw_state(NAN) {}
56
59 return this->accuracy_decimals_;
60 return 0;
61}
62void Sensor::set_accuracy_decimals(int8_t accuracy_decimals) {
63 this->accuracy_decimals_ = accuracy_decimals;
65}
66
68 this->state_class_ = state_class;
70}
76
78 this->raw_state = state;
79 this->raw_callback_.call(state);
80
81 ESP_LOGV(TAG, "'%s': Received new state %f", this->name_.c_str(), state);
82
83 if (this->filter_list_ == nullptr) {
85 } else {
86 this->filter_list_->input(state);
87 }
88}
89
90void Sensor::add_on_state_callback(std::function<void(float)> &&callback) { this->callback_.add(std::move(callback)); }
91void Sensor::add_on_raw_state_callback(std::function<void(float)> &&callback) {
92 this->raw_callback_.add(std::move(callback));
93}
94
96 // inefficient, but only happens once on every sensor setup and nobody's going to have massive amounts of
97 // filters
98 ESP_LOGVV(TAG, "Sensor(%p)::add_filter(%p)", this, filter);
99 if (this->filter_list_ == nullptr) {
100 this->filter_list_ = filter;
101 } else {
102 Filter *last_filter = this->filter_list_;
103 while (last_filter->next_ != nullptr)
104 last_filter = last_filter->next_;
105 last_filter->initialize(this, filter);
106 }
107 filter->initialize(this, nullptr);
108}
109void Sensor::add_filters(std::initializer_list<Filter *> filters) {
110 for (Filter *filter : filters) {
111 this->add_filter(filter);
112 }
113}
114void Sensor::set_filters(std::initializer_list<Filter *> filters) {
115 this->clear_filters();
116 this->add_filters(filters);
117}
119 if (this->filter_list_ != nullptr) {
120 ESP_LOGVV(TAG, "Sensor(%p)::clear_filters()", this);
121 }
122 this->filter_list_ = nullptr;
123}
124float Sensor::get_state() const { return this->state; }
125float Sensor::get_raw_state() const { return this->raw_state; }
126
128 this->set_has_state(true);
129 this->state = state;
130 ESP_LOGD(TAG, "'%s': Sending state %.5f %s with %d decimals of accuracy", this->get_name().c_str(), state,
131 this->get_unit_of_measurement_ref().c_str(), this->get_accuracy_decimals());
132 this->callback_.call(state);
133#if defined(USE_SENSOR) && defined(USE_CONTROLLER_REGISTRY)
135#endif
136}
137
138} // namespace sensor
139} // namespace esphome
static void notify_sensor_update(sensor::Sensor *obj)
StringRef get_device_class_ref() const
Get the device class as StringRef.
StringRef get_unit_of_measurement_ref() const
Get the unit of measurement as StringRef.
const StringRef & get_name() const
StringRef get_icon_ref() const
Definition entity_base.h:85
void set_has_state(bool state)
constexpr const char * c_str() const
Definition string_ref.h:69
constexpr bool empty() const
Definition string_ref.h:71
Apply a filter to sensor values such as moving average.
Definition filter.h:20
virtual void initialize(Sensor *parent, Filter *next)
Initialize this filter, please note this can be called more than once.
Definition filter.cpp:29
void input(float value)
Definition filter.cpp:14
Base-class for all sensors.
Definition sensor.h:43
void set_state_class(StateClass state_class)
Manually set the state class.
Definition sensor.cpp:67
void add_filter(Filter *filter)
Add a filter to the filter chain. Will be appended to the back.
Definition sensor.cpp:95
void publish_state(float state)
Publish a new state to the front-end.
Definition sensor.cpp:77
LazyCallbackManager< void(float)> callback_
Storage for filtered state callbacks.
Definition sensor.h:129
void internal_send_state_to_frontend(float state)
Definition sensor.cpp:127
float get_raw_state() const
Getter-syntax for .raw_state.
Definition sensor.cpp:125
float get_state() const
Getter-syntax for .state.
Definition sensor.cpp:124
void set_accuracy_decimals(int8_t accuracy_decimals)
Manually set the accuracy in decimals.
Definition sensor.cpp:62
void add_on_state_callback(std::function< void(float)> &&callback)
Add a callback that will be called every time a filtered value arrives.
Definition sensor.cpp:90
float state
This member variable stores the last state that has passed through all filters.
Definition sensor.h:117
StateClass get_state_class()
Get the state class, using the manual override if set.
Definition sensor.cpp:71
Filter * filter_list_
Store all active filters.
Definition sensor.h:131
float raw_state
This member variable stores the current raw state of the sensor, without any filters applied.
Definition sensor.h:123
LazyCallbackManager< void(float)> raw_callback_
Storage for raw state callbacks.
Definition sensor.h:128
int8_t get_accuracy_decimals()
Get the accuracy in decimals, using the manual override if set.
Definition sensor.cpp:57
void clear_filters()
Clear the entire filter chain.
Definition sensor.cpp:118
int8_t accuracy_decimals_
Accuracy in decimals (-1 = not set)
Definition sensor.h:134
StateClass state_class_
State class (STATE_CLASS_NONE = not set)
Definition sensor.h:135
bool get_force_update() const
Get whether force update mode is enabled.
Definition sensor.h:64
struct esphome::sensor::Sensor::SensorFlags sensor_flags_
void add_on_raw_state_callback(std::function< void(float)> &&callback)
Add a callback that will be called every time the sensor sends a raw value.
Definition sensor.cpp:91
void set_filters(std::initializer_list< Filter * > filters)
Clear the filters and replace them by filters.
Definition sensor.cpp:114
void add_filters(std::initializer_list< Filter * > filters)
Add a list of vectors to the back of the filter chain.
Definition sensor.cpp:109
uint16_t type
bool state
Definition fan.h:0
StateClass
Sensor state classes.
Definition sensor.h:29
@ STATE_CLASS_TOTAL
Definition sensor.h:33
@ STATE_CLASS_TOTAL_INCREASING
Definition sensor.h:32
@ STATE_CLASS_MEASUREMENT_ANGLE
Definition sensor.h:34
@ STATE_CLASS_MEASUREMENT
Definition sensor.h:31
void log_sensor(const char *tag, const char *prefix, const char *type, Sensor *obj)
Definition sensor.cpp:12
const LogString * state_class_to_string(StateClass state_class)
Definition sensor.cpp:39
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7