Как стать автором
Обновить

Комментарии 174

Как хорошо, как хорошо, какое совпадение! Два разных человека изобрели одно и то же устройство и запостили статьи об этом строго одновременно! geektimes.ru/post/299723

Ну ок, ссылка на другую статью присутствует. Но зачем тогда в обеих статьях употреблять местоимение «я», а не «мы»? Или кто-то палится, или мы имеем честь наблюдать крайне редкое заоблевание — слияние личностей, наподобие протоссов.
Я про софт писал, а товарищ про железо. Спасибо что заметили.
Ну садовод любитель — это я, тут нет никаких мы. А остальное — это незначительные детали.
Диссоциативное расстройство встречается не часто, а вот раздвоение личности довольно частое явление, но это не наш случай. Статьи написаны парой с перекрестными ссылками. Один человек пишет про железо, второй про софт, поэтому проще «я», а не «мы».
Так вот тут не раздвоение, а нечто обратное. Когда у двух человек одна личность, и они говорят об своём коллективе исключительно «я». Иначе я решительно не понимаю, что мешало в начале упомянуть, что мы с товарищем решили сделать соответствующий девайс. А дальше уже про свою часть и употреблять «я» сколько влезет. Про жену упомянуто, что это жена, а с товарищем, видимо, как в песне — я это ты, ты это я.
В первой части указано что есть я и коллега.
вы три значения квиксортом сортируете?
Да, но обратите внимание на теги под статьей.
А вы под каждое количество значений код сортировки переписываете?
нет. я стараюсь изначально применять подходящий алгоритм.
Так а как можно три значения отсортировать?
а вам их надо сортировать? вам же нужно найти средний по значению элемент…
например, так:
mid=?(a0>max(a1,a2),max(a1,a2),(?(a0<min(a1,a2),min(a1,a2),a0)));

Да, мне не столько сортировать, сколько среднее из трех найти надо.
для поиска элемента со значением между максимальным и минимальным — можно использовать, например, мою подсказку выше.
если элементов больше (ну, скажем, до десятка-двух)- бежите по массиву, и для каждого элемента считаете количество элементов больше него. как найдется элемент, у которого количество этих значений будет равно половине длинны массива — вы победили :-)
У меня при пяти элементах в массиве — ESP вообще виснуть начала. Так что остановился на стабильных трех.
а прикола ради замените квиксорт на обычный пузырек (при размере массивов до полусотни пузырек в среднем быстрее из-за меньших накладных расходов), и проверьте на ваших 5 элементах. 99.9%, что виснут не будет…
Попробую, спасибо!
Наконец-то первая статья по энергопотреблению Arduino с ESP8266. Спасибо!
Мне конечно не казалось, что она прямо первая. Но повозиться пришлось, т.к. полностью готового мануала я не нашел.
По поводу энергопотребления есть наблюдение, что эффективнее просыпаться из deep-sleep с включенным WiFi (если время опроса датчиков не большое), чем каждый раз подключаться из режима отключенного WiFi модема.

Делал на основе esp8266 «градусник» для народного мониторинга. Пробовал 2 варианта работы:
1. Просыпаться с выключенным WiFi модемом, собирать информацию с датчиков, включать WiFi модем, перезагружаться, передавать данные, уходить в deep-sleep;
2. Второй вариант — сохранить настройки WiFi на постоянно в памяти и просыпаться с включенным WiFi модемом и в то время, пока WiFi устанавливает соединение, опрашивать датчики и далее передавать данные, уходить в deep-sleep.

«Градусник» передает показания 1 раз в 15 минут (2 датчика температуры, давление, напряжение батареи, уровень сигнала WiFi). В первом варианте общее время нахождения вне deep-sleep за цикл передачи было 5-7 секунд, а во втором варианте время бодрствования 1,2-1,4 сек.

На данный момент передатчик работает с 29 октября 2017. Используются 4 батареи AA икеевские (+ линейный стабилизатор LDO). Сейчас напряжение 5.6 В (на старте было чуть выше 6 В).
Да, у меня первая версия работала также. Но я не хочу каждое включение использовать WiFi. Например, если я буду просыпаться 1 раз в час, а результаты измерений слать на сервер 4 раза в день, то может получиться более экономно. Но надо тестировать.
Про WiFi.disconnect() и сохраненные SSID / password надо использовать WiFi.persistent(false).
Это же спасёт от деградации флеш памяти ESP от постоянной перезаписи «креденшиалов» при каждом WiFi.begin()
Спасибо, именно этого мне и не хватало.

Можно слать раз в день и если влажность ниже порогового значения.

Но освещенность слать раз в день не получится. Иногда может быть полезным замерять продолжительность светового дня на конкретном окне у конкретного цветка.
Можно копить данные и отсылать сразу несколько измерений.
Так не получится, в блинке все данные будут в куче. Чтобы график выглядел нормально, данные надо отправлять по мере измерений.
Опять таки, ночная температура тоже достаточно важный параметр.

А как вы калибровали датчик?
Ну вот получили вы некое значение напряжения, какой влажности это соответствует? Влияет ли состав почвы на напряжение при одинаковой влажности?

Пока я только отнормировал шкалу от 0 до 100%, где 100% соответствует 0 В на входе АЦП (все «ушло» в землю), а 0% — это когда земля сухая (эквивалентно тому, что электрод просто висит в воздухе). Сейчас как раз тестирую, строю графики и пытаюсь придумать какую нибудь градацию шкалы (мокро, нормально, сухо).
Про состав почвы и прочее пока не думал.

Влажность почвы легко определяется вручную, сушкой и взвешеванием. Есть ГОСТы на эту тему, там всё подробно расписано.
Тут особой точности не надо, а при аккуратности погрешность будет определяться погрешностью используемых весов.

Я как то не уверен что кому то нужны такие сложности. В данном случае влажность понятие субъективное. То есть вот полил и можно отметить что сейчас полито. А когда посмотрел и считаешь что нужно уже поливать, то отметил что сухо. Этого вполне достаточно. Все что посредине можно разметить как угодно, хоть феями разрисовать.
Иначе вам придется описывать способ калибровки, состав земли и прочее и прочее. И так для каждого горшка…

Когда будут культуры которые не любят как усушки как и переувлажнения, тут феи вылезут боком.
В зависимости от того во что посажено может вылезти плесень, тогда проще всё выкинуть чем стерилизовывать имеющееся.
Могут сгнить(задохнуться) корни, может завестись мошкара или мох.
На разных этапах развития (и внезапно в разные сезоны года!), растения любят разную влажность.
Грунт в горшках примерно одинаков.
Первый попавшийся ГОСТ 28268-89. "Методы определения влажности, максимальной гигроскопической влажности и влажности устойчивого завядания растений"
Влажность грунта определяется формулой:


((м1-м0)/(м0-м))*100%, где
м — масса пустой ёмкости с крышкой;
м0 — масса высушенной почвы с ёмкостью и крышкой;
м1 — масса влажной почвы с ёмкостью и крышкой.


Сушим 3-10 часов, при температуре 100-110 градусов (можно и выше, но — аккуратно, можно высушить за недельку просто неполивая, а потом довести до кондициии в духовке). Сушка прекращается когда разница масс приближается к нулю.


Пяток проб не такая большая трата времени, зато можно прикинуть (не)линейность датчика и как-то ориентироваться что и как в горшке.

А если у бабушки вырастет GUI? Должны ли мы предусмотреть такое развитие событий? Заложим время и бюджет на все подобные варианты?
Я понятия не имею откуда вы решили что грунт в горшках у всех одинаков. Давайте тогда коротенечно опишите нам химический состав почвы в ваших средних по больнице горшках. Разработайте нам методологию полива, сколько капель на кубический миллиметр почвы нужно вылить что бы не перелить? Что делать с тем кто перелил на 1 каплю?
Или может вернемся к классике? Это когда для каждого растения организуется свой персональный горшок, с дренажом и прочими слоями по необходимости? А подобный прибор оставим для тех кто заводит кактус, да и тот забывает полить раз в году.
Весов мне на подоконнике ещё не хватало. И ведь придётся взвешивать в горшках, а они бывают и пластиковые и керамические и разного размера. А бывают и балконные ящики длинной 80 см. А ещё ведь и растения весьма разные, у имбиря (вчера как раз урожай снял) например клубень растёт. Так что я выбираю метод определения минимума, максимума по неким абстрактным потерям на электроде. А дальше время покажет. Через 6-10 месяцев подробно расскажу что получилось.
Да рос у меня корень имбиря в горшке и за полгода, объем этого самого корня удвоился, а количество земли осталось таким же. Так что метод взвешивания при наличии «живых жильцов» в горшках — это трудно.
По поводу взвешивания — смотря чем мерить. Плюс, если мерить вес за небольшой промежуток времени, то по отношению к весу всего горшка, вес растения не будет существенным и влиять на усредненные массы сухой и влажной почв не будет.
А вообще, мне стал интересен именно сам процесс и результат выращивания имбиря в горшке дома)
Закопал прошлой летом-осенью корень имбиря в горшке. Он достаточно долго колосился (длинный зеленый стебель). Месяц назад стебель отвалился, а недавно я раскопал и в горшке было уже два корня, старый чуть темнее и новый побольше и на вид — вполне съедобный. Да что таить и старый корень — тоже съедобный.
Спасибо!
а зря про состав почвы не думали. зависимость сопротивления он наличия солей в растворах очень значительна.
Думаю, я дойду и до этого.
НЛО прилетело и опубликовало эту надпись здесь
Ну для батарейки с емкостью 600-1000 мА это не так и много. Все конечно познается в сравнении.
А как насчет не влажность измерять, а использовать гидрогель?
Это конечно не так технологично, но у меня после пересадки в смесь гидрогель+земля прям в новую силу растения начали расти
Первый раз как то о таком слышу. Но как я понимаю это не решает проблему и гель когда то тоже весь высохнет.
Вся фишка в том, что можно поливать раз в неделю помногу, не боясь залить
Ой там ужас будет с ионным составом потом. Эта фигня очень своеобразно может влиять на pH и соотношение ионов. Накапливает и отдает неравномерно.
А во сне ESP может считать импульсы, или просыпаться от внешних событий? хОЧЕТСЯ беспроводной водосчетчик в умный дом на батарейках…

смотря какой сон. тот что deep sleep — неможет, ибо вырублено все.

Как я понял, в режиме Deep sleep и Light sleep у него CPU спит и на прерывания не отвечает.
During Light-sleep, the CPU is suspended and will not respond to the signals and interrupts
from the peripheral hardware interfaces. Therefore, ESP8266 needs to be woken up via
external GPIO. The waking process is less than 3 ms.
Таблица из даташита


Для другого девайса, о котором будет третья часть — мы реализовали внешнее прерывание, т.е. будим модуль из Deep sleep'а по наступлению нашего события.

кстати считать можно и двоичным кмоп счетчиком на рассыпухе, кушают они немного. ну и логика простая проснулся — прочитал отправил (при необходимости сбросил) и дальше спать.

Мне во всем этом больше нравится бОльшая гибкость и простота изменения софта. Хочу такие графики строю, а хочу такие. Хочу просыпаюсь 10 раз в день, а хочу раз в неделю. Через Blynk можно разные комбинации настроек менять и применять. Мне бы лично и 6 месяцев на одном комплекте батареек хватило.

раз в неделю не получится, там 32бита на счетчик, итого около часа максимум.

каждый сам выбирает микроскопы для забивания своих гвоздей.
Для водосчётчика не надо внешних событий. Для водосчётчика надо просыпаться по таймеру каждые 50-100 мс, включать подтяжку на ножке и смотреть, что там. А потом выключать подтяжку обратно, иначе есть шанс посадить батарейку ей.
А что по потреблению это может выйти, сколько на батарейке проживет обычной?
6 лет от одной литиевой батарейки 14505, минимум, при температура -40 'C (т.е абсолютно худший случай). Это с опросом датчиков, ведением журналов и т.п.
Это у меня устройство столько потребляет — занимаюсь разработкой счётчиков. Можно сделать с беспроводным интерфейсом и сроком службы батареи несколько лет. Это будет следующая модель.
WiFi подходит мало. И по потреблению и по архитектуре (физически ограничено количество абонентов на точку — на 16 уже всё начинает ломаться). Нужно смотреть на BT4, BLE и всякие LoRa и просто приёмо-передатчики со своими протоколами — там можно несколько лет работать от одной батареи.
Что не так в китайских беспроводных термометрах на 433 Mhz? Замерзают заразы в минус 32 на литиевых пальчиковых батарейках…
Батареи — говно (точнее, не тот литий). Литий разный бывает. Для наружного применения в России подходят ТОЛЬКО батареи LiSoCl2 с диапазоном температур -50..+80. Китайцы их отлично делают, но бывают подделки (замерзают при -30). Что-то типа такого. Вполне себе продаются.
Если батарейный отсек позволяет, то можно всунуть батареи по-больше (вплоть до 18505, у которых ёмкость значительно больше).

Существуют водосчетчики, которые передают данные по BLE.

А куда передают? У меня только WiFi ( Gpon от ростелекома), и как бы ничего больше нет…
Наверное нужен какой то хаб, который бы данные с BLE датчиков собирал и дальше уже в интернет отправлял.

Статья подразумевает что влажность почвы измеряется резистивным методом исходя из "необходимо на земляной электрод подать напряжение и на другом его конце измерить сколько этого самого напряжения дошло, а сколько «потерялось» в почве."


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


Еще одна важная деталь это то что диапазон чувствительности такого датчика будет со временем меняться из-за изменения плотности почвы и заряда батареи. Грубо говоря датчик начнет "дрифтовать", и по этому не имеет смысла привязка выходных показаний к процентам от 0 до 100, если только не придумать какой нибудь хитрый самонастраивающийся алгоритм.


У самого подобное устройство работает уже больше года от CR2032, только в место ESP я использовал NRF24+atmega отправляющий показания на "базовую станцию".

Про электрод — я наверное не очень точно выразился. Я если честно, в физику процесса не вдавался, подаю ШИМ и измеряю что навелось на входе АЦП. Чтобы исключить влияние заряда батареи на результаты измерений — сейчас добавлены коэффициенты. В следующей ревизии железки скорее всего добавим повышалку, так чтобы сигнал ШИМ и сигнал на входе фоторезистора не зависел от заряда батарейки.
Влияние плотности почвы и прочее — мне еще предстоит с этим столкнуться. У нас первая версия устройства была с батарейкой CR2032, но 170 мА WiFi модуля сделали практически невозможным хоть сколько долгую работу.

Обычный ESP8266 от CR2032 не сможет работать, так как "копейки" не рассчитаны на отдачу таких токов. Не рассматривали вариант с одной базовой станцией и множеством датчиков передающих показания по nrf24l01+? У меня такая реализация, NRF потребляет 900nA в спящем режиме, в связке со спящим Atmega получается всего около 2uA.

НЛО прилетело и опубликовало эту надпись здесь

Ну не совсем с вами согласен. Лично проводил опыты и в квартире в 100м2 сигнал не терялся с одного конца квартиры до другого. Тут скорее идет лотерея с китайскими паленными чипами, иногда везет иногда не очень. Еще на линию питания нужно обязательно ставить сглаживающие конденсаторы (если не изменят память, я ставил 22uf, но подбирал методом тыка), удивитесь насколько стабильнее они начнут работать. Из практики, мой датчик стоит примерно в 6-7 метрах от "БС", и пробивает 2 стены одна из которых бетонная. Если действительно имеются проблемы с покрытием, можно поставить какой-нибудь bridge маячек запитанный от розетки.

НЛО прилетело и опубликовало эту надпись здесь
Так у них их скорость передачи данных разная, соответственно, и помехозащищённость.
НЛО прилетело и опубликовало эту надпись здесь
Было много разных идей, вплоть до полностью пассивных датчиков на rfid и одной базовой станции на esp. Идей больше чем времени в итоге.
Для того, чтобы измерять влажность почвы, необходимо на земляной электрод подать напряжение и на другом его конце измерить сколько этого самого напряжения дошло, а сколько «потерялось» в почве.

В этом главная ошибка. Как и всех TDS-метров. Проводимость и влажность сложно сравнить друг с другом. Только приблизительно. Пропитайте грунт аммиачной селитной. Сухая — ноль. Капельку капнуть — 95%.
у них не прямое измерение электропроводности…
хотя, безусловно, я бы хотел посмотреть на зависимости и от влажности, и от концентрации различных солей.
зачем вы вызываете WiFi.mode(WIFI_OFF) перед WiFi.forceSleepBegin()? WiFi.forceSleepBegin() сама вызывает WiFi.mode(WIFI_OFF) в своем теле.

вот что в исходниках об функции WiFi.forceSleepBegin()
/**
* Disable WiFi for x us when value is not 0
* @param sleep_time_in_us
* @return ok
*/
bool ESP8266WiFiGenericClass::forceSleepBegin(uint32 sleepUs) {
_forceSleepLastMode = getMode();
if(!mode(WIFI_OFF)) {
return false;
}

if(sleepUs == 0) {
sleepUs = 0xFFFFFFF;
}

wifi_fpm_set_sleep_type(MODEM_SLEEP_T);
wifi_fpm_open();
return (wifi_fpm_do_sleep(sleepUs) == 0);
}
Видимо повторение — мать учения. Не знаю зачем.
У меня по идее ESP должна просыпаться с спящим модемом, я ведь перевожу ее в Deep sleep так ESP.deepSleep(sleep_time, WAKE_RF_DISABLED);
Надо проверить, как оно на практике.
А можно было просто взять например TPL5111, резистором подобрать интервал через который подавать питание и удивиться что оказывается от батарейки может и лет 20 прожить.
Тут вот есть даже готовое с переменным резистором.
А хорошая идея, обязательно впилим в какой нибудь будущий проект. Спасибо!
Но с текущим девайсом все чуть попроще, не в космосе работает, а на балконе.
Есть ещё одна хорошая идея для будущих проектов: вместо китайских ESP использовать CC3220 от Texas Instruments. Да, это дороже. Зато сэкономите время, которое, как известно, является невосполнимым ресурсом (в отличие от денег). В Вашем проекте я насчитал как минимум 3 места, где примененный модуль сталкивается с ограничениями.

В некоторых мануалах по оптимизации энергопотребления ESP8266 можно встретить команду WiFi.disconnect(); которая должна отключать модем от текущей WiFi сети. Однако на практике, эта команда удаляет сохраненный в памяти модема SSID() и пароль, поэтому использоваться ее мы не будем.
В CC3220 подобных багов нет.

Для коммутации разных сигналов на вход единственного АЦП — используется мультиплексор (модель).
В CC3220 АЦП имеет 4 входа.

У ESP8266 АЦП 10-битный, а диапазон измеряемых напряжений 0..1 В.
В CC3220 АЦП 12-битный, диапазон 0...1,5 В.

А ещё мне кажется, что с Вашим опытом работы пора уже переходить с Arduino на взрослые IDE.
Спасибо, интересно, надо посмотреть.

и как его к esp8266 прикрутить? да и зачем? если встроенный аналогичный и программируемый по цифре в esp уже встроен?

Если вдруг не будет хватать ног, то можно к RST ноге подключить TPL5111, а GPIO16 использовать. Но в схему конечно лучше глянуть для начала.

судя по даташитам gpio16 это выход таймера который будит esp8266 (и то если соединен с rst), как gpio он не адресуется

Я если мне не изменяет память использовал его как обычное gpio в другом проекте.
хм, да, действительно, есть возможность пинать его, не углядел.
Вспомнил!
Там заковырка в другом, для GPIO0-15 есть возможность рулить ими записью в регистры типа GPIO_*_W1TS/GPIO_*_W1TC (*-OUT, ENABLE, STATUS), где мл. 16 бит соответствуют GPIO0-15.
А вот что бы рулить GPIO16 – надо к нему лезть только через отдельный набор регистров для этого пина.
Видимо все зависит от того, где разрабатывать. В Arduino IDE чтобы управлять GPIO16 достаточно команд digitalWrite(GPIO16, LOW) \ digitalWrite(GPIO16, HIGH)
У нас в датчике CO2 на этом GPIO светодиод висит и ничего, светит.
Элементарное. Ставим после батарейки. И рубим батарею от всего и сразу на заданое через сопротивление время. Как только истекает время он подает питание всему. А как все железо отработает сессию то подает сигнал ему на пин о окончании сессии и он опять отрубает всему питание.
Теряется гибкость Настройки. Но для серийных применений — наверное будет оптимально.
Для настроек он может будить всю систему по кнопке. Нажал кнопку и настраивай. Как закончил настройки подал сигнал об окончании и он все отрубит и уйдет опять на цикл заданный сопротивлением.
ИМХО конечно. Но я отказался от развития подобного на базе wifi. Слишком он прожорливый. Так же как и блутус. Пока проснется, пока зарегистрируется в сети. пока соберет и отправит… Тоска зеленая в общем… Блутус еще и теряется постоянно. И это я еще не напомнил о процессе настройки wifi у устройств лишенных дисплея, что вообще для простых людей напоминает магию.
Радио трансиверы до 1 ГГц с шифрованием и прочим блекджеком, гораздо гораздее для подобных целей.
Например такой вот брелок (35х60х5мм) 3 кнопки, дисплей Е-Инк и с радио трансивером примерно метров на 500. От CR2032 будет жить 10+ лет.
Заголовок спойлера



Единственный минус, что для подсоединения к инету нужен «переходник». Но он у меня есть.
Жду платы из печати.
О, а можно подробнее? Что собирает данные, кто раздает, и т.д. А то я пытаюсь для дома собрать систему независимых датчиков, но с WiFi уже намучился
Подробнее будет когда все более менее причешется. Тут в двух словах не рассказать всю идеологию проекта. Это не «умный дом», у меня другая цель навеянная подслушанным обсуждением девочек «на кой все это нужно, почему не могут сделать что бы вот так ....»
Собирается все вот на такие штуки. Крутится на Debian. Каждый сам может их использовать как захочет, как и любые юниты из проекта. SDK и примеры кода будут в открытом доступе.
Заголовок спойлера




Они по сути заменяют собой стандартный выключатель света в каждой комнате, без дополнительного долбления стен и проводов(100х150х20мм). И в рамках моего решения собираются в один кластер, который обеспечивает хранение всех настроек и личной информации в пределах дома, без всяких облаков и серверов. За счет избыточности реализуем безопасное хранение, что бы ничего не потерялось если один модуль неожиданно подохнет.
Остальные юниты/датчики на батарейках живут 10+ лет. Имеют обратную связь + ОТА. И почти все укладываются в размер 30х50х5мм. Можно разбрасывать их горстями по всему дому. Дочь правда указала на возможную проблему что если они на полу ( температуру пола измеряют или протечки караулят), то их может пылесос собрать. :)
Заголовок спойлера

НЛО прилетело и опубликовало эту надпись здесь
CC1310. Он хорош что может при необходимости в mesh сеть и таким макаром покрывать любые площадя.
У меня вся элементная база от Ti, за исключением чипов памяти и обвязки, Ti их просто не производит. У них интересная система с бесплатными образцами, что для гаражного проекта облегчает финансовое бремя на прототипирование.
А при варианте что это куда то вырастет, у них есть программа по поддержки подобных гаражных эксперементаторов. :)
В общем ждем платы со стенсилом. Надеюсь жена не побьет за запекание плат в духовке :)
НЛО прилетело и опубликовало эту надпись здесь
Так там наверное конечные ноды не должны перепередавать сообщения, а промежуточные можно делать с питаием («умные» розетки/выключатели), как делает одна китайская фирма.

Leaf-nodes в mesh живут по 3+ года от CR2032

Зачем с ним мучится? У Ti отличная поддержка, хоть на форуме, хоть по телефону. Любые, даже самые тупые вопросы, отвечают в течении суток.
НЛО прилетело и опубликовало эту надпись здесь
Так вроде оперативно отвечали. Предложили рассмотреть вариант с драйвером.
В рамках нужного у них на данный момент каких только референсных дизайнов нет.
НЛО прилетело и опубликовало эту надпись здесь
Ну на тот момент чип был еще свежий. Вы желаете не возможного.
НЛО прилетело и опубликовало эту надпись здесь
может есть на форуме.
Я не представляю зачем нужны такие скорости. Разве что для обновления прошивки по воздуху. Но там максимум 128кбайт прошивка. В моем случаем пересылаемая информация вообще измеряется максимум сотней байт.
НЛО прилетело и опубликовало эту надпись здесь
а что за проект по передаче многоканального звука? если не секрет?
НЛО прилетело и опубликовало эту надпись здесь
так вроде такие скорости один фиг без надобности. на порядок меньше вполне достаточно.
НЛО прилетело и опубликовало эту надпись здесь
А вы их хотели 4 канала одновременно принимать? С разных источников? В цифровом виде? Да вы батенька тот еще затейник. И как вы себе представляете подобный процесс?
НЛО прилетело и опубликовало эту надпись здесь
НЛО прилетело и опубликовало эту надпись здесь
Печатные антенны рассчитывали или перерисовали готовые? Корпуса для устройств какие будете использовать? Дальность работы пульта 500м — это предположительно или испытывали? Меры по уменьшению пикового тока батареи приняли?
Дык смысл из пересчитывать, если они подробно описаны. Корпуса в процессе отрисовки. Будет либо силикон, либо пластик. Может и то и другое в вариантах. Дальность еще не испытывал. Но реализация согласно референсного дизайна. Так что не думаю что будут какие то проблема.
Не получится. Не все так просто.
1. Интервал конкретно этого таймера 7200с — тут уже проигрываем, так как ночью можно вообще 5-6 часов поспать, а с учетом светового дня во многих регионах России, можно и по 8-10 часов спать.
2. Толк будет (если не брать в расчет первый тезис) только если подавать питание на все устройство через транзистор, который управляется ногой от TPL5111. Если ставить ее просто на ногу ESP, то мы просто получаем дополнительное потребление, пусть и маленькое, но сразу теряем возможность задавать свое расписание (например, днем раз в 2 часа, утро/вечер раз в час, ночью спим, например).

Для этого вообще есть другие микросхемы — RTC с календарем и интераптом.
Я видимо чего то не понимаю в цветоводстве. Ибо не вижу смысла измерять даже раз в час. либо у вас там какие то резко изменяющиеся условия. То гроза, то вишня заколосится, то неожиданно ветер сухой с пустыни налетит.
ну это же Джаст фо фан. И температура днём может резко меняться или точне ночью могут быть заморозки. А днём могут птицы все окно загадить и станет темно.
Ну тогда меняем батареи на аккумуляторы. И сверху прикручиваем солнечную панель. Добавляем контролер. Заодно по уровню заряда с нее будете брать количество света полученного за весь день. Добавить базу растений с их требованиями и можно еще рекомендации выдавать по размещению :)
Так и до блокчейна не далеко.
Именно, что бы всегда знать кто именно поливал цветочек последний раз. Для этого нам понадобится встроить RFID в горшок и в каждую лейку. Что бы лейки были именными.
А как же без внедрения искусственного интеллекта? Нейросети считывают движения листиков и переводят на человеческий язык. Нейросети обязательно что deep learning, что бы быть в тренде. :)
Можно подумать над электрической стимуляцией обязанного поливать человека. Шокер ему в кресло. :)
В общем ничем не ограниченное поле для фантазий «Джаст фо фан».
Зовите если еще идеи понадобятся.
Ну это вы уже через край взяли. Вот соберу статистику за полгодика и сделаю выводы о требуемой частоте замеров на моем балконе.
Мне кажется что вам уже известна эта статистика, если поливали раньше.
Но в целом, если хотите по существу.
Весь сенсор можно уменьшить в размер батареек, еще и место останется.
При вашем подходе при работе с электродами, они очень быстро корродируют/ «испарятся», что еще не очень хорошо для самого растения, всякие там металлы в почве. Best practice, электроды «меняют местами» программно. Но в вашем случае такое сложно. Либо есть специальные сенсоры для измерения влажности почвы, на шнурочке.
В общем есть еще над чем работать.
Да, обычный дуб.
Один недостаток — будут подтравливаться электроды. Надо делать одно измерение в 120-ть минут. Скажем. Далее отключать их — вообще.
Разве будут подтравливаться даже если лаком покрыты?
Ну пока под лаком все выглядит прилично.
можно посмотреть фото состояния погруженной в землю части платы через год эксплуатации?
Месяцев через 10 можно будет.
хм, название статьи — год измеряем влажность почвы…
Имелось ввиду, что батареек хватит на год. Чесслово не собирался вводить в заблуждение.
Я думаю что WiFi для этих целей далеко не лучший вариант. Существенно проще (в плане логики, кода и компонентов) я собирал по этому мануалу
НЛО прилетело и опубликовало эту надпись здесь
Девайс шлёт Сообщения на сервер, также может отправить Пуш уведомление на телефон. Главное чтобы дома WiFi работал.
НЛО прилетело и опубликовало эту надпись здесь
Это я видимо не на то ответил. По блютусу да, вариантов нет. WiFi в этом плане удобнее.
Bluetooth + телефон — это лишь один из вариантов. Еще может быть Bluetooth + дом. сервер (RPi, OrangePi и т.п.), вместо какого-то внешнего сервера. Сценарий о гибнущем цветке — вообще не реалистичный. Он вполне пару дней может постоять без полива. Если уж и заботиться на случай долгого отсутствия, то делать нужно автополив.
НЛО прилетело и опубликовало эту надпись здесь
Ну у всех свои правила игры в блекджек. )
А блутус вообще не вариант. Не говоря о самой глючности, когда блутус куда то отваливается по не понятным причинам, так ему еще нужно время на подключение, и все это время он жрет батарейку. Судя по вашему примеру, так вся конструкция вообще всегда включена и сжирает батарейки упаковками.
Так и на айфоне наверняка бубны нужны, чтобы работало.

Нафига полноценный блютус? С установлениями соединений для передачи данных и прочим? Используем режим маячков, т.е. просто передаём результаты измерений "в воздух", которые может ловить любой BLE-приемник. На Хабре была статья, как из nRF24 сделать передатчик и приемник. Длина полезных данных — байт 16, хватит для передачи измерений.
Энергопотребление на один пакет примерно 50 мА*мСек, т.е. при передаче раз в секунду среднее потребление порядка 50мкА, а раз в 10 сек — уже 5 мкА.
А самый главный вопрос — зачем питание датчиков делать батарейным? :) Светодиодное освещение полок с растениями — тоже батарейное? Или горшки с растениями постоянно по квартире перемещаются?

Питание делать батарейным нужно делать хотя бы с эстетической точки зрения, чтобы из горошков провода не висели. Проблемы не видно, когда мы имеем дело с одним лабораторным горшком. Если говорить о жилом помещении, то:
а) горшки стоят везде где можно (шкафы, полки, подоконники и т.п.)
б) их много
Проводное решение вопроса ну будет оценено по достоинству домашними. Более того, каждый горшок придется оснастить блоком питания.

У меня есть более интересное предложение — солнечные батареи.
Небольшая по площади батарея вполне может давать 3 мА в пасмурную погоду. Нормальному устройству достаточно 100 мкА.
Батарейный блок все равно потребуется для пускового тока (он порядка 16 мА) — это как в машине аккумулятор. Однако, это очень редкое событие, остальное время батарейки расходоваться не будут.
Здесь у Вас в каждом предложении заблуждение. Bluetooth работает очень стабильно в т.н. режиме iBeacon (радиомаячок). В этом режиме с коллосально низким энергопотреблением (10-20 мкА) отправляется нужная информация (влажность, температура, батарейка и все что душе угодно). Подключаться не нужно совсем. Расход батарейки определяется в первую очередь алгоритмом, во вторую умением снизить энергопотребление микроконтроллера. Практические изыскания показывают, что при частом измерении параметров (для построения динамичных графиков), батареек хватает на месяцы.
Есть ещё куда стремиться. Вот чем хорош Xiaomi Smart Flower Monitor — так это тем, что он умеет ещё измерять количество минеральных веществ, и имеет обширную базу данных для 3000+ растений на смартфоне, с учётом необходимой целевой влажности и количества миниральных веществ.
Вот же хитрецы, все вперед нас сделали.
Слизали с нас, точно говорю…
146% украли вашу идею.
Один уже успел даже на кикстартере денег собрать под нее.
гыгы
Ого, больше ста баксов.
Изготовление матрицы для выдавливания корпуса из пластика начинается от 25К баксов. Да и на принтере не очень дешево по итогу выйдет. Я для своих прототипов печатал SLS и на обычном. И то и то кусается.
Так что минимальная партия должна окупить все побочные затраты на изготовление всякой оснастки.
Заголовок спойлера




> Изготовление матрицы для выдавливания корпуса из пластика начинается от 25К баксов. Да и на принтере не очень дешево по итогу выйдет.

Первая ссылка в гугле говорит о цифре ниже $3000.
Цифры обычно очень рознятся, все зависит от типа пластика, материала формы, количества и размера отливаемых деталей и т.д. На партию меньше 1000 обычно цена в любом случае будет дико кусачая.
Там говорится ОТ… вы копните поглубже… удивитесь страшно.
Я знаю про все сложности и цене изготовления красивых корпусов.
И свой коленочный прототип без корпуса — всегда дешевле будет стоить.
но сто баксов, это сто баксов.
Ну так там себестоимость плюс мечты инвесторов и мечты разработчика. Выглядит красиво и как законченный продукт
как показала практика и при 75 кГц результаты измерений влажности достаточно точные и отражают состояние почвы.

Посмотрите еще 80 Мгц решение — его сделали на базе промышленного, возможно, вам будет интересно сделать такой вариант.
Не подскажете, что подразумевается под 100% влажностью почвы? Я не могу понять. С нулём понятно — землю высушили, пропекли в духовке — и вот он ноль (пока почва не успела набрать чуть влажности из воздуха). А вот со 100% что? Это 100% от влагоемкости(льем больше — вода почвой уже не впитывается, появляется на поверхности), соотношение 1 к 1 объемов воды почвы или же соотношение масс?
У меня 100% влажность — это когда до входа АЦП ничего не дошло. А 0% — это когда дошло ровно все, что было отправлено. В какую то более сложную физику (влагоемкость) я не вдавался.
В целом интуитивно, когда шкала показывает 100%, земля объективно мокрая.
Вещь интересная, скажите, эта разработка имеет отношение к смартпотам?
Нет, к таким горшкам отношения не имеет. Это решение конкретной задачи по отслеживанию пересыхания почвы в горшках. Но все возможно.
Возможно, что наша разработка куда то и вырастет в будущем.
Лично мне кажется, что вам дорога именно к этим вещам, а они как раз набирают популярности.
Имею внешний датчик на esp8266 который по wifi отдаёт данные и уходит в ESP.deepSleep на 5 минут. В логах роутера (ubuntu) его работа выглядит так:
log
hostapd: wlan0: STA esp-mac-address IEEE 802.11: authenticated
hostapd: wlan0: STA esp-mac-address IEEE 802.11: associated (aid 2)
hostapd: wlan0: STA esp-mac-address RADIUS: starting accounting session 5AC7A992-00000088
hostapd: wlan0: STA esp-mac-address WPA: pairwise key handshake completed (RSN)
dhcpd[2069]: DHCPDISCOVER from esp-mac-address via wlan0
dhcpd[2069]: DHCPOFFER on 172.30.2.7 to esp-mac-address via wlan0
dhcpd[2069]: DHCPDISCOVER from esp-mac-address via wlan0
dhcpd[2069]: DHCPOFFER on 172.30.2.7 to esp-mac-address via wlan0
dhcpd[2069]: DHCPREQUEST for 172.30.2.7 (172.30.2.1) from esp-mac-address via wlan0
dhcpd[2069]: DHCPACK on 172.30.2.7 to esp-mac-address via wlan0
dhcpd[2069]: DHCPREQUEST for 172.30.2.7 (172.30.2.1) from esp-mac-address via wlan0
dhcpd[2069]: DHCPACK on 172.30.2.7 to esp-mac-address via wlan0
hostapd: wlan0: STA esp-mac-address IEEE 802.11: disassociated
hostapd: message repeated 9 times: [ wlan0: STA esp-mac-address IEEE 802.11: disassociated]
hostapd: wlan0: STA esp-mac-address IEEE 802.11: deauthenticated due to inactivity (timer DEAUTH/REMOVE)


т.е. esp-шка не отключается нормально от роутера, а просто вырубается. Немного напрягает это дело. Как правильно сделать отключение? WiFi.disconnect() никак не влияет.
Никогда не думал, как Deep Sleep «выглядит» со стороны роутера, но подозреваю, что возможно, для правильного отключения надо сначала выполнить такие команды:
WiFi.mode(WIFI_OFF);
WiFi.forceSleepBegin();
Попробовал. Ничего не изменилось в логах.
Видимо ESP не умеет более цивильным способом отключаться.
У ESP есть интересный режим работы — ESP-now.
Без Wi-Fi и IP. Время соединения значительно сокращается.
Здесь кратенько рассказано — youtu.be/6NsBN42B80Q
Спасибо, очень интересно посмотрю.
С ESP32 пока дел не имел, но там вроде есть такая же поддержка Ardiono IDE как в 8266.
В ESP8266 тоже есть поддержка ESP-now.
А как вам вариант поставить аккумуляторную батарейку и солнечную панель?
И еще вопрос, сколько у вас всего таких устройств установлено?
Солнечная батарея и аккумулятор — это существенное усложнение конструкции. И плюс это достаточно громоздкая штука, я бы пожалуй не хотел такого у себя на балконе.
Установлено пока несколько штук на тестах.
Правильный совет, между прочим. Усложнение небольшое, а на балконе можно было и от сети запитать.
Зарегистрируйтесь на Хабре, чтобы оставить комментарий

Публикации

Истории