naza2frsky - адаптер смартпорта для FrSky за 3$
на новых прошивках тараниса, OpenTX 2.1.X, особо на коды внимания можно не акцентировать т.к. все в самой аппе можно настроить, включая названия. А вообще известные коды перечислены в frskysport.h
Понял. Высота почему то -9999987.0. Домашняя высота не верно фиксируется?
Строка if ((home_altitude == 0) && (sat_visible > 5)) home_altitude = gps_altitude;
Обыскал весь интернет что бы сделать формулу дистанции, нашел, собрал, а потом нашел, что и в библиотеке TinyGPS она уже есть готовая.
Освежил знания в тригонометрии 😃
дистанцию тоже зря делал, насколько помню таранис сам считает.
По высоте. ну выведи сначала чистый gps_altitude потом чистый home_altitude и посмотри 😃
Пытался. почему то home_altitude 100000, ну и соответственно …
проверил.
Высота по gps гуляет сильно от 350 до 190. По этому наверно и точка фиксируется на большей высоте а затем падает. Пробую на балконе. может быть из за этого или есть другая причина такого гуляния?
проверил.
Высота по gps гуляет сильно от 350 до 190. По этому наверно и точка фиксируется на большей высоте а затем падает. Пробую на балконе. может быть из за этого или есть другая причина такого гуляния?
GPS в принципе хреновато высоту показывает, нужно минимум 6 спутников для точности в десяток метров. Если спутников меньше погрешность 300м - легко, так что балкон не показатель. Тем более для старенького, младшего ublox 6й серии
Облетал. координаты отработал хорошо, даже удаление в принципе неплохо. Проблема осталась с высотой. При чем в логе высота по gps - отрабатывает нормально. Вся проблема в первичной записи высоты в ячейку. Может сильно рано пишется. Хочу попробовать добавить внешнее прерывание, типа фиксация стартовой точки, когда высота GPS стабилизируется. Погрешность конечно будет, но не минус всю дорогу. 😃
Скорость показывает неверно. 5-6 к/ч. видимо нужно коэффициент подобрать.
Вариометр тоже =0. Я так понимаю по формуле это разница между уже считаной высотой и новым считыванием. Может разнести их дальше в процедуре?
по моему главное это координаты 😃
По поводу высоты, да можно добавить счетчик чтобы брало не первое измерение после фиксации 6 спутников, а например 10е. Или брать среднее арифметическое первых 10 измерений. Но повторяю значительно минимизировать проблемы с высотой можно только перейдя на более современный уровень, например на gps модуль с ublox 8, на ublox 6 погрешность будет присутствовать постоянно, не смотря на всех костыли
Скорость возможно выводится в м/с
Вариометр все та же песня про высоту 😃 Нужно в логе смотреть как меняется соседние значения высоты и сравнить с тем что выдает вариометр. Возможно умножить на 100, чтобы разница была не в метрах а в сантиметрах
Можешь выложить вариант с правильными координатами? Я в основной проект внесу изменения и выложу сюда, авось кому пригодится
Да, конечно. Соберу сегодня код. А то у меня в тестовом варианте (усеченные модули.) Добавлю в последнюю версию.
чет я даже строчки ни типа
if ((home_altitude == 0) && (sat_visible > 5)) home_altitude = gps_altitude;
ни загадочной
int c = GPS_Serial.read();
не обнаружил 😃
Ну да ладно, я только на 10 умножил координаты, должно работать. Получилась версия 0.5, тем кто протокол NMEA не использует качать НЕ НУЖНО разницы с 0.41 нет!
Я эти фишки пока не включал. Еще тестирую. Пару дней погоняю. Да и дистанцию, я понял не нужно включать. Если все же интересно - то в следующей выложу.
Проблему с высотой кажется понял, только еще не проверил в поле. Не верно работает эта строка if ((home_altitude == 0) && (sat_visible > 5)) home_altitude = gps_altitude;
процедура gps.satellites() возвращает 255 если спутники плохие. И соответственно условие срабатывает и home_altitude фиксируется как 1000000.0 Поставил условие && (sat_visible != 255) Да и кнопку добавил для резерва.
Похоже что 255 это -1 для 8ми битного числа 😃
подумал… лучше вместо && (sat_visible != 255) добавить условие
&& (gps_fixtype == 3)
так будет корректнее
попробую.
Облетал.
Высота отработала корректно (относительно ±2-3 м.) А вот скорость так и не понятна. В функции она выводиться в Км/ч - и составляет 0.14-0.21. Даже не пойму на что нужно умножить 😃
если смотреть на числа то получается
groundspeed = gps.f_speed_kmph()/36*200;
Но если объяснить почему 36 я еще как-то могу, то 200 нет 😃
/36 а не *36?
0.14-0.21 среднее 0.18
0.18 / 36 = 0.005
0.005 * 200 = 1
так .021 это примерно 70-80 к/ч по ощущениям. Замерить нечем. Подбором напрашивается 0.21*36*10 Но это пальцем в небо. Непонятно почему такие цифры возвращает эта функция. Попробую глянуть и в узлах. Она там по умолчанию
делить на 36 однозначно т.к. дальше в FrSkySPort на 36 умножается (эту процедуру лучше не трогать чтобы не пришлось добавлять ключи компилятору для dji и ublox одно, а для nmea по другое). На что умножать посмотри сам, тогда например на 20000, и лучше это делать в naza2frsky.ino
По повожу замерить. Можно прикрепить на аппарат смартфон/трекер, только покрепче, и включить запись трека а потом сравнить показания
Попробую с смартфоном.