Началось всё с того, что я захотел повысить мощность двигателя автомобиля установкой компрессора.
В процессе понадобилось разобраться с Arduino и написать алгоритмы автоматического управления реальными устройствами, формально - управление всего одним моторчиком, но на практике - выявилось несколько подводных камней, о которых не подозреваешь в начале.
Разработка и особенности управления "реальными" устройствами с позиции человека, который раньше не работал ни с Arduino, ни тем более не управлял какими-то устройствами - показались интересными для написания статьи.
Алгоритмы получились посложнее, чем "помигать светодиодом", но с точки зрения опытных разработчиков подобных систем, которые знают все нужные алгоритмы - наверняка покажутся наивными, тем более, в автоиндустрии всё это давно отлажено - в машинах много лет стоят контроллеры управления различными подобными устройствами.
Идея
Статья не про автомобили, а про разработку, поэтому об исходной идее расскажу коротко.
Компрессор для двигателя автомобиля - это простой способ повысить мощность атмосферного двигателя. Нагнетателей воздуха существует несколько вариантов (электро, турбины), но в данном случае мы говорим о том варианте, который описан чуть ниже.
Компрессор - это такой вентилятор в закрытом корпусе, который за счёт передачи ему вращения от двигателя - быстро вращается и нагнетает в двигатель автомобиля больше воздуха, чем двигатель мог бы "взять" самостоятельно. В результате работы компрессора на "входе" в двигатель создаётся избыточное давление. Не ~100 кПа (1 бар), а предположим 200 кПа (2 бара). Компрессор как бы "утрамбовывает" воздух в двигатель. Больше поступление воздуха = больше потребляемого бензина = больше мощность двигателя.
Схем установки компрессоров несколько, выбрал самую "феншуйную". В такой схеме компрессор устанавливается перед двигателем. Между компрессором и двигателем установлена так называемая "дроссельная заслонка". Дроссельная заслонка по-умолчанию закрыта. Когда водитель нажимает педаль газа - заслонка открывается, воздух начинает поступать в двигатель, двигатель начинает громко жужжать.
Возьмём обычный атмосферный двигатель. Перед дроссельной заслонкой обычное атмосферное давление, когда заслонка открывается - двигатель "засасывает" в себя нужный объём воздуха. Когда заслонка закрывается - двигатель просто перестаёт "засасывать" воздух.
Когда устанавливается компрессор, всё становится немного иначе и начинаются проблемы. Представьте, что заслонка открыта, компрессор работает, создаёт большое избыточное давление и водитель резко отпускает педаль газа. Заслонка резко закрывается и избыточному воздуху становится некуда уходить - в двигатель его не пускают, а между компрессором и двигателем обычная трубка, уходить уже некуда. Компрессор в такой ситуации страдает.
Существует простое решение это проблемы - например, "блоу офф". Это такой клапан, который ставится в зоне избыточного давления и при достижении определённого избытка открывается и выпускает лишний воздух, при этом создавая лишние звуки.
Но мне хотелось "феншуя", поэтому был выбран способ, практик которого я не нашёл на авто-просторах русскоязычного интернета: установка перепускного клапана в виде дополнительной дроссельной заслонки (далее ДДЗ) с электронным управлением и автоматизация управления ей на основе контроллера на Arduino.
Упрощённая схема работы показана на картинке. Избыток воздуха попадет через открытую ДДЗ на вход компрессора и компрессор начинает гонять этот воздух по кругу, не создавая избыточного давления.
Кроме отказа от блоу-офф, такая схема работы позволит ездить в полностью атмосферном режиме, включая и выключая компрессор по необходимости. Когда компрессор выключен - ДДЗ полностью открыта и воздух свободно поступает в двигатель.
Я - бэкендер. Пишу всякий разный бэкенд под всякий разный интернет. Опыта написания под Arduino не было. Знаний алгоритмов управления "реальными" устройствами нет. Стал писать всё с чистого листа, предполагая, что всё просто. Оказалось, что всё не просто.
Исходная идея (и алгоритм) казались простыми: есть датчик атмосферного давления (ДАД1) до основной дроссельной заслонки (далее ОДЗ) и есть дачик давления после ОДЗ (ДАД2). На основе этих датчиков мне и нужно было открывать ДДЗ, когда есть избыток воздуха, ориентируясь на ДАД1, и закрывать, когда избытка нет, но он нужен, ориентируясь на ДАД2.
Но сначала немного о подборе комплектующих.
Комплектующие
Подбор комплектующих для разработки под Arduino - элементарен. Все те компоненты, которые мне понадобились - хорошо описаны, под многое есть готовые библиотеки или алгоритмы.
Arduino UNO R3. Сама плата ардуино. Видимо, китайская реплика, раз продавалась на Алиэкспрессе. Выбрал среднюю между Mini и Mega, примерно посчитав требуемое количество входов. Аналоговых входов в итоге не хватило из-за добавления дополнительных компонентов.
74HC4051. Мультиплексор. Позволяет расширить количество аналоговых входов, подавая на вход разные комбинации цифровых сигналов. Цифровых входов оставалось достаточно, что позволило использовать эту схемку.
BTS7960 43A H-bridge. Драйвер управления заслонкой. Позволяет управлять вращением мотора в разных направлениях с задаваемой скоростью. Выбран с запасом по мощности.
ACS712. Амперметр. Нужен для отключения системы в случае превышения тока, потребляемого заслонкой. Позже в BTS7960 обнаружил аналогичный функционал, но этот компонент оставил как резервный.
DC-DC 12v-9v и DC-DC 12v-5v. Преобразователи напряжения. Первый служит для питания системы. Второй - для отслеживания выключения системы, чтобы привести систему в "нормальное" состояние.
Регтайм 3-12 60-600. Реле задержки выключения. Когда систему выключаем кнопкой - нужно продолжать подачу питания в систему, чтобы привести её в "нормальное" состояние.
Пищалка. Для диагностики неисправностей не подключая ноутбук.
HW-316. Реле на 4 канала для включения компрессора и компонентов системы охлаждения.
Датчик атмосферного давления со встроенным датчиком температуры. Два датчика. Датчики температуры - для управления системой охлаждения. Датчики атмосферного давления - для управления заслонкой. Датчики температуры - резисторы и их "чтение" отличается от других датчиков, используется так называемый опорный резистор.
Заслонка ВАЗ 21126. В состав заслонки кроме мотора входят два датчика положения дроссельной заслонки.
Так выглядит текущий вариант схемы.
После сборки схемы, используя макетную плату и комплект проводов, началось самое интересное - написание алгоритма. Итак, собственно, подводные камни.
Подводные камни
Первая особенность. Считывание напряжения с аналоговых входов Arduino
В алгоритме работы мне нужно считывать данные с датчиков. Типовой датчик состоит из двух входов и одного выхода: минус, базовое напряжение и выходной сигнал.
Базовое напряжение в большинстве случаев - 5 вольт. Выходной сигнал меняется от 0 до 5 вольт. Применительно, например, к датчику положения дроссельной заслонки: 0 вольт - заслонка закрыта, 5 вольт - заслонка открыта, промежуточные значения - промежуточные положения заслонки.
Принцип чтения значения такого датчика: выходной сигнал подключается к аналоговому входу Ардуино и в программе мы получаем возможность чтения значения в виде целого числа в интервале 0-1023. Это значение "мапится" хоть на вольты, хоть сразу на процент открытия заслонки.
Оказалось неожиданностью то, что граничные значения датчиков "плавают" в достаточно большом диапазоне в зависимости от:
температуры в помещении - показания ненамного, но отличаются;
от "прогрева" системы - сразу после включения показания немного, но отличаются от тех, что выдаются позже;
вероятно, от качества соединения проводов в монтажной плате, лишнего сопротивления из-за длины;
вероятно, от качества преобразования питания в DC-DC плате, что ведёт к "плаванию" базового напряжения.
Проблему изначально предполагал, но не думал, что погрешности будут такими большими. После того, как схема будет спаяна в постоянном виде, чтобы исключить плохой контакт - буду замерять напряжение в узловых местах, чтобы понять, кто вносит наибольшую погрешность и по возможности снизить её.
Решение проблемы - калибровка датчиков. Выставление минимального и максимального значения сигнала датчика в крайних положениях. Сейчас в коде используются подобранные константные значения.
Решение №2 - в дальнейшем, возможно, будет периодическая само-калибровка с сохранением состояния в энергонезависимую память.
Решение №3 - подбор качественных DC-DC преобразователей, качественный монтаж.
Как пример всей беды - сейчас датчик положения дроссельной заслонки откалиброван на напряжения 0,5-4,2 вольта, вместо идеальных 0-5 вольт.
Вторая особенность. Калибровка "противоположных" датчиков
Дроссельная заслонка устроена интересным образом - в её составе есть два датчика положения. Датчик 1 выдаёт напряжение тем больше, чем больше заслонка закрыта. Датчик 2 выдаёт напряжение тем меньше, чем больше заслонка закрыта.
На примере: при закрытой заслонке датчик 1 в идеале выдаёт 5 вольт, датчик 2 - 0 вольт.
Предполагая, что два датчика сделаны для отказоустойчивости - я сделал алгоритм оценки положения, основываясь на датчике 1, при этом сверяясь с датчиком 2, в случае расхождения показаний больше граничного значения - система уходит в режим ошибки.
В процессе же работы с заслонкой - получил необходимость периодически калибровать граничные значения датчиков, в итоге достаточно сильно их снизив.
Из-за этого стало закрадываться подозрение, что два датчика нужны не для отказоустойчивости, а как раз для некой самобалансировки и вычисления положения в зависимости от взаимных значений.
После сборки системы и отладки на реальном "железе" подумаю над пересмотром алгоритма использования датчиков в направлении вычисления положения, основываясь на двух значениях.
Также у драйвера управления дроссельной заслонкой есть возможность чтения используемого тока, что позволит калибровать крайние значения заслонки, предполагая увеличенное потребление тока, когда заслонка открылась в крайнее положение и пытается открыться дальше.
Третья особенность. Разные показания датчиков
Казалось бы - одинаковые датчики, но выдают разные показания. Что датчики температуры, что давления, что положения заслонки. Например, в одинаковых условиях датчики давления показывают разницу в 1,4 кПа.
Проблема предполагалась изначально и очевидное решение - калибровка.
Четвёртая особенность. Это реальный мир
Особенность управления мотором заслонки через драйвер типа H-bridge - для перемещения заслонки Arduino даёт команду на движение в нужном направлении с требуемой скоростью. Драйвер получает команду и начинает двигать заслонку. Алгоритм в это время может переходить к выполнению другой логики.
Вот здесь и началось интересное поведение заслонки.
Первый вариант алгоритма управления был очень простым: проверяем процент открытия заслонки, даём команду на движение и переходим к другим частям алгоритма, возвращаемся, проверяем процент открытия и всё по новой.
Алгоритм был написан, работал до тех пор, пока я не стал отлаживать другую его часть. В какой-то момент, я включаю дополнительную отладку и заслонка начинает двигаться рывками: то не двигается, то сразу закрывается рывком, то начинает открываться-закрываться.
Проблема оказалось неожиданной: пока другая часть кода писала отладочные данные в COM порт, а это происходит медленно, если выбрана медленная скорость передачи данных - заслонка успевала закрыться намного сильнее, чем требуется.
Решение - ориентироваться на таймер, привязывать начало действий ко времени, рассчитывать требуемое положение "вперёд" в любой нужный момент времени.
В упрощённом виде алгоритм стал таким: при начале движения заслонки фиксируется время начала движения, в любой другой момент времени, когда мы получили управление - требуемое положение заслонки вычисляется в зависимости от прошедшего времени и принимается решение, что делать дальше - останавливать, продолжать движение или начинать движение в обратном направлении.
Пятая особенность. Резонанс
Получается из предыдущей особенности. Когда мы хотим привести заслонку к нужному проценту открытия - мы даём команду на движение в нужном направлении с заданной скоростью. Когда мы в следующий раз попадаем в контролирующую часть алгоритма - заслонка может быть открыта больше, чем нам нужно. Даётся команда движения в противоложном направлении. В итоге могут возникнуть постоянные незатухающие и даже увеличивающиеся колебания заслонки.
Проблема решается просто - определяется допустимая погрешность на достижение нужного процента и вводится временной параметр, не позволяющий изменять направление движения, чаще, чем требуется.
Шестая особенность. Переполнение целых чисел
В Arduino рекомендуется работать с целочисленными значениями. Работа с вещественными числами медленнее.
В моих алгоритмах нет сложной логики, которую замедлили бы расчёты с вещественными числами и не люблю преждевременную оптимизацию (люблю разумную оптимизацию), но вот решил использовать расчёты с целыми числами.
А так как для значений выбирались подходящие типы, то после математических операций в какой-то момент оно выстрелило в ногу. Проблема понятная, легко отлаживается, но уж очень давно не работал на бэкенде с целочисленной математикой.
Седьмая особенность. Отладка
Тестирование различных бэкендов - просто и незатейливо. Можно написать тест логики, который проверит написанную функцию. Можно написать интеграционный тест, который проверит взаимодействие с другой системой.
В случае же с системой, которая работает с реальными устройствами, датчиками и которая может вести себя по разному в казалось бы одинаковых условиях - тестирование написанной логики превращается в занимательные упражнения.
Изначально хотел делать по принципу "мы не ищем лёгких путей" - написать код, поставить "железо", отлаживать на машине (конечно, не во время движения для начала).
Потом мне посоветовали сделать эмулятор для всего этого.
Сначала подумал об эмуляторах электронных устройств, когда программа устанавливалась бы на эмулятор ардуино и работала бы с полностью эмулированным железом. Такое ПО, да, существует, но под него, как понял - пришлось бы написать все эти эмуляторы всех устройств. В общем, этот путь для автокорпораций с отделами на тысячи опытных разработчиков.
Итоговый выбранный вариант: сделан физический эмулятор педали газа, написан эмулятор двигателя, компрессора, датчиков, подключён как отдельный компонент к основной программе, запускается на том же Ардуино. Тестирование проводилось на стенде, используя графики, построенные по передаваемым с устройства данным. В VSCode плагин визуализации графиков из COM порта, кстати, удобный.
Алгоритм
Архитектурно алгоритм разбит на четыре части:
Часть управления дроссельной заслонкой. Назначение - получает на вход команду приведения заслонки к требуемому положению в процентах 0-100 и далее независимо у себя "внутре" приводит заслонку к нужному положению, ориентируясь на показания датчиков положения, потребления тока, таймауты и так далее.
Часть основного контроля. Назначение - по показаниям датчиков давления понимает нужен наддув или нет, нажал ли сейчас водитель педаль газа или отпустил, или нажал и удерживает в неком среднем положении для равномерного движения. Вычисляет требуемое положение заслонки, даёт команду первому компоненту на установку нужного положения.
Часть дополнительного контроля. Назначение - включение/выключение компрессора, включения системы охлаждения (водяная помпа, вентилятор) в зависимости от датчиков температуры, сбор отладочной информации, обработка ошибок и граничных значений.
Часть эмулятора двигателя. Входит в основную программу как отдельный компонент, включается флажком в коде.
Часть управления дроссельной заслонкой
Первая часть алгоритма принимает на вход требуемое положение, запоминая его. Далее периодически рассчитывает промежуточное положение, передавая его во вторую часть алгоритма.
Расчёт промежуточного положения зависит от того, открывается заслонка (открываемся быстро, делаем "blow-off") или закрывается (закрываемся медленно, постепенно повышая наддув, плавное нарастание мощности). Как уже упоминал выше в "проблемах" - расчёт промежуточного положения зависит от времени начала движения и привязан к моменту времени, так мы в каждый момент знаем, какое положение требуется - независимо от того, прошла 1 мсек или 10 мсек с прошлого расчёта.
Вторая часть алгоритма принимает на вход промежуточное положение и обеспечивает его достижение, контролируя включение мотора.
Такое разделение можно назвать макро и микро-менджмент - оно позволяет обеспечить плавное движение в условиях постоянного изменения требуемого положения. Первая часть при этом обеспечивает соблюдение привязки времени начала движения, это важно при изменении на движение в противоположную сторону.
Пример: если заслонка в настоящее время закрывается, а новое требуемое положение означает, что нужно продолжать закрываться - изменения привязки времени не происходит, продолжая плавное закрытие заслонки.
Часть основного контроля
Первая часть алгоритма ответственна за определение того, что делает водитель - нажал на педаль газа или отпустил педаль газа. Решение делается путём оценки нескольких значений давления за константные периоды времени: постоянно растёт давление - педаль газа нажата, постоянно понижается - педаль газа отпущена.
Вторая часть алгоритма рассчитывает положение по относительно простым условиям (упрощённо):
если педаль газа нажата и давление после основной дроссельной заслонки (ОДЗ) растёт - хотим закрыть дополнительную дроссельную заслонку (ДДЗ) полностью, чтобы сделать наддув;
если педаль отпущена и давление ниже лимита (ОДЗ закрыта) - выпускаем избыток воздуха, открываем ДДЗ полностью (делаем "blow-off");
в остальных случаях поддерживаем давление до ОДЗ чуть больше давления после ОДЗ немного приоткрывая или призакрывая ДДЗ - стабильное положение, когда педаль газа немного нажата и машина просто равномерно движется примерно с одной скоростью.
Третья часть приводит рассчитанное положение к требуемому с учётом таймаутов и передаёт команду на контроль в часть управления заслонкой.
Часть дополнительного контроля
Эта часть не содержит какой-то интересной алгоритмической логики. В основном здесь используются простые условия вида: температура воздуха выросла до граничного значения - включаем помпу, ещё больше выросла - включаем вентилятор.
Также здесь есть возможность выключать компрессор в случае длительного холостого хода - долго стоим на светофоре или машина припаркована с включённым двигателем.
Часть эмулятора двигателя
У эмулятора есть физическая педаль газа в виде реостата (переменного резистора) - это такой ползунок, который может двигаться между двумя позициями, в коде мы знаем насколько он сдвинут - на 0% или на 100%. Ничем не отличается от электронной педали газа.
В эмуляторе есть значение текущих оборотов двигателя. Нажимаем немного педаль газа - обороты начинают расти. Нажимаем педаль газа сильно - обороты начинают расти, но быстрее.
Дальше есть значение эффективности работы компрессора. Компрессор на разных оборотах двигателя сжимает воздух с разной эффективностью - на малых оборотах сжатие менее эффективно. Для расчёта взят график эффективности примерно похожего компрессора и упрощён: рассчитываем эффективность по линейной формуле плюс учитывается точка перегиба - когда график сильно меняет наклон. За эту точку взял 2000 оборотов.
Дальше рассчитывается чистое давление перед ОДЗ, которое мог бы выдавать компрессор если ДДЗ закрыта. Оно зависит от эффективности и косвенно от оборотов.
Далее идёт расчёт давления перед ОДЗ, но с учётом положения ДДЗ. Положение ДДЗ берётся реальное. ДДЗ закрыта - давление максимально выдаваемое рассчитанное. ДДЗ открыта - давление минимальное (атмосферное), воздух "ходит по кругу".
Последнее рассчитываемое значение - давление после ОДЗ (непосредственно на входе в двигатель) - берётся предыдущее значение и к нему по похожей формуле применяется положение ОДЗ, а оно берётся равным положению педали газа. Педаль газа полностью нажата = ОДЗ полностью открыта - давление = рассчитанному давлению перед ОДЗ.
Таким образом получается система с прямой связью от педали газа и с обратной связью от реального значения положения ДДЗ, которая сама зависит от педали газа. Но работает. Примерно похоже на реальный двигатель, хотя я понимаю, что на машине оно будет вести себя иначе.
Демонстрация
Демонстрация работы получившегося прототипа на стенде.
То же самое, но на графиках.
Пояснение по видео с графиками. После записи видео заметил, что в одном моменте видео графики противоречат моим комментариям. Когда нажимается педаль газа без включения компрессора - растёт давление наддува до основной дроссельной заслонки. Так происходит потому, что в эмуляторе не предусмотрел учёт флага включения компрессора. Тестам открытия дополнительной дроссельной заслонки это не мешало, поэтому и заметил только сейчас. Если бы флаг учитывался, то правильно было бы так, как говорю в комментариях - на графиках бы было нормальное атмосферное давление.
После установки "железной" части системы и отладки уже на настоящих датчиках, педали газа, моторе, компрессоре - продолжу описание новых особенностей в следующей статье: Часть 2. Отладка на авто (здесь будет ссылка).
Комментарии (53)
twid
30.03.2024 16:20(промахнулся, это ответ SakHax =( )
(а) Автор перечислил лего, которое он использует, но не вижу, чтобы поинтересовался куда втыкает-то. Если б автор поинтересовался, как интересно люди пишут не под ардуино и ему подобное, он бы так не горячился)
(б) Ну да, это я молодым крылья обламываю, раз ругаю. Ведь у бэкендера возникла идея, ведь у него есть алгоритм - конечно, первым петпроектом в самолет надо лезть) Вообще не вопрос.
ptr128
30.03.2024 16:20+1Заслонка, как и любая механика, обладает инертностью. Классическое решение в этом случае - ПИД регулирование.
jonic
30.03.2024 16:20ну во первых с почином.
Во вторых секу3.
в третьих, когда я захотел машину мощнее я купил машину мощнее :)
Тем не менее, заниматься такими экспериментами круто и интересно, правда когда это еще будет работать стабильно - вопрос.
Я сейчас тоже размышляю на тему тестовых стендов и уюнит тестирование компонентов по на мк. Но пока что я дособираю стенд прошивки 10 комплектов плат и сбора с них логов в локи.
neenik Автор
30.03.2024 16:20Прочитал, что такое секу3. Интересно, но избыточно для моего случая. Полное перестроение системы управления двигателем. И если под свой ЭБУ я могу найти настройщика (буду не сам настраивать), то под этот - только самому учиться.
Но его плюсы - чуть-ли не рантайм настройка (и опенсорс), что здорово.
jonic
30.03.2024 16:20Советую ютуб канал совжесть :) оттуда я про этот секу3 и узнал. Там вообще много чего интересного происходит..
f29r
30.03.2024 16:20Из материала не понятно вообще, какую характеристику обеспечивает этот програмно-аппраратный комплекс.
Модельному управлению ДВС идёт 4й десяток лет. И критерий управляемости давно один единственный: обеспечить соответствие фактического момента на валу заданному.
Положение байпасной заслонки это инструмент, такой же как подача топлива, искра, положение вала и куча прочего чего в мотор могли напихать, да хоть управление подъёмом клапанов, многоступенчатый егр, управляемый термостат... фантазии не хватит перечислить всё.
Если переходить на язык BE, то увиденное сродни попытке написать свое решение для доступа к данным, потому что ADO слишком большое и фундаментальное
Но это все не имеет значения когда просто интересно покопаться в чем-то новом для себя.
З.ы. код в системах управления двс руками не пишут пару десятков лет повсеместно, и 30+ у отдельных поставщиков этих систем.
neenik Автор
30.03.2024 16:20Комплекс обеспечивает всего-лишь управление байпасом в рамках глобальной задачи поставить наддув на атмосферный мотор.
Модельное управление двигателем - без сомнения, в заводском производстве или автоспорте берётся какой-нибудь, упомянутый выше, секу3 и полностью управляет всем.
У меня же гражданское авто и не ультимативное, а компромиссное решение. С точки зрения разработки - классическая подпорка.
Подпорка понимает, что нужно вдуть больше воздуха и вдувает. А дальше пусть там двигатель сам решает, что с этим воздухом делать.
f29r
30.03.2024 16:20+2Secu занимается тем же, чем и ваше решение: пришёл, увидел, наследил. Я кода не видел, но рискну предположить что он написан руками, так делали в 80-90 годах прошлого века...
Какой-нибудь захудалый BOSCH для своих решений генерирует код по модели, к ней в придачу сразу и пачку тестов на логику, граничные условия, отказ, производительность в целом и каждого кусочка в отдельности. Т.е. давно делает то, о чем спустя много лет в мире энтерпрайза напишут тысячи книг, потом призовут на помощь AI...
И уже в те годы инженеры знали множество занятных вещей вроде того как шумит АЦП, как пульсирует давление воздуха на впуске или его расход, что температура, которую показывает датчик это совсем не та величина, на основании которой можно вести непосредственный расчёт чего бы то ни было, как и показания любого другого датчика.
Чтобы просто пересказать как работает чтение датчика электронной педали, и как оно превращается в реальное положение, только на общее описание понадобится пару страниц текста, а описание алгоритма защиты от сбоев вызовет у BE разработчика бурю эмоций из смеси непонимания с восхищением. Там будет все что угодно, минимизированная и очень быстрая целочисленная математика с размерностью в одно машинное слово, нулевая зависимость от любых библиотек кроме собственных, аппаратные решения вплоть до отдельного контроллера рядом с основным. У вас я даже watchdog не заметил.
Отдельным подарком будет сама плата ардуино, особенно если на ней не установлен reset-контроллер. Те, кто с atmega в авто много работают, знают, что можно повернуть ключ на старт, и через секунду прошивка контроллера покинет чат. Это, можно сказать, классика атмеги.
Если идти дальше, то любая автоэлектроника - она ведь realtime, с чётко заданным временным растром для каждой операции. А что кроме вашего кода работает на вашем контроллере кроме вами написанного кода - без поллитра не разобраться. Вы вот педаль отпустите, а оно вместо того чтобы дроссель открывать, сначала пожжужжит шестеренками в счетчике микросекунд и менеджере шим, которыми вы, наверно, и не планируете пользоваться. Но приоритеты же не вы расставляли.
Вобщем, добро пожаловать в загадочный и чудесный мир реалтайм эмбедщины :)
rcl
30.03.2024 16:20Кошмар полный. Автору надо бы в институт поступить, теорию автоматического управления поучить хотябы чуточку, техническую электронику хоть немного.
На условных операторах далеко не уедешь.
neenik Автор
30.03.2024 16:20+1Отучиться в институте, чтобы установить компрессор в авто как хобби-проект. Ваша рекомендация - пока самая необычная в списке.
rcl
30.03.2024 16:20Учиться надо не для того чтобы вставить компрессор, а для того, чтобы писать статьи на Habr нормальные. Нельзя так не уважать читателя.
neenik Автор
30.03.2024 16:20+2К счастью для пытливого читателя, в шапке упомянуто и отсутсвие первоначального опыта, и качество алгоритмов и цель статьи - рассмотрение подводных камней подобной разработки с позиции неопытного разработчика.
ovn83
30.03.2024 16:20Этими чарджерами увлекались 20 лет назад, на Ютубе сейчас на канал наткнулся, там человек на 2114 сейчас проходит по граблям.
Ардуино для детских поделок, в машине ему не место. Один автозапуск на нём сделал, не понимая, что может машину сжечь.
lost_embedder
30.03.2024 16:20+4Люблю интернет за потрясающую доброту комментариев. "Автор, ну куда ты полез, да еще статью об этом написал, все совсем не так". Что характерно, как должно быть "так" - никто не рассказывает, пока статью не напишешь :)
1) Респект за статью. Дельно и по существу. Может, и изобретение велосипеда (не знаю, никогда не смотрел на процессы разработки софта для automotive), но очень предметное и полезное. ИМХО, один из главных плюсов статьи - подробное описание встреченных граблей. Это та информация, которой не делятся производители. И в то же время - это ценный источник компетенций.
2) Есть у меня подозрение, что при всем опыте того же боша - не так уж там все гладко. В конце концов, не на ровном месте у них столько версий систем управления. так что заходы типа "делают совсем не так" и "прогоняют миллионы тестов", имхо, не относятся к делу.
3) Про электронную педаль.
"физическая педаль газа в виде реостата (переменного резистора) - это такой ползунок, который может двигаться между двумя позициями, в коде мы знаем насколько он сдвинут - на 0% или на 100%. Ничем не отличается от электронной педали газа."
Душню, но: электронная педаль газа - тоже с двумя резисторами. Только обычно не "противоположно направленными", а подобранными так, чтоб на выходе одного всегда напряжение было в два раза выше, чем на выходе второго.
4) Не знаю, доводилось слышать или нет про проект опенсорсного блока управления двигателем - https://rusefi.com/
Возможно, пригодится. Или нет.
REPISOT
30.03.2024 16:20+3Нулевой подводный камень - это выбор Arduino. У него несколько фундаментальных проблемм:
1 Прошивка.
Прошивку обсуждать не буду, есть множество материалов по этой теме. В двух словах – применять такой код в ответственных местах – не лучшее решение. Но для быстрой проверки возможности реализации - пойдет.
2 Схемотехника.
Схема платы Arduino сделана максимально упрощенно. Для обучения на столе. И даже так выявляется множество недостатков. Самый главный – это отсутствие фильтров по питанию. Вот пример, как должно быть. Это Минимальный уровень. В руководстве по ЭМС от Atmel (а теперь - Microchip) Фильтров сильно больше.
Hidden text
А вот так - на плате. Отмечены ножки 4 и 6 - VCC. Видите возле них конденсатор? Если что, на обратной стороне монтажа нет.
Hidden text
А он есть. На схеме.
Hidden text
А на плате - вот он. С такой разводкой он просто не работает.
Hidden text
Поэтому в том числе и плавают показания. А для применения в авто надо рассчитывать фильтры и защиты на автомобильную бортсеть, с ее уровнями напряжений, выбросов, помех.
sansar
30.03.2024 16:20+1тоже делал курсовую по внедрению наддува на ВАЗ (только основой был расчет рабочего колеса).
Ардуине - не место в машине только по причине неудачного опыта определённой группы экспериментаторов. Однако оно более распространено в мире чем январи.....причём последние не имеют всенародной любви и намеков на непогрешимость.(p s. - про "ковчег" и "титаник").
Обязательная основа эксперимента - ожидание хоть какого конкретно результата....иначе не поймёшь удачен он или нет. У автора есть ожидание.
Приведение концепта к нормам отказоустойчивости для авто применения - другой этап разработки.
p.s. ст.12.5 - никто не отменял.
JaAlex
30.03.2024 16:20Arduino меееедленннннаааяяяя :)
STM, наверно, надо использовать, но кодить поначалу сложнее.
twid
Автор статьи, прими мои извинения за нижеследующий комментарий. Кажется, возраст сказывается и не лучшее настроение. Извини.
Вы первый раз изучаете Arduino. И суете его в автомобиль.
(а) Налейте себе вкуснейшего чая или кофе, сходите на улицу, устройтесь на лучшей скамейке с видом на оживленное транспортное движение - и пока пьете, подумайте вот о чем... Что случится на дороге, если у любой машины резко откажут тормоз-газ-поворот руля.
Когда у вас возникла потрясающая идея что-либо совать в авто, у вас никакой стоп-сигнал не сработал аля "что-то может пойти не так"? Вообще?
*вздох* Когда у вас возникнет идея оптимизировать газовую плиту в квартире, очень вас прошу, предупредите соседей по подъезду. Пожалуйста. Они не виноваты.
(б) ВАЗ имеет репутацию автопроизводителя, чья продукция работает лучше швейцарских часов? По части механики, по части электроники...Можно arduino совать, нормально)
Я вот шуруповертом вчера работал, пойду его в ВАЗ суну, яжинженер. Разве не для того мне небо дало шуруповерт, чтобы я не нашел ему применения?)
(в) Вы сначала сунули в карнавал ВАЗовской электроники свой arduino, а потом выяснили что "оказывается коротит". Оказывается. Вдруг. Неожиданно. Кто бы мог подумать.
Еще и советский листочек-схему приложил.. Еще графики линейные порисовал..
Статью на хабр написал "делай как я".
Пишу этот комментарий другим пытливым инженерам - не делай так. Пожалуйста.
SakHax
Не во обиду вам, уважаемый, но наверное все же это старость в вас говорит, вы уже не изучаете этот мир а только наблюдаете и боитесь что в жизни что-нибудь случится, то у машины какой-то тормоза отвалятся, то кто то ни дай бог засунет ардуину в свою машину...
Но все таки, человек познает этот мир, открыл для себя микроконтроллер, причем человек не глупый, с опытом в смежной сфере, а вы как старый дед, нельзя мол так, а что случится то в данном конкретном случае, при отказе ардуины? Компрессор останется включеным? Пусть, будет изнашиваться только шнеки компрессора, ибо главная заслонка, механически закрыта, автомобиль не ускорится, ни замедлится.
Второе, вазовская электрика совсем не плоха, проста в своем минимализме, ну где вы найдете схему на иномарку которая поместится на одном развороте, а в вазе, пожалусто.
Да и непонятно, чем вам всем так не угодила ардуина, удобная плата для прототипирования, а все её хаят, не высказав не одного толкого аргумента.
1CHer
Для авто очень важна вибро устойчивость. Ардуинка всем хороша но когда она стационарна. Для условий тряски возьмите СТМ или наш новый Миладровский и компаундом залить не забудьте. Ну это хотя бы.
ptr128
Да без разницы. Arduino nano точно так же заливается компаундом и ничуть не хуже выдерживает тряску, чем китайские платы STM32. Зато можно подавать на 78L05 прямо бортовые 12V, не заморачиваясь с DC/DC преобразователем.
neenik Автор
Да, компаунд (лак) конечно применю. Виброизоляция + защита пайки от влажности. Опыт от электротранспорта есть.
neenik Автор
Не пойму промежуточных тезисов вашего посыла автору:
Вы против того, чтобы лезли в системы, отвечающие за безопасность авто, те, у кого нет требуемого опыта?
Вы против бесовского ардуино?
Вы против советов на хабре от людей, не обладающих нужным опытом?
twid
"те, у кого нет требуемого опыта?" Мы на сайте программистов...Людей, которые привыкли к требованиям "15 лет опыта работы на фреймворке, написанном года полтора назад". Так что, я думаю, мы оба понимаем, что "есть\нет опыта" здесь не аргумент.
Нет, я не против ардуино. Я за то, чтобы исследователь потренировался на системе, где он контролирует не только взятый им инструмент, но и систему, куда он внедряется. Чтобы исследователь мог удостовериться, что желаемый результат совпадает с действительным. Авто не является полем для экспериментов, как мне кажется.
Я против того, чтобы концепция "вооружись идеей, книжкой, линейными графиками" считалась рабочей. Компилятора в авто нет, сообщить об ошибке некому.
1CHer
Ну что Вы так критично? Илон вон смог? Смог! И автор сможет! (тэг сарказм). Вообще конечно хорошо ежели у него получится. Уверен что даже двигатель выдержит. Однако автор поста не понимает что этот турбо на самом деле даст максимум 10% мощности ибо переделывать там много нужно что бы это хоть как то работало нормально.
victor_1212
если правильно понимаю Вы рассматриваете supercharger, были ранние самолетные двигатели похожего типа, но если думать о практическом применении надо будет учесть склонность таких двигателей к детонации, в автомобилях их тоже применяли где-то в 1920х, но постепенно оставили как менее эффективные, чем с приводом компрессора от турбины, степень сжатия ВАЗ 21126 11, обычно в турбо двигателях степень сжатия существенно меньше, ну и остальное начиная с коробки передач вероятно не рассчитано на передачу большого момента характерного для турбо
neenik Автор
Да, supercharger. Конкретно SC-14, для установки которого всё давно продумано сообществом.
Про то, почему перешли на турбины - есть другое мнение. Для удешевления.
Про коробку и другое - уже предусмотрено.
victor_1212
отлично, напишите как получится, вероятно Вы понимаете, что характеристики горения заряда сильно зависят от давления, поэтому алгоритм управления зажиганием потребует модификации, также как и усиления коленвала, у меня Volvo 850 T5, с модифицированным компьютером (BSR уровень 2) + куча связанных с этим изменений, на котором проехал 200К, поэтому есть кое-какой опыт, желаю удачи
1CHer
Ну не только для удешевления. Так то хим процессы стабильнее и удобнее регулировать. От этого и КПД и прочие параметры лучше.
diakin
Посыл комментатора в том, что когда речь идет о собственной жизни и жизни окружающих, то здоровая паранойя будет нелишней. Главное, чтобы если что-то отвалится, автомобиль не остался без руля и ветрил на скорости, это ведь не сайтик зависнет. Хотя бы навскидку надо проанализировать ситуации с возможными отказами, что будет происходить, если управление заслонкой отрубится, или она полностью откроется\закроется и тп. ситуации.
Lastrer
Бул у меня иж-юпитер в студенческой молодости. И захотел я установить в него систему электронного зажигания с регулируемым углом опережения. Спаял, установил - работает!
Я множество раз ломался в поле - отвибрации страдала пайка. Компоненты вибрировалти и припой в месте соприкосновения с выводами растрескивался и ножка свободно начинала гулять в отверстии платы, давая нестабильный контакт.
1CHer
Поэтому применяют спец припой и компаунд. Платы так же тестируют на вибро.
warshtayner
Риски есть всегда, как говорится и в ложке супа можно утонуть, но если подумать, то вероятность пагубного катастрофического влияния минимальна.
Автор грамотно с инженерным подходом подошёл к делу. И почти уверен подошёл делу с оглядкой на возможные риски. Не стоит порицать людей за любовь к изобретению.
Автор спасибо буду делать как ты!
twid
Автор: Смотрите какая штука!
Хейтер: Это не инженерный подход.
Количество исследователей увеличилось втрое...Почему? Если ругают, то ругают "космонавта что лезет на небо". Это же Инженер, творящий Прогресс.
Вы видите наукообразный подход - ведь человек схему приложил, графики, формулы..А сколько на столе у него проводочков из ардуинки торчат - точно профи. А я по той же картинке распознаю и говорю "это не инженер".
Привет из девяностых. Да, тогда последнее слово техники было другое, но подход по пяти точкам к постановке и решению задачи один в один.
Как хейтер, одобряю апгрейд комментатора Lastrer. Вот он сделал верно. Автор - нет.
1CHer
Поставил бы Вам плюсов но кармы нет )