ESPHome 2025.12.2
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 if (this->raw_callback_) {
80 this->raw_callback_->call(state);
81 }
82
83 ESP_LOGV(TAG, "'%s': Received new state %f", this->name_.c_str(), state);
84
85 if (this->filter_list_ == nullptr) {
87 } else {
88 this->filter_list_->input(state);
89 }
90}
91
92void Sensor::add_on_state_callback(std::function<void(float)> &&callback) { this->callback_.add(std::move(callback)); }
93void Sensor::add_on_raw_state_callback(std::function<void(float)> &&callback) {
94 if (!this->raw_callback_) {
95 this->raw_callback_ = make_unique<CallbackManager<void(float)>>();
96 }
97 this->raw_callback_->add(std::move(callback));
98}
99
101 // inefficient, but only happens once on every sensor setup and nobody's going to have massive amounts of
102 // filters
103 ESP_LOGVV(TAG, "Sensor(%p)::add_filter(%p)", this, filter);
104 if (this->filter_list_ == nullptr) {
105 this->filter_list_ = filter;
106 } else {
107 Filter *last_filter = this->filter_list_;
108 while (last_filter->next_ != nullptr)
109 last_filter = last_filter->next_;
110 last_filter->initialize(this, filter);
111 }
112 filter->initialize(this, nullptr);
113}
114void Sensor::add_filters(std::initializer_list<Filter *> filters) {
115 for (Filter *filter : filters) {
116 this->add_filter(filter);
117 }
118}
119void Sensor::set_filters(std::initializer_list<Filter *> filters) {
120 this->clear_filters();
121 this->add_filters(filters);
122}
124 if (this->filter_list_ != nullptr) {
125 ESP_LOGVV(TAG, "Sensor(%p)::clear_filters()", this);
126 }
127 this->filter_list_ = nullptr;
128}
129float Sensor::get_state() const { return this->state; }
130float Sensor::get_raw_state() const { return this->raw_state; }
131
133 this->set_has_state(true);
134 this->state = state;
135 ESP_LOGD(TAG, "'%s': Sending state %.5f %s with %d decimals of accuracy", this->get_name().c_str(), state,
136 this->get_unit_of_measurement_ref().c_str(), this->get_accuracy_decimals());
137 this->callback_.call(state);
138#if defined(USE_SENSOR) && defined(USE_CONTROLLER_REGISTRY)
140#endif
141}
142
143} // namespace sensor
144} // 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:72
void set_has_state(bool state)
Definition entity_base.h:96
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:100
void publish_state(float state)
Publish a new state to the front-end.
Definition sensor.cpp:77
void internal_send_state_to_frontend(float state)
Definition sensor.cpp:132
float get_raw_state() const
Getter-syntax for .raw_state.
Definition sensor.cpp:130
CallbackManager< void(float)> callback_
Storage for filtered state callbacks.
Definition sensor.h:129
float get_state() const
Getter-syntax for .state.
Definition sensor.cpp:129
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:92
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
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:123
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_
std::unique_ptr< CallbackManager< void(float)> > raw_callback_
Storage for raw state callbacks (lazy allocated).
Definition sensor.h:128
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:93
void set_filters(std::initializer_list< Filter * > filters)
Clear the filters and replace them by filters.
Definition sensor.cpp:119
void add_filters(std::initializer_list< Filter * > filters)
Add a list of vectors to the back of the filter chain.
Definition sensor.cpp:114
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