MultiWii

kolaa
zvuk_Irkutsk:

Скорее всего проблема в регуляторах. Кстати кто они?
Минусы на тонких проводах от регулятора все заведены на общий минус платы? (Не путать с минусом силовых проводов)

Регуляторы mystery blue series esc 30a, минус общий. Один регуль правда ощутимо грелся (м.б. это 7805, который питает аппаратуру, не знаю) .
Буду регули под лупой рассматривать, может действительно земля где-то отлетела после очередного падения…

photocanon
kolaa:

Один регуль правда ощутимо грелся (м.б. это 7805, который питает аппаратуру, не знаю) .

Советую отдельно использовать питание схемы в обход регуляторов… плюс отсоединяем оставляем минус общий.

jekmv
Flutter:

А подробнее, как подключен PPMSum, правильная ли последовательность каналов, куда подключена серва, как это отражено в скетче? А то информация слишком общая.

ппм идет с 8шо канала приемника фрискай (прошивка с оф сайта под мой приемник для сумм ппм), последовательность каналов по скетчу, каждый канал отчетливо отображается в гуи без всяких глякой без сервы. все четко и ясно, все каналы с пределами 1000-2000. без серв все работает прекрасно. серва включается либо в А0, либо в А1, без разницы на платку вия и начинаются глюки (соответственно раскаменчено управление подвесом в скетче, управление им же идет по 3 и 4 ауксу изначально)
то есть все по книжке подключено и настроено, без серв все идеально

photocanon:

Вся собака зарыта в ппм сумм!

1 выложите полную схему этого сумматора если делали его сами!

суммп ппм идет с приемника, ничего через диоды не объединял, так как потерял бы восьмой канал. да и незачем это, аппаратура поддерживает все нормально.

photocanon:

Вся собака зарыта в ппм сумм!
вы второй канал или просто осцилограф свой повесьте на цепи питания приемника и мультивия… и посмотрите что творится с ними…

вешал, смотрел, менял бэки - ничего там от сервы не просаживается, с одним бэком стабильные 4,9 вольт, с другим - 5,5. в общем, по питанию то порядок

вообще как бы да, коллекторный двигатель создает помехи, никто не спорит, поэтому стандартные 100n повесил - ноль эффекта.

mahowik

Что будет нового и какие изменения были проделаны на пути к 2.1:

Some things everyone should be aware before upgrading to this version.

WMP and NUNCHUCK are no longer auto recognized.
You must explicitly declare them (or just WMP) in config.h

Pullups are now undefined by default
(think about activating it if you use a WMP only conf)
LCD is not activated by default

Failsafe is not activated by default

There is no more .pde files
You must use Arduino 1.0 or greater to compile the sketch (and open Multiwii.ino)

If the GUI does not work on your setup,
try to deactivate hardware acceleration for your display board
or use an alternative GUI like WinGUI

MultiWii is not a product, nor a plug and play solution.
Don’t expect to buy a compatible board and run it without a minimum knowledge.

Receiver part
OpenLRS Multi board support done
This is a board including an OpenLRS receiver where the atmel
is used also to run multiwii code.
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1438

Multiwii Serial Protocol
It’s a new protocol to communicate with the FC
It was introduced by me and tuned by Tommie
It’s a huge change, but it should ensure a generic way to communicate with the FC,
which is less dependant to version evolutions.
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1516

Now, there is no mod to the multiwii if we want to add a GUI/OSD/conf tool/…

Compatible GUI:
open source code, compatible with the new serial protocol
WinGUI from EOSBandi, which is fully equivalent with the original one,
with a better look
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1229
mwGui from kos
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1791
Android ones via serial bluetooth:

Compatible OSD:
open source code, compatible with the new serial protocol
Rushduino:
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=922
mobiDrone:
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1498

LCD config
OLED display
thanks to contributions of howardhb and Hamburger
more info here: www.multiwii.com/forum/viewtopic.php?f=7&t=1350

VT100 terminal type addition
thanks to contribution of Hamburger
more info here: www.multiwii.com/forum/viewtopic.php?f=7&t=1096

A multiline option is added to allow the configuration on more than 2 lines
useful for displays like OLED or VT100

We have now a lot of possibilities regarding LCD:
SERIAL3W : original 2x16 line from Sparkfun
TEXTSTAR : Cat’s Whisker LCD_TEXTSTAR Module CW-LCD-02
VT100 : vt100 compatible terminal
ETPP : Eagle Tree Power Panel LCD
LCD03 : an i2c LCD
OLED_I2C_128x64

New proc: ATmega32U4
Thanks to the work from ronco.
This proc can be found in the Arduino pro micro board, or Teensy 2.0
The Pro Micro is similar to the Pro Mini except with an ATmega32U4 on board.
The USB transceiver inside the 32U4 allows us to add USB connectivity on-board.
ronco also designed a custom board named nanowii.
One of the smallest 6DOF Multiwii board with usb, which can be now purchased.
more info here: www.multiwii.com/forum/viewtopic.php?f=6&t=1337

Servo:
Higher refresh rate:
Some servo (mostly digital ones) can work with a higher frequency than 50Hz.
The consequence is a sharper response.
ronco adapted the code to make this frequency configurable
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1644
Hardware PWM output:
On MEGA boards, it’s now possible to drive the gimbal servos with
a 11-bit PWM servo resolution. Thanks to ronco.
The hardware PWM output ensures a jitter free response.

LED flasher
A way to set a flash LED sequence from Tommie
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1505

Throttle expo
There is now another curve in the GUI to configure the Throttle expo.
It’s a way to smooth the throttle stick response around the hover point.
In order to help the setting, there is a small cursor in the graph to show
where is the current throttle input.

ACC LEVEL improvement
The LEVE mode is improved since 2.0 thanks to new choice of
new complementary filter coefficients and a floating point low pass filter

Headfree checkbox:
It’s possible to reset the headfree direction while flying via a checkbox.
thanks to Tommie

Sensor:
MPU6050: there was a bug which prevents using the gyro LPF. correted now.
SONAR: I2C sonar SRF0x code was added but is not currently used.
many new boards was also added in config.h file

Internal code:
The Serial part uses now less RAM (thanks to Tommie first mod)
RX/TX buffers are smaller than before.
EEPROM parameters are stored in a struct, and are written in the
EEPROM in a single step.
MAG declination was added by EOSBandi, to have more accurate orientation.
In some countries, it’s really mandatory to set this variable right,
otherwise it’s impossible to use GPS.
Flag var was introduced for global boolean type variables.
Hamburger introduced some “copter exemple” in order to check
if compilation is ok. (should be a way to remove some trivial bugs)

GUI:
thanks to Danal, there is now the PIN number and the propeller direction
drawed in the graph representation
thanks to kos, we can now load and save parameters into a file
there is now a reset button to set all parameters to default

GPS code:
Thanks to the work of EOSBandi, we have now a working GPS code !
The navigational routines are based on the works of Jason Short
and the Arducopter team (another great open source project).
EOSBandi adapted it to multiwii.
basically, there are 2 main options for GPS: SERIAL option and I2C option.

  • If you have a spare serial port AND an AtMega1280 or 2560 microcontroller
    based FC, you can connect your GPS to that port and enable the serial GPS
    code in the code.
    Patrick introduced a way to switch automaticly because GUI message parsing
    or NMEA message parsing on the same Serial port
    (useful for promini because you can use the same port for GUI and GPS
    in an exclusive mode)

  • You can use an I2C_GPS board, which contains a secondary AtMega328 processor
    with a serial GPS and runs the GPS parsing and navigational computations.
    This board communicates with the FC via the I2C bus.

more info here: code.google.com/p/i2c-gps-nav/downloads/list
and here in this huge post: www.multiwii.com/forum/viewtopic.php?f=8&t=649

There is also a specific GPS_FROM_OSD option:
it’s a way to use the GPS device of OSD to feed Multiwii with GPS data
MIS OSD uses this functionality

ESC calibration
experimental
It’s a special #define which allows to calibrate all ESCs with exaclty
the same signal.
more info here: www.multiwii.com/forum/viewtopic.php?f=13&t=1517

AIRPLANE mode
experimental, more info here:
www.multiwii.com/forum/viewtopic.php?f=8&t=364
code.google.com/p/multiwii/wiki/MWiiAirplane

HELICOPTER mode
experimental
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1562

Dual & Single copter
experimental
more info here: www.multiwii.com/forum/viewtopic.php?f=8&t=1882

An attempt to improve the documentation via wiki
wiki from googlecode:
code.google.com/p/multiwii/w/list
wiki from multiwii.com
www.multiwii.com/wiki/index.php?title=Main_Page
We all know the overall documentation is still to improve.

cylllka

Не знаю как будет летать 2.1, но по прошлым прошивкам хочу немного отписать собственных наблюдений:

Когда зимой пришел с goodluckbuy мой первый Мультивий Криус Лайт, сразу залил в него прошивку 1.9. ПИДы не крутил, плата приклеена на несколько слоев 2х стороннего скотча.
Установил на коптер вместо КУКа, одел валенок на гипс и поехал на полетухи. Взлет - ровно, стабильно, плавно. Когда налетался в акро, решили попробовать диковинку - акселерометр.
Лечу вперед в акро, щелкаю тумблер - коптер резко выравнивается и останавливается слегка друйфуя по ветру. Пробуем все сильнее наклонять коптер, щелкаем тумблер - снова зависаем в горизонте. Дальше натянув шлотнее шапку делаю мертвую петлю, в положении вверхтормашками снова щелкаю тумблер - резкий взззжжыы и коптер меньше чем за секунду зависает в горизонтальном положении. Повторяю это несколько раз, все в шоке и восторге от работы мультивия…
И тут появляется 2.0, заливаем, настраиваем. В Акро - висит, ниче так вроде висит. Включаем аксель - и коптер куда то убегает. Ну думаю сбилсь калибровка акселя. А так как пузырьковый уровень не взял, выключил его и забыл. Через время на полетушках решил повторить флип с включением акселя - коптер вяло выполняет непонятный пируэт и кидается на дерево, к счастью не застрял там, минус 2 пропа. Сергей mx400 на своей “коровке” тоже пытается повторить этот трюк - коптер кидает в планету. Дальнейшие настройки ПИДов не дали никаких положительных результатов. Если задирали Р или уменьшали D, то начинались осциляции. Но шустрой стабилизации небыло. Сложилось мнение, что прошивку заточили лишь для висения над подушкой и полета блинчиком. Сильные порывы ветра и коптер кидает куда попало.
Дальше тестим прошивку 2.0 а0 от mahowik. Стабильность значительн о лучше чем у стоковой 2.0, аксель работает адекватнее, но все равно коптер очень вяло реагирует на аксель. При порывах ветра колбасит и при этом коптер очень набирает высоту.

Поставил сегодня снова 1.9, пока проверил в ГУИ и без пропов. Отзыв на отклонение от горизонта значительо выше. Моторы противоположные газующим довольно сильно сбрасывают обороты, видимо из за коптер не набирает высоту при покачивании. На днях попробую снова облетать.

DVE

А что такого принципиального было изменено в 2.0 по сравнению с 1.9?

Я начал сразу с 2, 1.9 даже не тестировал, но вроде ничего криминального не было, вполне плавно летало. Хотя новая 2.0 dev-версия летала действительно получше.

cylllka

Криминального ничего, но с 1.9 коптер можно было швырнуть в любом положении в небо, газонуть и он выравнивался. С 2.0 даже страшно это делать, коптер летит куда ему вздумается.

mahowik
cylllka:

Не знаю как будет летать 2.1, но по прошлым прошивкам хочу немного отписать собственных наблюдений:

DVE:

А что такого принципиального было изменено в 2.0 по сравнению с 1.9?

DVE:

Хотя новая 2.0 dev-версия летала действительно получше.

Практика оч. часто НЕ подтверждает теорию 😃

Посмотрел 1.9 и 2.0 стоковые, если ты говоришь именно про стоковую 1.9 и если коротко, то магия там в том что Z акселя исключается из расчета на углах меньше 25 град (при отключенном TRUSTED_ACCZ)… но это скорее подпорка, чем полноценный фикс (была проблема с проседанием оси Z от вибраций), т.к. получается не линейный расчет угла из акселя. Выражаться будет так - при наклонах от 0-ля до 25-ти (если меедленно наклонять), будет недокручивать и показывать от 0-ля до ~10-15 град, а потом резкий переход на 25 (по идее) с уже последующим линейным отображением угла…
В 2.0 нашли решение от проседания оси Z (соот-но включили TRUSTED_ACCZ по умолчанию) увеличив диапазон акселя на 8-16g, но при этом получили больше шумов с акселя, что я задавил флоат фильтром и увеличил вес гиры (уже в последние dev включили)… На скорость в IMU (скорость вычисления угла) это не повлияло т.к. вес гиры был увеличен, соот-но и IMU стал мене зависим от акселя, а это большой плюс, т.к. гира меньше шумит и меньше видит вибрации… точнее IMU даже быстрей и точней стал за счет всеса гиры…

Попробуй закоментить в 2.0, возможно получишь любимый 1.9 😉
//#define TRUSTED_ACCZ

Если не поможет, то не исключено что это касется изменения разрядности pwm на моторы… тут я не шарю уже…

cylllka
mahowik:

Попробуй закоментить в 2.0, возможно получишь любимый 1.9 😉

Спасибо, попробуем.

mahowik
cylllka:

попробуем

а да, также для чистоты эксперимента в 2.0 Sensors.pde поменяй:

i2c_writeReg(ADXL345_ADDRESS,0x2C,0x09); //  register: BW_RATE     -- value: rate=50hz, bw=20hz

на строчку из 1.9

i2c_writeReg(ADXL345_ADDRESS,0x2C,8+2+1); // register: BW_RATE     -- value: 200Hz sampling (see table 5 of the spec)
SovGVD

имхо основное отличие в 2.0 было с изменением кода для работы регулей, после чего у меня через раз пепелацы стали летать, но так и не удалось нормально сделать - всегда то дрейфует куда то, то колбасит непойми как (трешка и гекса), при этом квадрик на 1.9 висел как прибитый на стоковых пидах
потом прошил для гексы регули и на 2.0 стало летать очень не плохо, потом залил мегапират 2.0.49 - вот это был идеал стабильности, по ощущением, как будто ла не в воздухе, а стоит на полочке (в новых версиях мегапирата такого не наблюдалось к сожалению)

alexmos
cylllka:

Криминального ничего, но с 1.9 коптер можно было швырнуть в любом положении в небо, газонуть и он выравнивался. С 2.0 даже страшно это делать, коптер летит куда ему вздумается

Вообще странно, я когда мержил в свой код (основанный на 1.9) все изменения от 2.0 - буквально каждую строку просматривал. В плане вычислений IMU и пид-контроллера там ничего не поменялось. Да и по поведению, когда залил 2.0 поверх 1.9, разницы не заметил.

mahowik:

В 2.0 нашли решение от проседания оси Z (соот-но включили TRUSTED_ACCZ по умолчанию) увеличив диапазон акселя на 8-16g, но при этом получили больше шумов с акселя, что я задавил флоат фильтром и увеличил вес гиры (уже в последние dev включили)…

Может как раз в это проблема - trusted acc z я всегда включаю т.к. без полноценного ACC летатать нельзя. И все фильтры на ACC не использую, т.к. комплементарный филтр с повышенным до 500 уровнем гиры - и так самый лучший LPF.

mahowik:

Если не поможет, то не исключено что это касется изменения разрядности pwm на моторы… тут я не шарю уже…

Да, я тоже так тут начинается магия таймеров и их настройки. Одно ясно - если хочется мегастабилного полета, нужен хардварный PWM высокого разрешения, чего 328 чип обеспечить не может никак - там всего 2 16-ти битных таймера… Видимо, предыдущий вариант софтового PWM был более удачным чем в 2.0

Uvis

Сонар в 2.1 так и не используется? Только для “чтоб был”?

omegapraim
SovGVD:

имхо основное отличие в 2.0 было с изменением кода для работы регулей, после чего у меня через раз пепелацы стали летать, но так и не удалось нормально сделать - всегда то дрейфует куда то, то колбасит непойми как (трешка и гекса), при этом квадрик на 1.9 висел как прибитый на стоковых пидах
потом прошил для гексы регули и на 2.0 стало летать очень не плохо, потом залил мегапират 2.0.49 - вот это был идеал стабильности, по ощущением, как будто ла не в воздухе, а стоит на полочке (в новых версиях мегапирата такого не наблюдалось к сожалению)

Сегодня полетал на прошивке 2.0 с моторками и регулями от avionix. Про моторки и регули уже писал в закупке. Ну что можно сказать: летает, на 2.0 конечно стабильности поменьше, но вполне себе висит. А вот с RC-Timer у меня проблемы были уж не знаю из-за прошивки это или из-за регулей, постоянный срыв синхронизации пипилац падал не то что через раз, а каждый раз, а на других регулях и моторках уже 2й полет и все нормально.

cylllka
omegapraim:

А вот с RC-Timer … постоянный срыв синхронизации

Моторы не TD750 случайно?

omegapraim

Да именно дт 750. Кстати нашел тут интересную статью, на первый взгляд может показаться что не относящуюся к мультивию, но кто знает, тот поймет о чем я.
star3x.com/…/prevrashhaem-usbasp-v-stk500/ Вечерком осуществлю данный апгрейд программатора и расскажу как все прошло.

cylllka
omegapraim:

Да именно дт 750.

Я в ТУТ отписал. Что столкнулся с подобной проблемой на 120грамовом коптере. КОгда начали копать, оказалось что перешитые регули плохо дружили с моторами у которых большое кол-во полюсов.
з.ы. Пардон на оффтоп

omegapraim

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

omegapraim

Саш раму с таймера заказывал, как она? Сегодня Решил полетать и коптер перевернуло ветром(((((

cylllka
omegapraim:

Саш раму с таймера заказывал, как она?

Ну если закрыть глаза на большой вес -300грамм, то вполне не плохо для такой цены. Лучи при хороших падениях ломаются на мотормаунте, в одном месте. Но я наловчился их сваривать пламенем газовой горелки. Прочности сварного шва достаточно для таких вот флипов. На борту 2.0 а0 от mahowik (акро)