mirror of
https://github.com/esphome/esphome.git
synced 2025-10-26 12:43:48 +00:00
[mlx90393] Fix inverted gain and resolution. Expose temperature_compensation and hallconf. (#7635)
Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com>
This commit is contained in:
@@ -1,20 +1,21 @@
|
||||
from esphome import pins
|
||||
import esphome.codegen as cg
|
||||
import esphome.config_validation as cv
|
||||
from esphome.components import i2c, sensor
|
||||
import esphome.config_validation as cv
|
||||
from esphome.const import (
|
||||
CONF_FILTER,
|
||||
CONF_GAIN,
|
||||
CONF_ID,
|
||||
UNIT_MICROTESLA,
|
||||
UNIT_CELSIUS,
|
||||
STATE_CLASS_MEASUREMENT,
|
||||
CONF_OVERSAMPLING,
|
||||
CONF_RESOLUTION,
|
||||
CONF_TEMPERATURE,
|
||||
CONF_TEMPERATURE_COMPENSATION,
|
||||
ICON_MAGNET,
|
||||
ICON_THERMOMETER,
|
||||
CONF_GAIN,
|
||||
CONF_RESOLUTION,
|
||||
CONF_OVERSAMPLING,
|
||||
CONF_FILTER,
|
||||
CONF_TEMPERATURE,
|
||||
STATE_CLASS_MEASUREMENT,
|
||||
UNIT_CELSIUS,
|
||||
UNIT_MICROTESLA,
|
||||
)
|
||||
from esphome import pins
|
||||
|
||||
CODEOWNERS = ["@functionpointer"]
|
||||
DEPENDENCIES = ["i2c"]
|
||||
@@ -26,30 +27,46 @@ MLX90393Component = mlx90393_ns.class_(
|
||||
)
|
||||
|
||||
GAIN = {
|
||||
"1X": 7,
|
||||
"1_33X": 6,
|
||||
"1_67X": 5,
|
||||
"2X": 4,
|
||||
"2_5X": 3,
|
||||
"3X": 2,
|
||||
"4X": 1,
|
||||
"5X": 0,
|
||||
"1X": 0,
|
||||
"1_25X": 1,
|
||||
"1_67X": 2,
|
||||
"2X": 3,
|
||||
"2_5X": 4,
|
||||
"3X": 5,
|
||||
"3_75X": 6,
|
||||
"5X": 7,
|
||||
}
|
||||
|
||||
RESOLUTION = {
|
||||
"16BIT": 0,
|
||||
"17BIT": 1,
|
||||
"18BIT": 2,
|
||||
"19BIT": 3,
|
||||
"DIV_8": 3,
|
||||
"DIV_4": 2,
|
||||
"DIV_2": 1,
|
||||
"DIV_1": 0,
|
||||
}
|
||||
|
||||
CONF_X_AXIS = "x_axis"
|
||||
CONF_Y_AXIS = "y_axis"
|
||||
CONF_Z_AXIS = "z_axis"
|
||||
CONF_DRDY_PIN = "drdy_pin"
|
||||
CONF_HALLCONF = "hallconf"
|
||||
|
||||
|
||||
def mlx90393_axis_schema(default_resolution: str):
|
||||
def _validate(config):
|
||||
if config[CONF_TEMPERATURE_COMPENSATION]:
|
||||
for axis in [CONF_X_AXIS, CONF_Y_AXIS, CONF_Z_AXIS]:
|
||||
if axis not in config:
|
||||
continue
|
||||
if (res := config[axis][CONF_RESOLUTION]) in [
|
||||
"DIV_8",
|
||||
"DIV_4",
|
||||
]:
|
||||
raise cv.Invalid(
|
||||
f"{axis}: {CONF_RESOLUTION} cannot be {res} with {CONF_TEMPERATURE_COMPENSATION} enabled"
|
||||
)
|
||||
return config
|
||||
|
||||
|
||||
def mlx90393_axis_schema():
|
||||
return sensor.sensor_schema(
|
||||
unit_of_measurement=UNIT_MICROTESLA,
|
||||
accuracy_decimals=0,
|
||||
@@ -58,7 +75,7 @@ def mlx90393_axis_schema(default_resolution: str):
|
||||
).extend(
|
||||
cv.Schema(
|
||||
{
|
||||
cv.Optional(CONF_RESOLUTION, default=default_resolution): cv.enum(
|
||||
cv.Optional(CONF_RESOLUTION, default="DIV_4"): cv.enum(
|
||||
RESOLUTION, upper=True, space="_"
|
||||
)
|
||||
}
|
||||
@@ -66,19 +83,19 @@ def mlx90393_axis_schema(default_resolution: str):
|
||||
)
|
||||
|
||||
|
||||
CONFIG_SCHEMA = (
|
||||
CONFIG_SCHEMA = cv.All(
|
||||
cv.Schema(
|
||||
{
|
||||
cv.GenerateID(): cv.declare_id(MLX90393Component),
|
||||
cv.Optional(CONF_GAIN, default="2_5X"): cv.enum(
|
||||
GAIN, upper=True, space="_"
|
||||
),
|
||||
cv.Optional(CONF_GAIN, default="1X"): cv.enum(GAIN, upper=True, space="_"),
|
||||
cv.Optional(CONF_DRDY_PIN): pins.gpio_input_pin_schema,
|
||||
cv.Optional(CONF_OVERSAMPLING, default=2): cv.int_range(min=0, max=3),
|
||||
cv.Optional(CONF_OVERSAMPLING, default=0): cv.int_range(min=0, max=3),
|
||||
cv.Optional(CONF_FILTER, default=6): cv.int_range(min=0, max=7),
|
||||
cv.Optional(CONF_X_AXIS): mlx90393_axis_schema("19BIT"),
|
||||
cv.Optional(CONF_Y_AXIS): mlx90393_axis_schema("19BIT"),
|
||||
cv.Optional(CONF_Z_AXIS): mlx90393_axis_schema("16BIT"),
|
||||
cv.Optional(CONF_X_AXIS): mlx90393_axis_schema(),
|
||||
cv.Optional(CONF_Y_AXIS): mlx90393_axis_schema(),
|
||||
cv.Optional(CONF_Z_AXIS): mlx90393_axis_schema(),
|
||||
cv.Optional(CONF_TEMPERATURE_COMPENSATION, default=False): bool,
|
||||
cv.Optional(CONF_HALLCONF, default=0xC): cv.one_of(0xC, 0x0),
|
||||
cv.Optional(CONF_TEMPERATURE): sensor.sensor_schema(
|
||||
unit_of_measurement=UNIT_CELSIUS,
|
||||
accuracy_decimals=1,
|
||||
@@ -96,7 +113,8 @@ CONFIG_SCHEMA = (
|
||||
},
|
||||
)
|
||||
.extend(cv.polling_component_schema("60s"))
|
||||
.extend(i2c.i2c_device_schema(0x0C))
|
||||
.extend(i2c.i2c_device_schema(0x0C)),
|
||||
_validate,
|
||||
)
|
||||
|
||||
|
||||
@@ -111,6 +129,8 @@ async def to_code(config):
|
||||
cg.add(var.set_gain(GAIN[config[CONF_GAIN]]))
|
||||
cg.add(var.set_oversampling(config[CONF_OVERSAMPLING]))
|
||||
cg.add(var.set_filter(config[CONF_FILTER]))
|
||||
cg.add(var.set_temperature_compensation(config[CONF_TEMPERATURE_COMPENSATION]))
|
||||
cg.add(var.set_hallconf(config[CONF_HALLCONF]))
|
||||
|
||||
if CONF_X_AXIS in config:
|
||||
sens = await sensor.new_sensor(config[CONF_X_AXIS])
|
||||
|
||||
Reference in New Issue
Block a user