Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dim to warm #452

Draft
wants to merge 37 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 10 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
9dfb839
untested
th3w1zard1 Mar 18, 2023
f3b2e20
don't update brightness if dim_to_warm is set
th3w1zard1 Mar 18, 2023
314d49d
ensure brightness is a feature of lightbulb
th3w1zard1 Mar 18, 2023
0f7fb92
fixed equation
th3w1zard1 Mar 18, 2023
256bb5d
fixed a typo
th3w1zard1 Mar 18, 2023
aebe5d5
fixed a typo
th3w1zard1 Mar 18, 2023
2fb5010
changed source for max/min brightness
th3w1zard1 Mar 18, 2023
e1b9a28
derp moment
th3w1zard1 Mar 18, 2023
bf49721
formatting
th3w1zard1 Mar 18, 2023
e17a89b
formatting
th3w1zard1 Mar 18, 2023
c4d8499
Update strings.json
th3w1zard1 Mar 22, 2023
8c56bc7
Update strings.json
th3w1zard1 Mar 22, 2023
dbcb154
Ran pre-commit
th3w1zard1 Mar 22, 2023
b7520bd
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Mar 22, 2023
6ba511b
More pre-commit nonsense.
th3w1zard1 Mar 22, 2023
afbe85a
Merge branch 'dim-to-warm' of https://github.com/th3w1zard1/adaptive-…
th3w1zard1 Mar 22, 2023
7d6064e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Mar 22, 2023
e27c5d5
More pre-commit nonsense
th3w1zard1 Mar 22, 2023
ab96ac0
Merge branch 'dim-to-warm' of https://github.com/th3w1zard1/adaptive-…
th3w1zard1 Mar 22, 2023
94064fc
Fix variable scope.
th3w1zard1 Mar 25, 2023
4f1312c
use update_entity for ensured functionality
th3w1zard1 Mar 25, 2023
7589ea3
merge upstream/master
th3w1zard1 Mar 25, 2023
8731b2f
Merge branch 'master' into dim-to-warm
th3w1zard1 Mar 27, 2023
d0f6810
Merge remote-tracking branch 'upstream/master' into dim-to-warm
th3w1zard1 Mar 27, 2023
8549525
Fix brightness being null while light is off.
th3w1zard1 Mar 28, 2023
c24c553
Added `dim_to_warm_brightness_check`
th3w1zard1 Mar 30, 2023
efdc652
Use difference of both ct calcs.
th3w1zard1 Mar 30, 2023
22356a8
brightness check is more strict
th3w1zard1 Mar 30, 2023
5b018bb
merge upstream/master
th3w1zard1 Mar 30, 2023
98f4c36
merge origin/main
th3w1zard1 Apr 10, 2023
89f131b
pass the flake8 test
th3w1zard1 Apr 10, 2023
2cd478c
fixes and cleanup
th3w1zard1 Apr 10, 2023
5d0352f
Update switch.py
th3w1zard1 Apr 10, 2023
be9defb
fix everything
th3w1zard1 Apr 10, 2023
5dbadcd
cleanup
th3w1zard1 Apr 10, 2023
28364bf
whoops
th3w1zard1 Apr 10, 2023
5237735
Update switch.py
th3w1zard1 Apr 10, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions custom_components/adaptive_lighting/const.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@
CONF_MIN_SUNSET_TIME = "min_sunset_time"
CONF_TAKE_OVER_CONTROL, DEFAULT_TAKE_OVER_CONTROL = "take_over_control", True
CONF_TRANSITION, DEFAULT_TRANSITION = "transition", 45
CONF_DIM_TO_WARM, DEFAULT_DIM_TO_WARM = "dim_to_warm", False

SLEEP_MODE_SWITCH = "sleep_mode_switch"
ADAPT_COLOR_SWITCH = "adapt_color_switch"
Expand Down Expand Up @@ -111,6 +112,7 @@ def int_between(min_int, max_int):
(CONF_SEPARATE_TURN_ON_COMMANDS, DEFAULT_SEPARATE_TURN_ON_COMMANDS, bool),
(CONF_SEND_SPLIT_DELAY, DEFAULT_SEND_SPLIT_DELAY, int_between(0, 10000)),
(CONF_ADAPT_DELAY, DEFAULT_ADAPT_DELAY, int_between(0, 10000)),
(CONF_DIM_TO_WARM, DEFAULT_DIM_TO_WARM, bool),
]


Expand Down
3 changes: 2 additions & 1 deletion custom_components/adaptive_lighting/strings.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,8 @@
"take_over_control": "take_over_control: If anything but Adaptive Lighting calls 'light.turn_on' when a light is already on, stop adapting that light until it (or the switch) toggles off -> on.",
"detect_non_ha_changes": "detect_non_ha_changes: detects all >10% changes made to the lights (also outside of HA), requires 'take_over_control' to be enabled (calls 'homeassistant.update_entity' every 'interval'!)",
"transition": "Transition time when applying a change to the lights (seconds)",
"adapt_delay": "adapt_delay: wait time between light turn on (seconds), and Adaptive Lights applying changes to the light state. May avoid flickering."
"adapt_delay": "adapt_delay: wait time between light turn on (seconds), and Adaptive Lights applying changes to the light state. May avoid flickering.",
"dim to warm": "dim_to_warm: Adjust color temperature even further on a parabolic curve depending on the current brightness of the light. Does not work with take_over_control"
th3w1zard1 marked this conversation as resolved.
Show resolved Hide resolved
}
}
},
Expand Down
29 changes: 29 additions & 0 deletions custom_components/adaptive_lighting/switch.py
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@
ATTR_TURN_ON_OFF_LISTENER,
CONF_ADAPT_DELAY,
CONF_DETECT_NON_HA_CHANGES,
CONF_DIM_TO_WARM,
CONF_INITIAL_TRANSITION,
CONF_INTERVAL,
CONF_LIGHTS,
Expand Down Expand Up @@ -568,6 +569,7 @@ def __init__(
self._lights = data[CONF_LIGHTS]

self._detect_non_ha_changes = data[CONF_DETECT_NON_HA_CHANGES]
self._dim_to_warm = data[CONF_DIM_TO_WARM]
self._initial_transition = data[CONF_INITIAL_TRANSITION]
self._sleep_transition = data[CONF_SLEEP_TRANSITION]
self._interval = data[CONF_INTERVAL]
Expand Down Expand Up @@ -830,6 +832,33 @@ async def _adapt_light(
max_kelvin = attributes["max_color_temp_kelvin"]
color_temp_kelvin = self._settings["color_temp_kelvin"]
color_temp_kelvin = max(min(color_temp_kelvin, max_kelvin), min_kelvin)
if self._dim_to_warm and "brightness" in features:
# uncomment these lines for easy debugging using light.turn_on outside of the integration.
#await self.hass.helpers.entity_component.async_update_entity(light)
#cur_state = self.hass.states.get(light)
#brightness = cur_state.attributes[ATTR_BRIGHTNESS]
#service_data[ATTR_BRIGHTNESS] = brightness
min_ct = self._sun_light_settings.min_color_temp # pylint: disable=protected-access
max_ct = color_temp_kelvin
max_brightness = self._sun_light_settings.max_brightness # pylint: disable=protected-access
min_brightness = self._sun_light_settings.min_brightness # pylint: disable=protected-access
max_brightness = max((max_brightness*2.55),brightness)
min_brightness = min((min_brightness*2.55),brightness)
# No max/min brightness attributes? Unfortunate.
#min_brightness = attributes["min_brightness"]
#max_brightness = attributes["max_brightness"]
_LOGGER.debug(
"Setting color temp using the following values in eq: max_brightness: %s, min_brightness: %s, max_ct: %s, min_ct: %s, brightness: %s",
max_brightness,
min_brightness,
max_ct,
min_ct,
brightness,
)
# y = a(x-h)^2+k where h,k is the vertex (255,6500) or (max_brightness,max_ct)
# a = (min_ct-max_ct)/(min_brightness-max_brightness)^2
# check: y = (1000-6500)/((1-h)^2)*(x-255)^2+6500 if x=2 then y=1043.221836 when min_brightness=1,max_brightness(h)=255,max_ct=6500,min_ct=1000
color_temp_kelvin = ((min_ct-max_ct)/(min_brightness-max_brightness)**2)*(brightness-max_brightness)**2+max_ct
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What is the reasoning behind this equation?

Do you perhaps have a graph or something that we can add to the README?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes! please look at the issue #78 I have a graph posted toward the bottom of the thread

service_data[ATTR_COLOR_TEMP_KELVIN] = color_temp_kelvin
elif "color" in features and adapt_color:
_LOGGER.debug("%s: Setting rgb_color of light %s", self._name, light)
Expand Down