Создание собственной системы стабилизации

SergDoc

Кстати а вот и ошибка, почему нифига не работало:

DMA_InitStructure.DMA_Memory0BaseAddr    = (uint32_t)txBuffer;

а небыло этой строки вообще 😃

rual
SergDoc:

а небыло этой строки вообще

Этож строка только для Ф4. Как она вообще со старой компилилась,? Либо у тебя альтернативная структура для Ф1 гдето в заголовках болтается.

SergDoc

Да нет вот от Ф1 нету ничего, этот проект я полностью пересобирал и цеплял всё сам, компилилась зараза 😦
Не буду утверждать, но когда я делал этот драйвер, то нигде не мог найти подходящей инфы, а тут смотрю аероквады (не путать с автоквад) ковыряют так до боли знакомый кодятник (с тойже бетой) - всё никаких git - надоело 😦

SergDoc

Поковырялся в кодятнике code.google.com/p/aq32plus/ - вот это блин солянка, и вии и baseflight и px4 и даже рево (я учусь makefile делать далеко не удачный пример 😦 )

mataor
Sir_Alex:

которые в теории умеют CAN

хех… почему в теории? походу просто ребята сварганили клона создав свою разводку, а прошивка родная от ESC32

а цена действительно шикарная… жалко я сейчас некредитоспособен…

Sir_Alex
mataor:

хех… почему в теории?

Ну потому что ESC32 в теории CAN умеет, а по факту, реализации нету в коде (ну или не было раньше, мот уже есть)

SergDoc

главное из этого - чтобы лапы can не были заняты шимом выходным, или ещё чем…

rual
Sir_Alex:

Ну потому что ESC32 в теории CAN умеет, а по факту, реализации нету в коде (ну или не было раньше, мот уже есть)

Если в коде нет, то нафиг они за такую цену. Если только как плата под разработку ПО, но всё равно дорого.

Sir_Alex
rual:

Если в коде нет, то нафиг они за такую цену. Если только как плата под разработку ПО, но всё равно дорого.

Если в коде нет, значит можно дописать 😃
А если ждать когда кто нибудь всё придумает и сделает, то зачем эта тема нужна?
Да и цена вроде адекватная, по сравнению с оригиналом (ESC32)

RaJa
Sir_Alex:

Если в коде нет, значит можно дописать 😃
А если ждать когда кто нибудь всё придумает и сделает, то зачем эта тема нужна?
Да и цена вроде адекватная, по сравнению с оригиналом (ESC32)

Насколько я помню - они до 4S только, а значит применение очень ограниченное - в основном мелкие коптеры-игрушки и FPV. То есть бестолковые. Там, где нужна обратная связь и раскрываются преимущества CAN, требуется и напряжение побольше, для серьезных машинок.

rual
Sir_Alex:

Если в коде нет, значит можно дописать

Это понятно, но кто будет писать? У меня 6 месяце ушло на понимание принципов получения горизонта от ДУСа и акселя, хотя вроде всё понятно и примеров море. А чтоб нормальный код регуля написать нужно подробно изучить принципы и теорию работы БК мотора как электромашины (векторы напряжения и тока, скольжение поля и пр., я давно это мимо проходил), описать это коде. Тупой порт открытого (и правильного (!)) кода, а надо ещё найти таковой, может дать только обратку по оборотам, ну и возможно, если схема предусматривает, токам фаз.

RaJa:

где нужна обратная связь и раскрываются преимущества CAN, требуется и напряжение побольше, для серьезных машинок.

Можно поподробней, какие параметры гонят регули обратно и как их использовать? Пока представляю только 2 применения: диагностика аварийных ситуаций и автоподстройка ПИДов.

RaJa
rual:

Это понятно, но кто будет писать? У меня 6 месяце ушло на понимание принципов получения горизонта от ДУСа и акселя, хотя вроде всё на понятно и примеров море. А чтоб нормальный код регуля написать нужно подробно изучить принципы и теорию работы БК мотора как электромашины (векторы напряжения и тока, скольжение поля и пр., я давно это мимо проходил), описать это коде. Тупой порт открытого (и правильного (!)) кода, а надо ещё найти таковой, может дать только обратку по оборотам, ну и возможно, если схема предусматривает, токам фаз.

Можно поподробней, какие параметры гонят регули обратно и как их использовать? Пока представляю только 2 применения: диагностика аварийных ситуаций и автоподстройка ПИДов.

Какие именно эти регули гонят - не знаю, но принципиально могут возвращать информацию о срыве синхронизации, вращается мотор или нет, какой ток потребляет каждый мотор, с какой частотой вращается мотор и на основании этих данных можно более точно управлять, ловить аварийные ситуации и садиться с частичной потерей двигателей, отключать мотор, застрявший в траве при приземлении и много чего еще. Но это нетривиальная автоматика. Тут требуется серьезная поддержка в полетном контроллере. Я таких полетных контроллеров с открытым кодом не знаю.

Sir_Alex
rual:

А чтоб нормальный код регуля написать нужно подробно изучить принципы и теорию работы БК мотора как электромашины (векторы напряжения и тока, скольжение поля и пр., я давно это мимо проходил), описать это коде. Тупой порт открытого (и правильного (!)) кода, а надо ещё найти таковой, может дать только обратку по оборотам, ну и возможно, если схема предусматривает, токам фаз.

Так софт под этот регуль Open Source, и он доступен, я имел ввиду только добавить поддержку CAN.

rual:

Можно поподробней, какие параметры гонят регули обратно и как их использовать? Пока представляю только 2 применения: диагностика аварийных ситуаций и автоподстройка ПИДов.

Так пока нету таких систем, которые бы использовали подобную информацию, вот и ниодин геруль их и не гонит (да и через PWM это невозможно).
На сколько я помню, vis.asta например получал от каждого регуля потребляемый ток, температуру (двигателя? регуля?), обороты. Ну и наверное нештатные ситуации, типа заклинивания.
Даже если контроллер и не будет в состоянии учитывать эту информацию, то ее можно хотя бы в телеметрию пускать (ну и в лог писать). Возможно это поможет в случае краша, разобраться что не так было.

RaJa
Sir_Alex:

Так пока нету таких систем, которые бы использовали подобную информацию, вот и ниодин геруль их и не гонит (да и через PWM это невозможно).
На сколько я помню, vis.asta например получал от каждого регуля потребляемый ток, температуру (двигателя? регуля?), обороты. Ну и наверное нештатные ситуации, типа заклинивания.
Даже если контроллер и не будет в состоянии учитывать эту информацию, то ее можно хотя бы в телеметрию пускать (ну и в лог писать). Возможно это поможет в случае краша, разобраться что не так было.

Да, Виктор получает довольно много инфы с регулей, они у него как раз на CAN шине. Для телеметрии инфы слишком много - частота работы регуля обычно от 8 кГц. А если писать только события, то ее все равно надо обрабатывать на борту. В любом случае, я не вижу смысла ставить такие регули пока нет готовности с ними работать по полной, иначе слишком дорого, а толку чуть.

oleg70

Кто нибудь подскажите: как ошибку USART посчитать (%-baudrate) у F303 ??
Начальные условия: кварц-16 Мгц, требуемая частота fCLK - 56 мгц… В даташите таблица есть только под 8-мгц кварц…
Чет похоже у меня проблема с обменом между “камнями” из за этого… (часто зависает).

mataor

хмм… насколько помню она считается практически идентично для всех процессоров и является по сути отклонением расчетного значения счетчиков от задаваемого

SergDoc
oleg70:

В даташите таблица есть только под 8-мгц кварц…

А причём тут кварц? всё равно она делится до 1МГц-а какой бы кварц не стоял, и все расчёты делителей скачут уже от этого…

oleg70
SergDoc:

А причём тут кварц?

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

oleg70
SergDoc:

но можно задать частоту i2s

это как же(?), мне то usart нужен… ?
видать придется в дебри STD LIB лезть… (а неохота 😃)