Создание собственной системы стабилизации
Кстати а вот и ошибка, почему нифига не работало:
DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)txBuffer;
а небыло этой строки вообще 😃
а небыло этой строки вообще
Этож строка только для Ф4. Как она вообще со старой компилилась,? Либо у тебя альтернативная структура для Ф1 гдето в заголовках болтается.
Да нет вот от Ф1 нету ничего, этот проект я полностью пересобирал и цеплял всё сам, компилилась зараза 😦
Не буду утверждать, но когда я делал этот драйвер, то нигде не мог найти подходящей инфы, а тут смотрю аероквады (не путать с автоквад) ковыряют так до боли знакомый кодятник (с тойже бетой) - всё никаких git - надоело 😦
Поковырялся в кодятнике code.google.com/p/aq32plus/ - вот это блин солянка, и вии и baseflight и px4 и даже рево (я учусь makefile делать далеко не удачный пример 😦 )
Случайно увидел в продаже ESC32 контроллеры, которые в теории умеют CAN, по разумной цене: witespyquad.gostorego.com/…/rtf32.html
которые в теории умеют CAN
хех… почему в теории? походу просто ребята сварганили клона создав свою разводку, а прошивка родная от ESC32
а цена действительно шикарная… жалко я сейчас некредитоспособен…
хех… почему в теории?
Ну потому что ESC32 в теории CAN умеет, а по факту, реализации нету в коде (ну или не было раньше, мот уже есть)
главное из этого - чтобы лапы can не были заняты шимом выходным, или ещё чем…
Ну потому что ESC32 в теории CAN умеет, а по факту, реализации нету в коде (ну или не было раньше, мот уже есть)
Если в коде нет, то нафиг они за такую цену. Если только как плата под разработку ПО, но всё равно дорого.
Если в коде нет, то нафиг они за такую цену. Если только как плата под разработку ПО, но всё равно дорого.
Если в коде нет, значит можно дописать 😃
А если ждать когда кто нибудь всё придумает и сделает, то зачем эта тема нужна?
Да и цена вроде адекватная, по сравнению с оригиналом (ESC32)
Если в коде нет, значит можно дописать 😃
А если ждать когда кто нибудь всё придумает и сделает, то зачем эта тема нужна?
Да и цена вроде адекватная, по сравнению с оригиналом (ESC32)
Насколько я помню - они до 4S только, а значит применение очень ограниченное - в основном мелкие коптеры-игрушки и FPV. То есть бестолковые. Там, где нужна обратная связь и раскрываются преимущества CAN, требуется и напряжение побольше, для серьезных машинок.
Если в коде нет, значит можно дописать
Это понятно, но кто будет писать? У меня 6 месяце ушло на понимание принципов получения горизонта от ДУСа и акселя, хотя вроде всё понятно и примеров море. А чтоб нормальный код регуля написать нужно подробно изучить принципы и теорию работы БК мотора как электромашины (векторы напряжения и тока, скольжение поля и пр., я давно это мимо проходил), описать это коде. Тупой порт открытого (и правильного (!)) кода, а надо ещё найти таковой, может дать только обратку по оборотам, ну и возможно, если схема предусматривает, токам фаз.
где нужна обратная связь и раскрываются преимущества CAN, требуется и напряжение побольше, для серьезных машинок.
Можно поподробней, какие параметры гонят регули обратно и как их использовать? Пока представляю только 2 применения: диагностика аварийных ситуаций и автоподстройка ПИДов.
Это понятно, но кто будет писать? У меня 6 месяце ушло на понимание принципов получения горизонта от ДУСа и акселя, хотя вроде всё на понятно и примеров море. А чтоб нормальный код регуля написать нужно подробно изучить принципы и теорию работы БК мотора как электромашины (векторы напряжения и тока, скольжение поля и пр., я давно это мимо проходил), описать это коде. Тупой порт открытого (и правильного (!)) кода, а надо ещё найти таковой, может дать только обратку по оборотам, ну и возможно, если схема предусматривает, токам фаз.
Можно поподробней, какие параметры гонят регули обратно и как их использовать? Пока представляю только 2 применения: диагностика аварийных ситуаций и автоподстройка ПИДов.
Какие именно эти регули гонят - не знаю, но принципиально могут возвращать информацию о срыве синхронизации, вращается мотор или нет, какой ток потребляет каждый мотор, с какой частотой вращается мотор и на основании этих данных можно более точно управлять, ловить аварийные ситуации и садиться с частичной потерей двигателей, отключать мотор, застрявший в траве при приземлении и много чего еще. Но это нетривиальная автоматика. Тут требуется серьезная поддержка в полетном контроллере. Я таких полетных контроллеров с открытым кодом не знаю.
А чтоб нормальный код регуля написать нужно подробно изучить принципы и теорию работы БК мотора как электромашины (векторы напряжения и тока, скольжение поля и пр., я давно это мимо проходил), описать это коде. Тупой порт открытого (и правильного (!)) кода, а надо ещё найти таковой, может дать только обратку по оборотам, ну и возможно, если схема предусматривает, токам фаз.
Так софт под этот регуль Open Source, и он доступен, я имел ввиду только добавить поддержку CAN.
Можно поподробней, какие параметры гонят регули обратно и как их использовать? Пока представляю только 2 применения: диагностика аварийных ситуаций и автоподстройка ПИДов.
Так пока нету таких систем, которые бы использовали подобную информацию, вот и ниодин геруль их и не гонит (да и через PWM это невозможно).
На сколько я помню, vis.asta например получал от каждого регуля потребляемый ток, температуру (двигателя? регуля?), обороты. Ну и наверное нештатные ситуации, типа заклинивания.
Даже если контроллер и не будет в состоянии учитывать эту информацию, то ее можно хотя бы в телеметрию пускать (ну и в лог писать). Возможно это поможет в случае краша, разобраться что не так было.
Так пока нету таких систем, которые бы использовали подобную информацию, вот и ниодин геруль их и не гонит (да и через PWM это невозможно).
На сколько я помню, vis.asta например получал от каждого регуля потребляемый ток, температуру (двигателя? регуля?), обороты. Ну и наверное нештатные ситуации, типа заклинивания.
Даже если контроллер и не будет в состоянии учитывать эту информацию, то ее можно хотя бы в телеметрию пускать (ну и в лог писать). Возможно это поможет в случае краша, разобраться что не так было.
Да, Виктор получает довольно много инфы с регулей, они у него как раз на CAN шине. Для телеметрии инфы слишком много - частота работы регуля обычно от 8 кГц. А если писать только события, то ее все равно надо обрабатывать на борту. В любом случае, я не вижу смысла ставить такие регули пока нет готовности с ними работать по полной, иначе слишком дорого, а толку чуть.
Кто нибудь подскажите: как ошибку USART посчитать (%-baudrate) у F303 ??
Начальные условия: кварц-16 Мгц, требуемая частота fCLK - 56 мгц… В даташите таблица есть только под 8-мгц кварц…
Чет похоже у меня проблема с обменом между “камнями” из за этого… (часто зависает).
хмм… насколько помню она считается практически идентично для всех процессоров и является по сути отклонением расчетного значения счетчиков от задаваемого
В даташите таблица есть только под 8-мгц кварц…
А причём тут кварц? всё равно она делится до 1МГц-а какой бы кварц не стоял, и все расчёты делителей скачут уже от этого…
А причём тут кварц?
Example 1
To obtain 9600 baud with fCK = 8 MHz.
● In case of oversampling by 16:
USARTDIV = 8 000 000/9600
BRR[31:0] = USARTDIV = 833d = 0x0341
● In case of oversampling by 8:
USARTDIV = 2 * 8 000 000/9600
USARTDIV = 1666,66 (1667d = 0x683)
BRR[3:0] = 0x3 << 1 = 0x1
BRR = 0x681
Tx/Rx baud
fCK
USARTDIV
-------------------------------= -
Tx/Rx baud
2×fCK
USARTDIV
= --------------------------------
Tx/Rx baud
fCK
USARTDIV
= --------------------------------
Тут еще “оверсамплинг” какой то, короче я запутался…
Error calculation for programmed baud rates at fCK = 72 MHz
for oversampling by 16 and by 8
Baudrate Oversampling by 16 (OVER8 = 0) Oversampling by 8 (OVER8 = 1)
S.No Desired Actual
USART_
BRR value
% Error =
(calculated -
Desired
baudrate)/Desired
Ага в 303 не как в 407 там System Clock берётся от частоты кварца но можно задать частоту i2s Clock - дабы считать ошибки www.st.com/web/en/catalog/tools/PF258143#
но можно задать частоту i2s
это как же(?), мне то usart нужен… ?
видать придется в дебри STD LIB лезть… (а неохота 😃)