Векторное управление BLDC
Даа, слов много. Меня интересовало как с малой индукцией можно крутить мотор с той же силой.
Индукцией переменной составляющей на частоте ШИМ - почувствуйте разницу. Поймите же вы наконец, и перестаньте мешать в кучу процессы, происходящие на совершенно разных частотах. Я выше привёл пример, но, похоже, придётся написать ещё больше текста:
Допустим, я на свой мотор подаю 30 ампер, и он раскручивается до 18000 RPM. Ток пульсаций на частоте ШИМ достигает аж “огроменных” 0.5A! Несомненно, это такая же огромная индукция, как на рабочей частоте мотора (16 полюсов, 18000*8/60=2400Гц) при 30A фазного тока. Сколько потерь будет вносить чистый сигнал без ШИМ в этом случае? И сколько вклада внесёт ШИМ своими 0.5A на 190кГц? Если зависимость от индукции квадратичная, а от частоты линейная (у железа всё несколько проще и даже наоборот, но я начинал за здравие, поэтому продолжу) - считаем: 30A^2*2400Гц=2160000 попугаев потерь на рабочей частоте мотора, 0.5А^2*190000Гц=47500 попугаев потерь из-за ШИМ в этом же режиме, что в 45 раз меньше за ток подмагничивания, на который мы, в отличии от тока пульсаций ШИМ, никак повлиять не можем, т.к. именно этот ток и крутит мотор. А с пульсациями от ШИМ мы можем делать что хотим, они никакого влияния на тягу мотора не оказывают, только на потери и проблемы с оцифровкой сигналов с датчиков. Справедливости ради замечу: У железа, из-за электропроводности в пластинах, картина может быть и обратной - рост частоты приводит к квадратичному росту потерь. Только в моторах всё сложнее - есть ещё индукция рассеяния, она работает без участия железа. Тут практика нужна, но у меня пока проблем с этим не возникает. Регуль, вращающий мотор с частотой 60 оборотов в минуту, качающий в него 200мА (меньше недостаточно для страгивания - залипает на полюсах), при этом шпарящий все 3 DrMOSа на всех своих 193кГц - с аккумулятора потребляет около 15мА. Где же космические потери то?
Надеюсь, теперь я ответил на ваш вопрос корректно, и что-то сам понял, как вы хотели? 😃 Приношу свои извинения за то, что раздражаю своим многословием…
Только принцип работы импульсника объяснять не надо, это и так понятно.
Не похоже, поэтому и расписал. Я обратил внимание на ваши неоднократные высказывания по поводу вреда ШИМ, и с вами абсолютно не согласен. В конце концов, писал я не только вам, тут и другие читатели есть, менее компетентные, но более любопытные.
Их детище Кисс не выдерживает циклический наброс нагрузки, сваливается в защиту. Выяснил при тестах на стенде.
Да, читал. Только нет же исходников, документации и т.п., чтоб глянуть что именно они там наворотили? Тогда мне с этого практической пользы никакой. Если б я мог чужие ошибки изучить… Я почему-то решил, что это открытый любительский проект какой-то, возможно даже здешних форумчан…
Все равно ничего не понял, где я должен почувствовать разницу и т.д.
Ладно замнем. Вам понятно и ладно. Может кто еще что-нибудь понял.
Получится игрушка, хорошо.
Удачи.
Со стандартным драйвером мой коптер имеет эффективность порядка 13-ти грамм на ватт (при массе 900 грамм и порядка 80 ватт запаса энергии на борту), теоретическая самого винта порядка 17-ти. Ожидаю со своим драйвером порядка 14…15 грамм на ватт, и гораздо меньший акустический шум. Свиста тут нет - ШИМ 187.5кГц, глубина 16 бит, главный цикл всё пересчитывает тоже на приличной частоте - 93.75кГц (512 тактов на цикл). Пока хватает ресурсов, но ещё ж не всё написано. Сильно мешает отсутствие аппаратного деления у применённого тут ARM Cortex M0.
Ну а в целом, в схемотехнике придётся доработать только одно место - у DrMOS слабый верхний ключ (типичное значение порядка 5мОм), его можно продублировать внешним на 1мОм. Нижний там достаточно хороший (порядка 1мОм). в остальном же игрушка обещает быть интересной.
теоретически мотором можно управлять
- подавая один импульс определенной переменной длительности (в зависимости от требуемого момента) то есть разово заряжать катушку мотора
- выбрав тактику шим модуляции с помощью которой определяется напряжение и ток в обмотке. то есть дозировать заряд катушки по времени
в пользу второго способа склоняет логическое суждение что двиглу нужна синусоида (или трапеция) с тем чтобы он увереннее и кпдшнее работал
однако если рассмотреть характер потерь силового ключа то значительная часть происходит в момент переключения ключа. тоесть чем больше переключений (под током) тем выше потери. т.е. фактически устойчивость работы мотора выше но кпд регулятора ниже.
Записал формы напряжения в двух фазах (трех каналов у моего осцилла нет), в разных масштабах по времени, чтобы было понятно. И еще формы на выходе усилителя шунтов, синхронно с напряжением этой же фазы.
Скважность в обоих каналах почти одинакова потому, что мотор был не нагружен. А вот при замере формы тока я его тормозил, иначе все плоское и виден только шум. Коэффициент для перехода к значению тока около 33 А/в.
Было бы понятнее, если б заполнение ШИМ на фазах было пропущено через ФНЧ. Тогда было бы видно форму напряжения на фазах. Ещё как вариант - выводить это дело через МК самого контроллера. Он же всем заведует и ему виднее что там где творится. Можно в нём всё обработать, зафильтровать, и вывести через отдельные ШИМ каналы. Напряжения и токи ведь интересуют именно на обмотках? А там треугольник обычно, и всё это пересчитывать с фазных нужно…
Вот, к примеру, я отлаживал ФАПЧ, и у меня два канала с регуля идут на звуковую карту в компе:
Вверху сигнал ошибки ФАПЧ (расколбас где-то ±15 градусов), а внизу - как раз сглаженное внутренними фильтрами противоЭДС одной из обмоток. Что на канал выведу - то и покажет. Могу токи сравнить, сигналы ОС, посмотреть как фильтры фазу крутят и т.п. Ну и на компе в саундфордже я могу полноценно посмотреть спектр и понять, какой фильтр лучше подойдёт для сглаживания того же шума ФАПЧ, к примеру, и т.д.
Из того, что я понял по теоретической части: Сперва я хотел прикрутить векторное управление, но не взлетело. Копнул глубже, и остановился на трапеции и своих алгоритмах, которые мне помог разработать симулятор этого мотора (самописный, для отладки алгоритмов в “сферической в вакууме” виртуальной среде).
Почему не взлетело? И какие алгоритмы в итоге выбрали?
Погрешности датчиков тока на эффекте Холаа не мешают? Я пробовал такие, их как акселерометр использовать можно, сигнал зависит от ускорения. Не говорю уже о проводах с током лежащих рядом.
Как я понимаю источников питания на плате контроллера у Вас нет, в угоду габаритам. Делать 12в для затворов необходимости нет, да и драйверов как отдельных элементов на плате тоже нет. Интересно, но мне многое не нравится.
Было бы понятнее, если б заполнение ШИМ на фазах было пропущено через ФНЧ. Тогда было бы видно форму напряжения на фазах. Ещё как вариант - выводить это дело через МК самого контроллера. Он же всем заведует и ему виднее что там где творится. Можно в нём всё обработать, зафильтровать, и вывести через отдельные ШИМ каналы.
Если надо понятнее, то могу на численной модели записать графики. Там они будут чистые, не отягощенные всякими особенностями. А с МК я делаю запись в RAM с необходимой частотой, а потом уже неспешно передаю через USART. Да можно и через DAC вывести, я даже пины на плате для этого предусмотрел, но как-то необходимости пока не было.
Почему не взлетело? И какие алгоритмы в итоге выбрали?
Уже взлетело. Я много чего перепробовал, с разным успехом. Начал с полного моделирования мотора в МК, но там слишком много рекурсий, и видимо модель вышла неустойчивой. К тому же мне не хватило ресурсов STM32F030. Потом уже, когда переписал под другой механизм - обнаружил некоторые ошибки грубые, из-за которых могло не заработать. Пока переписывал - построил виртуальную систему, которая помогла мне отладить код прямо на компе, и вернулся частично к прежней модели, но уже упрощённой. Моделирование показало, что fxpt_atan2() отлично работает и имеет хорошую устойчивость к шуму, но вот форма тока при фазовом сдвиге, относительно противоЭДС, сильно искажается и вносит серьёзные ошибки в вычисление фазы. У меня источник напряжения, не тока. Для нормальной работы следящих систем, регулирующих именно токи через две обмотки (третья работает пассивно) - не хватает скорости работы ОС. Решение так и не нашел. Поэтому я остановился на генераторе трёхфазного напряжения, амплитуда которого регулируется уже более медленной ОС по току. Это если нужно регулировать именно крутящий момент, а не обороты. Ну а ток уже получается какой получается, и дальше я с ним уже работаю как есть. Решил вопрос фильтрацией сигналов с датчиков синхронными RC-фильтрами второго порядка (программными). Чтоб они не искажали результат своей ФЧХ - точно такие же фильтры сглаживают и противоЭДС обмоток. В результате трапеция и всякие “НЁХ” на датчиках тока сглаживаются во что-то синусоподобное, с чем хорошо справляется арктангенс. При синфазных сигналах они вообще вырождаются в синус, и ошибка минимальна. ФАПЧ просто вычитает из фазы тока фазу противоЭДС, поэтому фильтры друг друга компенсируют. При этом следящая система компенсирует и фазовый сдвиг тока из-за индуктивности, идеально согласуя ток с положением ротора. Сложность вся именно в вычислении противоЭДС из комплексного напряжения между фазами…
Дополнительно думаю сглаживать ошибки ФАПЧ фильтром Бесселя 4-го порядка, уже за фазовым детектором (опять же моделирование показало что лучше). Он режет всё что выше частоты генератора, включительно. Вносит задержку в 3.5 периода генератора, поэтому ФАПЧ получается медленный на низких оборотах. Думаю ограничить минимальную частоту среза фильтра, чтоб на малых оборотах было шумно, но зато не тормозило. Пока ещё вожусь. Допишу быструю синхронизацию ФАПЧ с помощью частотомеров, сдвигающих частоту генератора к частоте противоЭДС так, чтоб она сразу оказалась в полосе захвата ФАПЧ и т.д.
Вот, собственно, и вся модель…
Погрешности датчиков тока на эффекте Холаа не мешают?
Вообще шикарные. Проблем пока не заметил. Но мне и не требуется разрешение в 24 бита, так что…
Как я понимаю источников питания на плате контроллера у Вас нет, в угоду габаритам. Делать 12в для затворов необходимости нет, да и драйверов как отдельных элементов на плате тоже нет.
Два питания. Одно 5V, с центральной платы с мозгом. Там общий преобразователь на питание всей требухи стоит. Плодить преобразователи я не стал. Если найду что-то привлекательное - влеплю. Ну и батарея подключается. Тут в этой схеме есть моменты, которые желательно вылизать. На сигнальные линии нужны символические RC фильтры, если выяснится, что захват у МК не имеет адекватного встроенного фильтра дребезга. Ну или как минимум резисторы для защиты сигнальных линий. Ещё верхние ключи в этих DrMOS, возможно, придётся продублировать внешними. Один датчик тока выкинуть можно, арифметика позволяет, но я выкидывать не стал. Решил что с ним преимуществ больше. Избыточность позволяет работать с лёгким клиппингом сигналов, да и шум равномернее. Мне так же не нравится не развязанная с силовой сигнальная масса - повышенные требования к трассировке центральной платы.
Потревожу немного эту тему. По поводу того, для чего планирую использовать контроллер, и причем здесь коптеры. Вот смотрел и выбирать варианты ВМГ и мне на данный момент видится например такой вариант, мотор ML 5010 300KV, проп 2055, питание 8S-12S.
Контроллер-регулятор будет четвертой ревизии, ожидаемые параметры:
- одноплатный 45мм x 45мм;
- вес 20-30г без конденсаторов и проводов;
- номинальный ток (+30°C) 50А;
- предел по напряжению питания 40-50в.
Уже давно сделал трассировку новой платы, но не решаюсь пока заказывать, думаю и ищу недостатки.
Меньше габариты/вес не получаются. В соответствии с ними подбираю другие параметры. Цена получается большой, все компоненты выбраны по характеристикам без учета цены, pcb еще 6 слоев со слепыми переходными.
Дальше, есть еще софтверная часть, которую в очередной раз переписываю, на этот раз упрощаю и выбрасываю например оценку формы ЭДС (она работает нестабильно и пользы от нее немного). Здесь назревает некоторая проблема. Каким параметром ВМГ надо управлять? Сейчас есть возможность управлять током (т.е. моментом) или скоростью. В обоих случаях это регулирование конкретной величины измеряемой в некоторых единицах, это не throttle от 0 до 100 %.
Итоговая задача управлять тягой, но при этом винт с неизменяемым шагом, изменять можно только скорость. А на тягу влияет как минимум воздушная скорость движения винта, которую можно оценить по потребляемой мотором мощности для поддержания заданных оборотов. Появляется такая идея, что надо управлять мощностью, чтобы приблизиться к регулированию именно тяги. Но как это хорошо сделать чтобы не проиграть в скорости переходных процессов, я пока не знаю.
Вот из-за таких идей и хочется свой контроллер мотора, с которого можно спрашивать все интересные параметры, а не только выдавать в него заданный throttle.
Полетный контроллер еще хочется сделать.
Для начала непонятна задача , что потребовалось делать свой пк и рег с нуля.
По мощности, создается впечатление, что нет понимания как работает коптер. Или коптер не нужен?
6 слоев со слепыми переходными
6 слоев конечно хорошо с точки зрения компактности и качества разводки, но имеет смысл делать например для большого количества мелких регулей, где сама плата будет минимальных размеров и можно будет вместить много таких в один стандартный заказ. А для себя или для попробовать выйдет очень дорого и/или долго. Все же для тестов и разработки лучше обходиться минимумом слоев.
в принципе пока еще есть смысл делат ьсамодельные регуляторы класса “высоковольтные”.
для 10 -15 банок липо.
подобные регуляторы могут быть востребованы в электротранспорте (электровелосипеды, электроскутеры мини-электромобили)
к примеру регулятор на 14 банок и 80 ампер стоит от 4тр за штуку
предыдущее решение на 2х платах ИМХО было более правильное …
на силовой плате можно использовать материал с толстой медной фольгой , а плате управления с тонкой … это сильно упростит и удешевит изготовление платы , даже если процессорная будет 4х слойной …
драйверы ключей и датчики тока можно вынести на процессорную плату , на силовой оставить только ключи и измерительные резисторы …
в принципе пока еще есть смысл делать самодельные регуляторы класса “высоковольтные”.
для 10 -15 банок липо.
не только высоковольтные …
эти регули нужны там где на малых оборотах (от нуля) требуется высокий крутящий момент , а датчиков в моторе нет …
конкретно для коптеров особого смысла в них не вижу , а вот для транспорта будет интересно …
Каким параметром ВМГ надо управлять? Сейчас есть возможность управлять током (т.е. моментом) или скоростью. В обоих случаях это регулирование конкретной величины измеряемой в некоторых единицах, это не throttle от 0 до 100 %.
Итоговая задача управлять тягой, но при этом винт с неизменяемым шагом, изменять можно только скорость. А на тягу влияет как минимум воздушная скорость движения винта, которую можно оценить по потребляемой мотором мощности для поддержания заданных оборотов. Появляется такая идея, что надо управлять мощностью, чтобы приблизиться к регулированию именно тяги. Но как это хорошо сделать чтобы не проиграть в скорости переходных процессов, я пока не знаю.
И даже более точная фраза
я пока не знаю.
Она точнее всего отражает суть проблемы.
Столько потрачено времени, столько проделано работы (уже и объяснять пытались не раз), а нет самого главного - понимания того, что требуется получить (как должно работать).
Вообще-то с этого всегда надо начинать. Т.е. делаются эксперименты на уже готовых или на макетах.
Понимается суть задачи.
Ищутся пути решения.
Создаются макеты.
Проверяется как выполняется задача, выявляются ошибки, просчеты.
Если выясняется, что решение неверное, то все по новой.
Если правильно, то отрабатывается готовый образец.
А у Вас. Все наоборот. Правда в Вашу защиту можно сказать, что такое часто у нас - увидели красивое слово, годится не годится не важно, оно же где-то рядом, значит можно использовать, тем более за бугром все юзают, а значит (только поэтому) это самое правильное решение. Такое характерно для начальников. Им как туземцам главное чтобы “блестело”, а грамотное решение не блестит, а значит на него не получишь денег.
В результате на выходе получается, что вроде работает, но пользователи только плюются на такие создания. Т.к. заставляют работать только на этом, а работать невозможно.
Но Вы же не начальник.
Да, я описал длительный процесс. Хочется быстро. Но, зачастую именно так быстрее получается требуемый результат.
главное чтобы “блестело”
В конце концов любой продукт должен блестеть. Иначе здесь быстро найдутся “умники”, скажущие, что у китайцев блестит лучше.
В конце концов любой продукт должен блестеть.
Ну да, в конце тоже надо, иначе как продашь. Но это отдельный вопрос. Я то сейчас про начальный этап.
Мне всегда было обидно за народ, который имея хорошее образование (познания) в какой-то области и не обладая умениями решать задачу в целом тратят зря время и силы. Когда можно было просто сделать первичный анализ и не проверять все решения подряд.
В данном случае напрашивается не понимание, что делает ПК в коптерах, а что делает рег и что от них требуется.
Да, конечно любой опыт хорошо. И вполне возможно, что полученный результат пригодится, но скорее в области отличной от коптеров.
Мне всегда было обидно за народ, который имея хорошее образование (познания) в какой-то области и не обладая умениями решать задачу в целом тратят зря время и силы. Когда можно было просто сделать первичный анализ и не проверять все решения подряд.
В данном случае напрашивается не понимание, что делает ПК в коптерах, а что делает рег и что от них требуется.
Интересно было бы узнать ваше понимание, что должен делать регулятор а что пк. А по мощности что не так?
в принципе пока еще есть смысл делат ьсамодельные регуляторы класса “высоковольтные”.
для 10 -15 банок липо.
подобные регуляторы могут быть востребованы в электротранспорте (электровелосипеды, электроскутеры мини-электромобили)
к примеру регулятор на 14 банок и 80 ампер стоит от 4тр за штуку
Это отдельно надо делать. То что есть не HV.
предыдущее решение на 2х платах ИМХО было более правильное …
на силовой плате можно использовать материал с толстой медной фольгой , а плате управления с тонкой … это сильно упростит и удешевит изготовление платы , даже если процессорная будет 4х слойной …
драйверы ключей и датчики тока можно вынести на процессорную плату , на силовой оставить только ключи и измерительные резисторы …
Возможно. Сложности тоже есть, громоздко получается. На больший ток я думаю да, нужно силовую часть на отдельную плату, которые можно было бы параллелить.
Интересно было бы узнать ваше понимание, что должен делать регулятор а что пк. А по мощности что не так?
Упрощенно для понимания.
ПК отвечает за удержание 3д позиции и перемещение в 3д координатах (перемещение можно даже считать производным удержания). И здесь ПК главный, а рег с ВМГ исполнители. Думать должен только ПК, а те исполнять.
Ну регу еще достается задача следить, чтоб мотор исполнял команду.
Что там с мощностью ПК сам разберется с помощью своих датчиков.
Все, что по мощности требуется, так это чтобы ее хватило у рега с ВМГ и желательно с запасом (и чем больше, тем лучше, конечно в рамках разумного).
Т.е. от рега требуется, чтобы он держал/менял обороты мотора по команде.
При работе на фиксированный винт мотор работает по винтовой характеристике. Это когда тяга (мощность) меняется при изменении оборотов. Естественно на разных скоростях она меняется, но ПК все равно будет сравнивать тягу через положение, так что знать истинную мощность ни к чему.
Отсюда следует, что чем точнее удержание оборотов регом, тем точнее удержание тяги (мощности) ВМГ. А значит ПК меньше работы на корректировку тяги. А так на сегодня ПК больше трудится, чтобы компенсировать неточный рег с помощью ПИДов. Совсем без контроля оборотов никто не делает, иначе ПК вообще не сможет работать. Но упрощать не всегда есть хорошо. Невозможно одну погрешность компенсировать точностью и скоростью в другом месте.
При работе по нагрузочной характеристике (с ВИШ) еще проще. Надо строго держать одни обороты как бы не менялась нагрузка.
Удержание позиции вала как у сервы это уже другая задача. И мешать все в одну кучу конечно можно, но все же стоит различать задачи.
Упрощенно для понимания.
…
Ну это известный вариант, управлять скоростью в регуляторе, а остальное в ПК. Только простые ESC например задают заполнение ШИМ а не скорость, а ток при этом гуляет как хочет в зависимости от нагрузки, и это не контролируется, что тоже мне не нравится.
Да и всякие другие параметры полезно принимать от регулятора в ПК, все те же обороты и ток (или мощность). Как минимум, чтобы диагностировать неполадки перед стартом.
Вот по поводу диагностики, так же пытаюсь делать в своем контроллере. Добавил делитель напряжения с фаз, можно будет делать тест, что выходные транзисторы целы и мотор подключен.
Так по мощности то что? Я думал дело в том, что для той ВМГ, что я назвал мой регулятор получается слишком тяжелый (~20г), большой и по току запас еще будет.
Удержание позиции вала как у сервы это уже другая задача. И мешать все в одну кучу конечно можно, но все же стоит различать задачи.
Да я не знаю кто мешает, я только сказал, что возможность есть. Да и характеристики получаются слабые у такой бездатчиковой сервы (нет достаточной точности и жесткого удержания позиции с высокой точностью), нужен или датчик положения/скорости или редуктор.
подобные регуляторы могут быть востребованы в электротранспорте (электровелосипеды, электроскутеры мини-электромобили) к примеру регулятор на 14 банок и 80 ампер стоит от 4тр за штуку
На это вот я даже не рассчитываю, что смогу сделать дешевле, даже если представить, что будет производство 1000+ штук. Кстати надо будет посчитать, что стоимость какая у меня получается. Приблизительно, эти образцы обходятся не менее 10тр, без монтажа, паяю сам по 1-2 шт.
а ток при этом гуляет как хочет в зависимости от нагрузки
Ток потребления в существующих гуляет не как хочешь, а строго в соответствии с нагрузкой.
Нагрузка дрейфует и ток также плывет. Конечно под запись точнее можно было бы сказать кто раньше начинает, но пока только глазами.
По началу своих тестов у меня было даже подозрение на китайский сервотестер, что дает плавающий сигнал.
Но когда сделал свой цифровой тестер с шагом 1 мкс и 1000 шагов на весь диапазон газа, то окончательно убедился в вине самого рега.
Да и всякие другие параметры полезно принимать от регулятора в ПК, все те же обороты и ток (или мощность). Как минимум, чтобы диагностировать неполадки перед стартом.
Принимать надо с определенной погрешностью, а не плюс минус километр. Толку от неопределенности.
Диагностировать перед стартом можно и существующие (при небольшой доработке), только надо знать как, чтоб дописать еще и программу.
Приблизительно, эти образцы обходятся не менее 10тр, без монтажа, паяю сам по 1-2 шт.
Посчитал цены поэлементно, получается 8469 + еще цена PCB. Из этого ~4500 это транзисторы и драйверы затворов. Дальше по цене идут усилители, МК и преобразователи питания.
Добрый день.
Готов поучаствовать материально в развитии проекта. Мне нужны контроллеры мощностью 2 кВт на напряжение питания 300 Вольт. В качестве силовой части готовые IPM модули планирую. Если на основе вашей прошивки сделаете, готов оплатить честно труд. Нужно 20 контроллеров.