ESPHome 2025.12.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 default:
49 return LOG_STR("");
50 }
51}
52
53Sensor::Sensor() : state(NAN), raw_state(NAN) {}
54
57 return this->accuracy_decimals_;
58 return 0;
59}
60void Sensor::set_accuracy_decimals(int8_t accuracy_decimals) {
61 this->accuracy_decimals_ = accuracy_decimals;
63}
64
66 this->state_class_ = state_class;
68}
74
76 this->raw_state = state;
77 if (this->raw_callback_) {
78 this->raw_callback_->call(state);
79 }
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 if (!this->raw_callback_) {
93 this->raw_callback_ = make_unique<CallbackManager<void(float)>>();
94 }
95 this->raw_callback_->add(std::move(callback));
96}
97
99 // inefficient, but only happens once on every sensor setup and nobody's going to have massive amounts of
100 // filters
101 ESP_LOGVV(TAG, "Sensor(%p)::add_filter(%p)", this, filter);
102 if (this->filter_list_ == nullptr) {
103 this->filter_list_ = filter;
104 } else {
105 Filter *last_filter = this->filter_list_;
106 while (last_filter->next_ != nullptr)
107 last_filter = last_filter->next_;
108 last_filter->initialize(this, filter);
109 }
110 filter->initialize(this, nullptr);
111}
112void Sensor::add_filters(std::initializer_list<Filter *> filters) {
113 for (Filter *filter : filters) {
114 this->add_filter(filter);
115 }
116}
117void Sensor::set_filters(std::initializer_list<Filter *> filters) {
118 this->clear_filters();
119 this->add_filters(filters);
120}
122 if (this->filter_list_ != nullptr) {
123 ESP_LOGVV(TAG, "Sensor(%p)::clear_filters()", this);
124 }
125 this->filter_list_ = nullptr;
126}
127float Sensor::get_state() const { return this->state; }
128float Sensor::get_raw_state() const { return this->raw_state; }
129
131 this->set_has_state(true);
132 this->state = state;
133 ESP_LOGD(TAG, "'%s': Sending state %.5f %s with %d decimals of accuracy", this->get_name().c_str(), state,
134 this->get_unit_of_measurement_ref().c_str(), this->get_accuracy_decimals());
135 this->callback_.call(state);
136#if defined(USE_SENSOR) && defined(USE_CONTROLLER_REGISTRY)
138#endif
139}
140
141} // namespace sensor
142} // 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:69
void set_has_state(bool state)
Definition entity_base.h:93
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:42
void set_state_class(StateClass state_class)
Manually set the state class.
Definition sensor.cpp:65
void add_filter(Filter *filter)
Add a filter to the filter chain. Will be appended to the back.
Definition sensor.cpp:98
void publish_state(float state)
Publish a new state to the front-end.
Definition sensor.cpp:75
void internal_send_state_to_frontend(float state)
Definition sensor.cpp:130
float get_raw_state() const
Getter-syntax for .raw_state.
Definition sensor.cpp:128
CallbackManager< void(float)> callback_
Storage for filtered state callbacks.
Definition sensor.h:128
float get_state() const
Getter-syntax for .state.
Definition sensor.cpp:127
void set_accuracy_decimals(int8_t accuracy_decimals)
Manually set the accuracy in decimals.
Definition sensor.cpp:60
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:116
StateClass get_state_class()
Get the state class, using the manual override if set.
Definition sensor.cpp:69
Filter * filter_list_
Store all active filters.
Definition sensor.h:130
float raw_state
This member variable stores the current raw state of the sensor, without any filters applied.
Definition sensor.h:122
int8_t get_accuracy_decimals()
Get the accuracy in decimals, using the manual override if set.
Definition sensor.cpp:55
void clear_filters()
Clear the entire filter chain.
Definition sensor.cpp:121
int8_t accuracy_decimals_
Accuracy in decimals (-1 = not set)
Definition sensor.h:133
StateClass state_class_
State class (STATE_CLASS_NONE = not set)
Definition sensor.h:134
bool get_force_update() const
Get whether force update mode is enabled.
Definition sensor.h:63
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:127
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:117
void add_filters(std::initializer_list< Filter * > filters)
Add a list of vectors to the back of the filter chain.
Definition sensor.cpp:112
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
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