Помогите пожалуйста с подбором и настройкой оборудования для теплиц

//light1.js 
//'use strict';
var grow_box = "test1"; // CHANGE_ME! имя устройства. Выводится в заголовок окна и служит для разделения устройств
log.info("light_"+grow_box+"START######################"); //Это лог.

var dimmer_light = "wb-mdm3_42/Channel 1"; // CHANGE_ME! устройство-диммер То есть строка, которая определяет куда писать изменения мощности.
var dimmer_zeroValue = 1; //"0" диммера
var dimmer_maxValue = 95; //100% диммера

var dimmer_relay = "wb-mio-gpio_157:1/K3"; //CHANGE_ME! устройство-реле питания диммера (доработка, используемй диммер подтягивает свой вход к VCC)

var sensor_light = "wb-ms_41/Illuminance"; // CHANGE_ME! устройство-датчик освещенности

var ps = new PersistentStorage("storage_"+grow_box, {global: true});// Определим объект-хранилище.

var sunraiseStartTime; //Время начала "рассвета"
var sunraiseStopTime; //Время конца "рассвета"
var sunsetStartTime;//Время начала "заката"
var sunsetStopTime; //Длительность "заката"
var light_increment = 0; //Глобальная для хранения приращения освещенности
var setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
//var dimmer_increment = (dimmer_maxValue-dimmer_zeroValue)/400; //увеличение освещения в цикл расчетное на 0.25%
var dimmer_increment = (dimmer_maxValue-dimmer_zeroValue)/100; //увеличение освещения в цикл расчетное на 1%
setTimeVariable();

//Элементы виртуального устройства
//управления
var deviceCells = { 
  "Light_measured": {
    type: "text",
    value: "0"
  },
  "Lamp power set" : {
    type : "range",
    value : dimmer_zeroValue,
    min : dimmer_zeroValue,
    max : dimmer_maxValue
  },
  //Начало рассвета hh:mm
  "Sunraise (start) time": {
    type: "text",
    readonly: false,
    value: ps["sun_start_time"],
  },
  //Длительность рассвета
  "Sunraise duration": {
    type: "text",
    readonly: false,
    value: ps["sun_start_duration"],
  },
  //Начало заката hh:mm
  "Sunset (stop) time": {
    type: "text",
    readonly: false,
    value: ps["sun_stop_time"],
  },
  //Длительность заката
  "Sunset duration": {
    type: "text",
    readonly: false,
    value: ps["sun_stop_duration"],
  },
  "Light SetPoint": {
    type: "value",
    readonly: false,
    value: ps["light_setpoint"]
  },
  sunraiseProcess : {
          type : "switch",
          value : false,
  },   
  sunsetProcess : {
          type : "switch",
          value : false,
  },
  dayProcess : {
          type : "switch",
          value : false,
  },
};


//Создадим виртуальное устройство и добавим в него элементы 
  defineVirtualDevice("light_"+grow_box, {
    title:"Light of "+grow_box,
    cells: deviceCells
  });

defineRule("Sunraise start time change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunraise (start) time", //при изменении поля времени начала рассвета запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunraise start time ", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_start_time"] = newValue;
    setTimeVariable();
  }
});

defineRule("Sunraise duration change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunraise duration", //при изменении поля времени начала рассвета запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunraise duration", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_start_duration"] = newValue;
    setTimeVariable();
  }
});

defineRule("Sunset start time change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunset (stop) time", //при изменении поля времени начала ЗАКАТА запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunset (stop) time ", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_stop_time"] = newValue;
    setTimeVariable();
  }
});

defineRule("Sunset duration change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunset duration", //при изменении поля времени начала рассвета запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunset duration", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_stop_duration"] = newValue;
    setTimeVariable();
  }
});

defineRule("Light SetPoint change", { //название правила 
whenChanged: "light_"+grow_box+"/Light SetPoint", //при уставки желаемой освещенности -запишем в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/light_setpoint ", newValue); //Это лог. Он попадает в /var/log/messages
    ps["light_setpoint"] = newValue;
    setPointLight = Number(newValue);
  }
});

defineRule("dayProcess change", { //название правила 
whenChanged: "light_"+grow_box+"/dayProcess", // Для режима "День"
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    if (newValue){ //Включаем "день"
    //log.info("light_"+grow_box+"/light_setpoint ", newValue); //Это лог. Он попадает в /var/log/messages
      dev["light_"+grow_box+"/sunraiseProcess"] = false; //Выключаем "рассвет" Таймер остановит правило "SunRaise_starter"
      //dev["light_"+grow_box+"/sunsetProcess"] = false; //Выключаем "закат" Таймер остановит правило "SunSet_starter"
      setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
    }else{
      //dev[dimmer_light] = dimmer_zeroValue;
    }
  }
});

//*Дополнение для реле диммера
defineRule("dimmer_change", { //название правила 
whenChanged: "light_"+grow_box+"/Lamp power set", //При изменении мощности диммера - проверим и включим реле
  then: function (newValue, devName, cellName) { //выполняй следующие действия
  if ((newValue>dimmer_zeroValue)&&(dev[dimmer_relay] == false)){ //Если диммер уже включен а реле выключено
    dev[dimmer_relay] = true; //включаем реле
  }
  if ((newValue<=dimmer_zeroValue)&&(dev[dimmer_relay] == true)){ //Если диммер на минимуме а реле включено
    dev[dimmer_relay] = false; //вЫключаем реле
  }
}
});  
//*Конец дополнения

defineRule("sensor_light change", { //название правила 
whenChanged: sensor_light, //При изменении измеренной освещенности - установим значения виртуального устройства.
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    dev["light_"+grow_box]["Light_measured"] = newValue;
    if ((dev["light_"+grow_box]["sunraiseProcess"]==true)||(dev["light_"+grow_box]["dayProcess"]==true)||(dev["light_"+grow_box]["sunsetProcess"]==true)){// если сейчас нужен свет
      newValue = Number(newValue); //Приведем к числу
      if (newValue>setPointLight) { // Если текущая освещенность больше уставки
        //log.info("light_"+grow_box+"Light_measured BIG",newValue);
        if (dev[dimmer_light]>dimmer_zeroValue){
          dev[dimmer_light] -= dimmer_increment;
        }
      } else{ // если меньше
        //log.info("light_"+grow_box+"Light_measured LOW",newValue);
        if (dev[dimmer_light]<dimmer_maxValue){
          dev[dimmer_light] += dimmer_increment;
        }
      }
      dev["light_"+grow_box+"/Lamp power set"] = dev[dimmer_light];
    }
  }
});


defineRule("cron minute timer", { //Просто задание, которое выполняется каждую минуту и взводит/опускает флаги "Рассвет", "Закат"
  when: cron("00 * * * * *"),
  then: function () {
    //log.info(grow_box, "cron timer executed! DEBUG ONLY.");
    d = new Date(); //Текущее время
    //sunraiseStartTime 
    if ((dev["light_"+grow_box]["sunraiseProcess"]==false) && (d > sunraiseStartTime) && (d<sunraiseStopTime)){
      log.info(grow_box, "cron timer executed! Sunraise process START", "sunraiseStartTime",sunraiseStartTime ,"sunraiseStopTime",sunraiseStopTime);
      dev["light_"+grow_box]["sunraiseProcess"] = true;
    }
    //sunsetStartTime
    if ((dev["light_"+grow_box]["sunsetProcess"]==false) && (d > sunsetStartTime) && (d<sunsetStopTime)){
      log.info(grow_box, "cron timer executed! SunSET process START", "sunsetStartTime",sunsetStartTime ,"sunsetStopTime",sunsetStopTime);
      dev["light_"+grow_box]["sunsetProcess"] = true;
    }
    //dayProcess
    if ((dev["light_"+grow_box]["dayProcess"]==false) && (d > sunraiseStopTime) && (d<sunsetStartTime)){
      log.info(grow_box, "cron timer executed! DAY process START","sunraiseStopTime",sunraiseStopTime,"sunsetStartTime",sunsetStartTime);
      dev["light_"+grow_box]["dayProcess"] = true;
    }
  }
});

defineRule("cron day timer", { //Просто задание, которое выполняется раз в сутки и меняет дату в переменных на текущую.
  when: cron("01 00 00 * * *"),
  then: function () {
    setTimeVariable();
  }
});

function string_to_time(srcString) { 
  //log.info("string_to_time_"+grow_box, srcString)
  var d = new Date();
  var datetime = new Date(d.getFullYear()+'-'+(d.getMonth()+1)+'-'+d.getDate()+'T' + srcString + 'Z');
  datetime.setMinutes(datetime.getMinutes() + datetime.getTimezoneOffset());//Приведем к локальному:
  return datetime; 
};


function setTimeVariable() { 
  sunraiseStartTime = string_to_time(ps["sun_start_time"]); //Время начала "рассвета"
  sunraiseStopTime = new Date(sunraiseStartTime);
  sunraiseStopTime.setMinutes(sunraiseStopTime.getMinutes() + parseInt(ps["sun_start_duration"])); //окончание "рассвета"
  sunsetStartTime = string_to_time(ps["sun_stop_time"]);//Время начала "заката"
  sunsetStopTime = new Date(sunsetStartTime);
  sunsetStopTime.setMinutes(sunsetStopTime.getMinutes() + parseInt(ps["sun_stop_duration"])); //окончание "заката"
};


defineRule("SunRaise_starter", { //название правила 
whenChanged: "light_"+grow_box+"/sunraiseProcess", //При изменении переуключателя "рассвет"
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+" sunraiseProcess function", newValue, devName, cellName); //Это лог.
    if (newValue){ //Запускаем "рассвет"
      dura = (sunraiseStopTime - sunraiseStartTime)/1000; //время в секундах
      setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
      light_increment = setPointLight/dura; //увеличение освещенности в секунду расчетное
      setPointLight = 1;
	  log.info("light_"+grow_box+" sunraiseProcess", "dura", dura, "dimmer_increment", dimmer_increment); //Это лог.
      startTicker(grow_box+"raiseTicker", 1000); //Запуск таймера, отрабатывает раз в секунду.
    } else { //Останавливаем "рассвет"
      timers[grow_box+"raiseTicker"].stop(); 
      log.info("light_"+grow_box+"Ticker STOP sunraise");
    }
  }
});

defineRule("SunSet_starter", { //название правила 
whenChanged: "light_"+grow_box+"/sunsetProcess", //При изменении переуключателя "Закат"
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+" sunsetProcess function", newValue, devName, cellName); //Это лог.
    if (newValue){ //Запускаем "закат"
      dev["light_"+grow_box]["dayProcess"] = false;
      setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
      dura = (sunsetStopTime - sunsetStartTime)/1000; //время в секундах
      light_increment = -(setPointLight)/dura; //уменьшение освещения в секунду расчетное. От уставки!
      //dev["light_"+grow_box+"/dayProcess"] = false; //Выключаем "день"
	  log.info("light_"+grow_box+" sunsetProcess", "dura", dura, "light_increment", light_increment, "setPointLight", setPointLight); //Это лог.
      startTicker(grow_box+"raiseTicker", 1000); //Запуск таймера, отрабатывает раз в секунду.
    } else { //Останавливаем "закат"
      timers[grow_box+"raiseTicker"].stop(); 
      log.info("light_"+grow_box+"Ticker STOP sunset");
      setPointLight = 0;
      dev[dimmer_light] = dimmer_zeroValue;
    }
  }
});


defineRule("handmadeSunTicker", { // Таймер плавного рассвета/заката
  when: function () { return timers[grow_box+"raiseTicker"].firing; },
  then: function () {
    setPointLight += light_increment;
    if (setPointLight>Number(ps["light_setpoint"])){
      log.info("light_"+grow_box+"raiseTicker STOP ON setPointLight");
      dev["light_"+grow_box+"/sunraiseProcess"] = false; //Выключаем "рассвет" Таймер остановит правило "SunRaise_starter"
    }
    if (setPointLight<0){
      log.info("light_"+grow_box+"setTicker STOP ON setPointLight");
      dev["light_"+grow_box+"/sunsetProcess"] = false; //Выключаем "закат" Таймер остановит правило "SunSet_starter"
    }
    if ((dev["light_"+grow_box+"/Lamp power set"]>dimmer_maxValue)||(dev["light_"+grow_box+"/Lamp power set"]<dimmer_zeroValue)){
      log.info("light_"+grow_box+"raiseTicker STOP ON Lamp power set");
      dev["light_"+grow_box+"/sunraiseProcess"] = false; //Выключаем "рассвет" Таймер остановит правило "SunRaise_starter"
      dev["light_"+grow_box+"/sunsetProcess"] = false; //Выключаем "закат" Таймер остановит правило "SunSet_starter"
    }
  }
});

Спасибо большое. На днях мы уже соберём стеллаж полностью и на нём опробуем

Добавлена строчка

var dimmer_relay = "wb-mio-gpio_157:1/K3"; //CHANGE_ME! устройство-реле питания диммера (доработка, используемй диммер подтягивает свой вход к VCC)

и одно правило:

//*Дополнение для реле диммера
defineRule("dimmer_change", { //название правила 
whenChanged: "light_"+grow_box+"/Lamp power set", //При изменении мощности диммера - проверим и включим реле
  then: function (newValue, devName, cellName) { //выполняй следующие действия
  if ((newValue>dimmer_zeroValue)&&(dev[dimmer_relay] == false)){ //Если диммер уже включен а реле выключено
    dev[dimmer_relay] = true; //включаем реле
  }
  if ((newValue<=dimmer_zeroValue)&&(dev[dimmer_relay] == true)){ //Если диммер на минимуме а реле включено
    dev[dimmer_relay] = false; //вЫключаем реле
  }
}
});  
//*Конец дополнения

Да. Я заметил. спасибо огромное

Здравствуйте. Полку с датчиком освещённости я попытался отстроить. Вопрос только в плавности включения тк он включается сразу на 10% по этой причине несколько раз включается и выключается. Я стараюсь отстроить, но не получается. Возможно что-то прописать в правиле?
Хотел попросить Вас написать похожий скрипт, но без датчика освещённости. Чтобы оператор задал какую-то величину, время рассвета, заката, продолжительность и всё. Тоже самое, что вы сделали, только без привязки к датчику освещённости. Спасибо

Так, сейчас подумаю. Выложите сюда скрипт в таком состоянии как он у вас сейчас - посмотрю.

//light3.js 
//'use strict';
var grow_box = "test3"; // CHANGE_ME! имя устройства. Выводится в заголовок окна и служит для разделения устройств
log.info("light_"+grow_box+"START######################"); //Это лог.

var dimmer_light = "wb-dac/EXT1_O3"; // CHANGE_ME! устройство-диммер То есть строка, которая определяет куда писать изменения мощности.
var dimmer_zeroValue = 0; //"0" диммера
var dimmer_maxValue = 10000; //100% диммера

var dimmer_relay = "wb-mr6cu_29/K3"; //CHANGE_ME! устройство-реле питания диммера (доработка, используемй диммер подтягивает свой вход к VCC)

var sensor_light = "light_conversion/light_converted"; // CHANGE_ME! устройство-датчик освещенности

var ps = new PersistentStorage("storage_"+grow_box, {global: true});// Определим объект-хранилище.

var sunraiseStartTime; //Время начала "рассвета"
var sunraiseStopTime; //Время конца "рассвета"
var sunsetStartTime;//Время начала "заката"
var sunsetStopTime; //Длительность "заката"
var light_increment = 0; //Глобальная для хранения приращения освещенности
var setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
//var dimmer_increment = (dimmer_maxValue-dimmer_zeroValue)/400; //увеличение освещения в цикл расчетное на 0.25%
var dimmer_increment = (dimmer_maxValue-dimmer_zeroValue)/100; //увеличение освещения в цикл расчетное на 1%
setTimeVariable();

//Элементы виртуального устройства
//управления
var deviceCells = { 
  "Light_measured": {
    type: "text",
    value: "0"
  },
  "Lamp power set" : {
    type : "range",
    value : dimmer_zeroValue,
    min : dimmer_zeroValue,
    max : dimmer_maxValue
  },
  //Начало рассвета hh:mm
  "Sunraise (start) time": {
    type: "text",
    readonly: false,
    value: ps["sun_start_time"],
  },
  //Длительность рассвета
  "Sunraise duration": {
    type: "text",
    readonly: false,
    value: ps["sun_start_duration"],
  },
  //Начало заката hh:mm
  "Sunset (stop) time": {
    type: "text",
    readonly: false,
    value: ps["sun_stop_time"],
  },
  //Длительность заката
  "Sunset duration": {
    type: "text",
    readonly: false,
    value: ps["sun_stop_duration"],
  },
  "Light SetPoint": {
    type: "value",
    readonly: false,
    value: ps["light_setpoint"]
  },
  sunraiseProcess : {
          type : "switch",
          value : false,
  },   
  sunsetProcess : {
          type : "switch",
          value : false,
  },
  dayProcess : {
          type : "switch",
          value : false,
  },
};


//Создадим виртуальное устройство и добавим в него элементы 
  defineVirtualDevice("light_"+grow_box, {
    title:"Light of "+grow_box,
    cells: deviceCells
  });

defineRule("Sunraise start time change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunraise (start) time", //при изменении поля времени начала рассвета запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunraise start time ", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_start_time"] = newValue;
    setTimeVariable();
  }
});

defineRule("Sunraise duration change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunraise duration", //при изменении поля времени начала рассвета запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunraise duration", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_start_duration"] = newValue;
    setTimeVariable();
  }
});

defineRule("Sunset start time change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunset (stop) time", //при изменении поля времени начала ЗАКАТА запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunset (stop) time ", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_stop_time"] = newValue;
    setTimeVariable();
  }
});

defineRule("Sunset duration change", { //название правила 
whenChanged: "light_"+grow_box+"/Sunset duration", //при изменении поля времени начала рассвета запишем его в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/Sunset duration", newValue); //Это лог. Он попадает в /var/log/messages
    ps["sun_stop_duration"] = newValue;
    setTimeVariable();
  }
});

defineRule("Light SetPoint change", { //название правила 
whenChanged: "light_"+grow_box+"/Light SetPoint", //при уставки желаемой освещенности -запишем в хранилище
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+"/light_setpoint ", newValue); //Это лог. Он попадает в /var/log/messages
    ps["light_setpoint"] = newValue;
    setPointLight = Number(newValue);
  }
});

defineRule("dayProcess change", { //название правила 
whenChanged: "light_"+grow_box+"/dayProcess", // Для режима "День"
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    if (newValue){ //Включаем "день"
    //log.info("light_"+grow_box+"/light_setpoint ", newValue); //Это лог. Он попадает в /var/log/messages
      dev["light_"+grow_box+"/sunraiseProcess"] = false; //Выключаем "рассвет" Таймер остановит правило "SunRaise_starter"
      //dev["light_"+grow_box+"/sunsetProcess"] = false; //Выключаем "закат" Таймер остановит правило "SunSet_starter"
      setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
    }else{
      //dev[dimmer_light] = dimmer_zeroValue;
    }
  }
});

//*Дополнение для реле диммера
defineRule("dimmer_change", { //название правила 
whenChanged: "light_"+grow_box+"/Lamp power set", //При изменении мощности диммера - проверим и включим реле
  then: function (newValue, devName, cellName) { //выполняй следующие действия
  if ((newValue>dimmer_zeroValue)&&(dev[dimmer_relay] == false)){ //Если диммер уже включен а реле выключено
    dev[dimmer_relay] = true; //включаем реле
  }
  if ((newValue<=dimmer_zeroValue)&&(dev[dimmer_relay] == true)){ //Если диммер на минимуме а реле включено
    dev[dimmer_relay] = false; //вЫключаем реле
  }
}
});  
//*Конец дополнения

defineRule("sensor_light change", { //название правила 
whenChanged: sensor_light, //При изменении измеренной освещенности - установим значения виртуального устройства.
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    dev["light_"+grow_box]["Light_measured"] = newValue;
    if ((dev["light_"+grow_box]["sunraiseProcess"]==true)||(dev["light_"+grow_box]["dayProcess"]==true)||(dev["light_"+grow_box]["sunsetProcess"]==true)){// если сейчас нужен свет
      newValue = Number(newValue); //Приведем к числу
      if (newValue>setPointLight) { // Если текущая освещенность больше уставки
        //log.info("light_"+grow_box+"Light_measured BIG",newValue);
        if (dev[dimmer_light]>dimmer_zeroValue){
          dev[dimmer_light] -= dimmer_increment;
        }
      } else{ // если меньше
        //log.info("light_"+grow_box+"Light_measured LOW",newValue);
        if (dev[dimmer_light]<dimmer_maxValue){
          dev[dimmer_light] += dimmer_increment;
        }
      }
      dev["light_"+grow_box+"/Lamp power set"] = dev[dimmer_light];
    }
  }
});


defineRule("cron minute timer", { //Просто задание, которое выполняется каждую минуту и взводит/опускает флаги "Рассвет", "Закат"
  when: cron("00 * * * * *"),
  then: function () {
    //log.info(grow_box, "cron timer executed! DEBUG ONLY.");
    d = new Date(); //Текущее время
    //sunraiseStartTime 
    if ((dev["light_"+grow_box]["sunraiseProcess"]==false) && (d > sunraiseStartTime) && (d<sunraiseStopTime)){
      log.info(grow_box, "cron timer executed! Sunraise process START", "sunraiseStartTime",sunraiseStartTime ,"sunraiseStopTime",sunraiseStopTime);
      dev["light_"+grow_box]["sunraiseProcess"] = true;
    }
    //sunsetStartTime
    if ((dev["light_"+grow_box]["sunsetProcess"]==false) && (d > sunsetStartTime) && (d<sunsetStopTime)){
      log.info(grow_box, "cron timer executed! SunSET process START", "sunsetStartTime",sunsetStartTime ,"sunsetStopTime",sunsetStopTime);
      dev["light_"+grow_box]["sunsetProcess"] = true;
    }
    //dayProcess
    if ((dev["light_"+grow_box]["dayProcess"]==false) && (d > sunraiseStopTime) && (d<sunsetStartTime)){
      log.info(grow_box, "cron timer executed! DAY process START","sunraiseStopTime",sunraiseStopTime,"sunsetStartTime",sunsetStartTime);
      dev["light_"+grow_box]["dayProcess"] = true;
    }
  }
});

defineRule("cron day timer", { //Просто задание, которое выполняется раз в сутки и меняет дату в переменных на текущую.
  when: cron("01 00 00 * * *"),
  then: function () {
    setTimeVariable();
  }
});

function string_to_time(srcString) { 
  //log.info("string_to_time_"+grow_box, srcString)
  var d = new Date();
  var datetime = new Date(d.getFullYear()+'-'+(d.getMonth()+1)+'-'+d.getDate()+'T' + srcString + 'Z');
  datetime.setMinutes(datetime.getMinutes() + datetime.getTimezoneOffset());//Приведем к локальному:
  return datetime; 
};


function setTimeVariable() { 
  sunraiseStartTime = string_to_time(ps["sun_start_time"]); //Время начала "рассвета"
  sunraiseStopTime = new Date(sunraiseStartTime);
  sunraiseStopTime.setMinutes(sunraiseStopTime.getMinutes() + parseInt(ps["sun_start_duration"])); //окончание "рассвета"
  sunsetStartTime = string_to_time(ps["sun_stop_time"]);//Время начала "заката"
  sunsetStopTime = new Date(sunsetStartTime);
  sunsetStopTime.setMinutes(sunsetStopTime.getMinutes() + parseInt(ps["sun_stop_duration"])); //окончание "заката"
};


defineRule("SunRaise_starter", { //название правила 
whenChanged: "light_"+grow_box+"/sunraiseProcess", //При изменении переуключателя "рассвет"
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+" sunraiseProcess function", newValue, devName, cellName); //Это лог.
    if (newValue){ //Запускаем "рассвет"
      dura = (sunraiseStopTime - sunraiseStartTime)/1000; //время в секундах
      setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
      light_increment = setPointLight/dura; //увеличение освещенности в секунду расчетное
      setPointLight = 1;
	  log.info("light_"+grow_box+" sunraiseProcess", "dura", dura, "dimmer_increment", dimmer_increment); //Это лог.
      startTicker(grow_box+"raiseTicker", 1000); //Запуск таймера, отрабатывает раз в секунду.
    } else { //Останавливаем "рассвет"
      timers[grow_box+"raiseTicker"].stop(); 
      log.info("light_"+grow_box+"Ticker STOP sunraise");
    }
  }
});

defineRule("SunSet_starter", { //название правила 
whenChanged: "light_"+grow_box+"/sunsetProcess", //При изменении переуключателя "Закат"
  then: function (newValue, devName, cellName) { //выполняй следующие действия
    log.info("light_"+grow_box+" sunsetProcess function", newValue, devName, cellName); //Это лог.
    if (newValue){ //Запускаем "закат"
      dev["light_"+grow_box]["dayProcess"] = false;
      setPointLight = Number(ps["light_setpoint"]); // уставка освещенности
      dura = (sunsetStopTime - sunsetStartTime)/1000; //время в секундах
      light_increment = -(setPointLight)/dura; //уменьшение освещения в секунду расчетное. От уставки!
      //dev["light_"+grow_box+"/dayProcess"] = false; //Выключаем "день"
	  log.info("light_"+grow_box+" sunsetProcess", "dura", dura, "light_increment", light_increment, "setPointLight", setPointLight); //Это лог.
      startTicker(grow_box+"raiseTicker", 1000); //Запуск таймера, отрабатывает раз в секунду.
    } else { //Останавливаем "закат"
      timers[grow_box+"raiseTicker"].stop(); 
      log.info("light_"+grow_box+"Ticker STOP sunset");
      setPointLight = 0;
      dev[dimmer_light] = dimmer_zeroValue;
    }
  }
});


defineRule("handmadeSunTicker", { // Таймер плавного рассвета/заката
  when: function () { return timers[grow_box+"raiseTicker"].firing; },
  then: function () {
    setPointLight += light_increment;
    if (setPointLight>Number(ps["light_setpoint"])){
      log.info("light_"+grow_box+"raiseTicker STOP ON setPointLight");
      dev["light_"+grow_box+"/sunraiseProcess"] = false; //Выключаем "рассвет" Таймер остановит правило "SunRaise_starter"
    }
    if (setPointLight<0){
      log.info("light_"+grow_box+"setTicker STOP ON setPointLight");
      dev["light_"+grow_box+"/sunsetProcess"] = false; //Выключаем "закат" Таймер остановит правило "SunSet_starter"
    }
    if ((dev["light_"+grow_box+"/Lamp power set"]>dimmer_maxValue)||(dev["light_"+grow_box+"/Lamp power set"]<dimmer_zeroValue)){
      log.info("light_"+grow_box+"raiseTicker STOP ON Lamp power set");
      dev["light_"+grow_box+"/sunraiseProcess"] = false; //Выключаем "рассвет" Таймер остановит правило "SunRaise_starter"
      dev["light_"+grow_box+"/sunsetProcess"] = false; //Выключаем "закат" Таймер остановит правило "SunSet_starter"
    }
  }
});

Я сделал 2 видео. Ссылки прикреплю. С самого начала прироста вообще нет тк освещённость не меняется, а потом как на видео…

Поменять на 20

Заменить на

  if ((newValue<=dimmer_zeroValue)&&(dev[dimmer_relay] == true)&&(dev["light_"+grow_box]["sunraiseProcess"] == false)){ //Если диммер на минимуме а реле включено
    dev[dimmer_relay] = false; //вЫключаем реле

Это определённо помогло. Спасибо большое. Остался вопрос с запуском рассвета. Когда начинается рассвет, светильники не включаются и мощность на диммере не меняется тк нету изменения освещённости. Если я, условно, взмахну рукой (изменю показатель освещённости), то всё заработает.

И можно попросить скрипт, чтобы можно было задать мощность, время и продолжительность рассвета/заката, чтобы можно было работать без датчика освещённости? спасибо

Не совсем так. Пока требуемая освещенность не будет выше измеренной - светильник и не включится. Задача-то поддерживать установленную. И если осветить датчик чем-то - то светильники будут тускнеть соответственно.

Посмотрю. Какой-то из промежуточных вариантов так и работал. Пока - просто используйте значение канала с датчиком для установки остальных.

Хорошо. Я попробую в понедельник просто оставить стеллаж на всё время включения, чтобы освещённость не менялась.

Хорошо. Спасибо большое
Надеюсь, что скоро перестану вас доставать. В пн у меня начинаются жёсткие курсы по java. Хоть будет человек со знанием java в штате…

Именно JavaScript. Java - все ж несколько другой язык.

Ну значит после java возьмусь конкретно за javaScript

Здравствуйте. Посмотрите пожалуйста скрипт по работе без датчика. Спасибо
С закатом всё хорошо. Меня немного волнует рассвет. Иногда срабатывает хорошо, а иногда всё стоит на месте без изменений, пока не поднесёшь руку к датчику, изменяя освещённость.\ Спасибо

Добрый день. Скрипт смотрел, я скорее всего удалил все промежуточные копии.

Оставить и не трогать - пробовали? Возможно просто внешняя освещенность выше. Она ж показывается.

Пробовал. По разному. Бывает так, что не срабатывает или срабатывает. Если освещённость вообще не меняется, то не срабатывает (выжидал 5 минут из 10). Сейчас запустим на сутки. Посмотрим, как проработает. В последнне время появилась такая “фишка”, что не взводит флажок “день”. Возможно это всё из-за того, что я его долго и муторно гоняю. Короче бывает разное. Ставим на сутки-двое, посмотрим результат. Я думаю, что в итоге всё будет нормально.

можно будет имеющийся скрипт упростить до “жёсткого сценария” без датчика? Спасибо!


Здравствуйте. Вот примерный итог по освещённости за 2 дня. Мы 6 числа поставили цикл: в 7 рассвет, 19 закат, продолжительность 15 мин каждый. В первую ночь свет был на 10% и не выключился. Я немного подкорректировал и на следующую ночь он выключился. По рассвету вопросов нет. По поводу заката: в 2х местах явное падение освещённости в 19:02, а потом резкое его увеличение. Я не могу понять, с чем это связано тк мощность снижалась планомерно и нету скачка, который компенсировал бы это падение

также (на первом скрине), я ввёл другое время рассвета и заката, чтобы посмотреть, как он срабатывает. Всё плавно. Сейчас я сместил время заката немного дальше тк в 19 часов у нас отключаются другие боксы и, возможно, это как-то воздействует на освещённость.

Да, возможно. Надо еще график датчика освещенности посмотреть - там видно будет.


Вот График освещённости.
Ещё хотел спросить по поводу скрипта без датчика? Спасибо