PX4飞控导出GPS数据拟合飞行轨迹

前言:想要拟合飞行轨迹,百度了一下,高人介绍的都是什么百度地图API,无忧地图,PYTHON;不是不好,是尝试了一下,注册非常麻烦,结果没拟合出想要的轨迹;接着我们分享一下5行代码的MATLAB;

一.先看结果,再看过程

有些帖子看半天,结果发现不是自己想找的答案,给大家节约宝贵时间,点个赞!!!嘻嘻

二维——经纬拟合

三维——经纬高拟合

 二.实现过程

1.下载飞行ulog文件;

2.将ulog文件转成csv:

       将ulog文件单独放在一个文件夹中,在当前路径下执行指令:ulog2csv log_××××.ulg

3.找到需要的log_×××_gps_position_0.csv文件用于matlat分析

4.二维——经纬拟合Matlab代码如下

clear all
% close all
clc

[FileName PathName]=uigetfile({'log_48_2019-11-14-11-19-26_vehicle_gps_position_0.csv'},'');
file=fullfile(PathName,FileName);
fidID = fopen(file);
M=csvread(file,1,0);

 x=M(:,3);%lon
 y=M(:,1);%alt
 z=M(:,4);%lat
 
%%%-----二维拟合--------%%%
 plot(x,z);

5.三维——经和高度先拟合,纬度和高度拟合,再双双拟合,Matlab代码如下

clear all
% close all
clc

[FileName PathName]=uigetfile({'log_48_2019-11-14-11-19-26_vehicle_gps_position_0.csv'},'');
file=fullfile(PathName,FileName);
fidID = fopen(file);
M=csvread(file,1,0);

 x=M(:,3);%lon
 y=M(:,1);%alt
 z=M(:,4);%lat
 
%%%-----二维拟合--------%%%
 %plot(x,z);

  
%%%-----三维拟合--------%%%
 p_yx = polyfit(y,x,4);
 x_out = polyval(p_yx, y);
 p_yz = polyfit(y,z,4);
 z_out = polyval(p_yz, y);
 plot3(x_out ,y, z_out, 'r*'); hold on;
  
 % µÃ³öÇúÏߺ¯Êý x_out = f(z_out)   z_out = f(y)
 p_zx_out = polyfit(z_out,x_out,4);   
 x_out_f = polyval(p_zx_out,z_out);
 plot3(x_out_f,y,z_out,'b*'); hold on;

大图:

gps数据:

本人原创不多,拿来分享,共同提高,不对请大神们批评指正,不胜感激!(完)

  • 10
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jones250

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值