一种无头控制的方法转让专利

申请号 : CN201610297215.3

文献号 : CN107346140B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 郑卫锋其他发明人请求不公开姓名

申请人 : 北京臻迪机器人有限公司

摘要 :

本发明公开了一种无头控制的方法,无头控制的方法包括:S1,接收到无头控制命令或起飞命令;S2,实时计算遥控器指向无人机的航向角theta;S3,根据航向角theta得出旋转矩阵DCM;S4,将接收到的初始控制量V与旋转矩阵DCM结合得出无人机的无头姿态控制量C;S5,无人机根据无头姿态控制量C调整飞行姿态。这样,当用户触发无头控制键,或者触发起飞按键通过遥控器控制无人机起飞时,用户利用遥控器控制无人机飞行,无论无人机的机头处于哪个方向,无人机都会以用户的方位进行飞行,并且由于系统在实时计算遥控器指向无人机的航向角,用户利用遥控器控制无人机向左或右飞行时,无人机就会以用户为中心以无人机到用户的距离为半径盘旋飞行。

权利要求 :

1.一种无头控制的方法,其特征在于,包括以下步骤:S1,遥控器接收到无头控制命令或起飞命令;

S2,遥控器实时计算遥控器指向无人机的航向角theta;

实时获取遥控器的纬度lat1和经度lon1,以及无人机的纬度lat2和经度lon2;

计算遥控器和无人机的纬度差θ=lat1-lat2,和经度差b=lon1-lon2;

theta=arctan2f(sin(b)*cos(lat2),cos(lat1)*cos(lat2)*sin(lat2)-sin(lat1)*cos(lat2)*cos(b))S3,根据航向角theta得出旋转矩阵DCM;

S4,将遥控器接收到的用户输入的初始控制量V与所述旋转矩阵DCM结合得出无人机的无头姿态控制量C;

S5,遥控器将无头姿态控制量C发送至无人机,以供无人机根据所述无头姿态控制量C调整飞行姿态。

2.根据权利要求1所述的无头控制的方法,其特征在于,在所述步骤S1与S2之间还包括:Sa,根据遥控器与无人机的实时距离S是否在危险距离范围内,来确定无人机的飞行状态。

3.根据权利要求2所述的无头控制的方法,其特征在于,所述步骤Sa具体包括:Sa1,遥控器实时计算遥控器与无人机的实时距离S;

Sa2,当所述实时距离S大于危险距离时,无人机正常飞行,当所述实时距离S小于或等于危险距离时,无人机悬停。

4.根据权利要求3所述的无头控制的方法,其特征在于,所述步骤Sa1具体包括:根据lat1、lon1、lat2、lon2、θ、b和earth_radius计算遥控器与无人机的实时距离S,其中,earth_radius是地球半径。

5.根据权利要求4所述的无头控制的方法,其特征在于,所述实时距离S为:

6.根据权利要求1所述的无头控制的方法,其特征在于,所述旋转矩阵DCM为:其中,pitch=0,roll=0,yaw=theta。

7.根据权利要求1-6任一项所述的无头控制的方法,其特征在于,所述步骤S4具体包括:遥控器接收用户输入的初始控制量V;

计算无人机的无头姿态控制量C为:

C=DCM*V。

8.根据权利要求7所述的无头控制的方法,其特征在于,所述初始控制量V为:其中,Vpitch是遥控器接收的无人机前后移动的控制量,Vroll是遥控器接收的无人机横向移动的控制量,Vthrust是遥控器接收的无人机上下移动的控制量。

9.根据权利要求7所述的无头控制的方法,其特征在于,所述无人机的无头姿态控制量C为:其中,Cpitch是无头控制下的无人机前后移动的姿态控制量,Croll是无头控制下的无人机横向移动的姿态控制量,Cthrust是无头控制下的无人机上下移动的姿态控制量。

说明书 :

一种无头控制的方法

技术领域

[0001] 本发明涉及无人机技术领域,具体涉及是一种无头控制的方法。

背景技术

[0002] 目前,无人驾驶飞机简称“无人机”,是利用无线电遥控设备和自备的程序控制装置操纵的不载人飞机,目前大量应用在航拍、地貌的测量、运输等行业。
[0003] 无人机在使用中具有成本低、使用方便、环境适应性强等特点,所以正逐步走进人们的普通生活,广受大家的喜爱与应用,一般的无人机都有机头,当无人机飞行的距离比较近时,用户可以用眼睛看见无人机的机头,然而一旦无人机飞行的距离比较远或无人机的飞行距离超出人的视线范围时,用户无法用眼睛辨别无人机机头的方向,就不能很好的控制无人机的飞行,无人机就会乱飞,这样会存在很大的安全隐患。
[0004] 因此,需要一种新的技术方案,能够在用户利用遥控器控制无人机飞行时,无论无人机的机头处于哪个方向,无人机都会以用户的方位进行飞行。
[0005] 有鉴于此特提出本发明。

发明内容

[0006] 本发明要解决的技术问题在于克服现有技术的不足,提供一种当用户触发无头控制键时,在用户利用遥控器控制无人机飞行时,无论无人机的机头处于哪个方向,无人机都会以用户的方位进行飞行的无头控制的方法。
[0007] 为解决上述技术问题,本发明采用技术方案的基本构思是:
[0008] 本发明提出了一种无头控制的方法,所述无头控制的方法包括:
[0009] S1,遥控器接收到无头控制命令或起飞命令;
[0010] S2,遥控器实时计算遥控器指向无人机的航向角theta;
[0011] S3,根据航向角theta得出旋转矩阵DCM;
[0012] S4,将遥控器接收到的用户输入的初始控制量V与所述旋转矩阵DCM结合得出无人机的无头姿态控制量C;
[0013] S5,遥控器将无头姿态控制量C发送至无人机,以供无人机根据所述无头姿态控制量C调整飞行姿态。
[0014] 优选地,在所述步骤S1与S2之间还包括:
[0015] Sa,根据遥控器与无人机的实时距离S是否在危险距离范围内,来确定无人机的飞行状态。
[0016] 优选地,所述步骤Sa具体包括:
[0017] Sa1,遥控器实时计算遥控器与无人机的实时距离S;
[0018] Sa2,当所述实时距离S大于危险距离时,无人机正常飞行,当所述实时距离S小于或等于危险距离时,无人机悬停。
[0019] 优选地,所述步骤Sa1具体包括:
[0020] 实时获取遥控器的纬度lat1和经度lon1,以及无人机的纬度lat2和经度lon2;
[0021] 计算遥控器和无人机的纬度差θ=lat1-lat2,和经度差b=lon1-lon2;
[0022] 根据lat1、lon1、lat2、lon2、θ、b和earth_radius计算遥控器与无人机的实时距离S,其中,earth_radius是地球半径。
[0023] 优选地,所述实时距离S为:
[0024]
[0025] 优选地,所述航向角theta为:
[0026] theta=arctan2f(sin(b)*cos(lat2),cos(lat1)*cos(lat2)*sin(lat2)-sin(lat1)*cos(lat2)*cos(b))。
[0027] 优选地,所述旋转矩阵DCM为:
[0028]
[0029] 其中,pitch=0,roll=0,yaw=theta。
[0030] 优选地,所述步骤S4具体包括:
[0031] 遥控器接收用户输入的初始控制量V;
[0032] 计算无人机的无头姿态控制量C为:
[0033] C=DCM*V。
[0034] 优选地,所述初始控制量V为:
[0035]
[0036] 其中,Vpitch是遥控器接收的无人机前后移动的控制量,Vroll是遥控器接收的无人机横向移动的控制量,Vthrust是遥控器接收的无人机上下移动的控制量。
[0037] 优选地,所述无人机的无头姿态控制量C为:
[0038]
[0039] 其中,Cpitch是无头控制下的无人机前后移动的姿态控制量,Croll是无头控制下的无人机横向移动的姿态控制量,Cthrust是无头控制下的无人机上下移动的姿态控制量。
[0040] 采用上述技术方案后,本发明与现有技术相比具有以下有益效果。
[0041] 通过上述技术方案,当用户触发无头控制键时,在用户利用遥控器控制无人机飞行时,无论无人机的机头处于哪个方向,无人机都会以用户的方位进行飞行,并且由于系统在实时计算遥控器指向无人机的航向角,用户利用遥控器控制无人机向左或右飞行时,无人机就会以用户为中心以无人机到用户的距离为半径盘旋飞行。
[0042] 或者,当用户触发遥控器上的起飞按键,遥控器就会接收到起飞命令,然后,无人机就会以用户的方位进行飞行,这样,只要用户发起起飞控制,无论无人机的机头处于哪个方向,就可以从开始起飞直接进入无头控制模式,方便用户的使用。

附图说明

[0043] 为了更清楚的说明本发明具体实施方式中的技术方案,下面将对具体实施方式中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
[0044] 图1示出了本发明的一个实施例的无头控制的方法的流程图;
[0045] 图2示出了本发明的一个实施例的步骤Sa展开的流程图。

具体实施方式

[0046] 下面结合附图对本发明的具体实施方式作进一步详细的描述。
[0047] 如图1所示,一种无头控制的方法,所述无头控制的方法包括:
[0048] S1,遥控器接收到无头控制命令;
[0049] S2,遥控器实时计算遥控器指向无人机的航向角theta;
[0050] S3,根据航向角theta得出旋转矩阵DCM;
[0051] S4,将遥控器接收到的用户输入的初始控制量V与所述旋转矩阵DCM结合得出无人机的无头姿态控制量C;
[0052] S5,遥控器将无头姿态控制量C发送至无人机,以供无人机根据所述无头姿态控制量C调整飞行姿态。
[0053] 在上述技术方案中,在无人机的遥控器上设有无头控制键,当用户按下无头控制键时,系统就会计算该遥控器指向无人机的航向角theta,这样就知道了无人机相对于遥控器(即无人机相对于人)的方向,然后再利用该航向角theta确定出旋转矩阵DCM,这样,当用户向遥控器输入初始控制量V时,就可以将旋转矩阵DCM赋予到初始控制量V上,就可以得出控制无人机的无头姿态控制量C,无人机就可以根据该无头姿态控制量C进行飞行,这样无论无人机的机头处于哪个方向,经过上述方案后无人机都会按照遥控器(即人)的方位进行飞行。
[0054] 或者,当用户触发遥控器上的起飞按键,遥控器就会接收到起飞命令,然后,无人机就会以用户的方位进行飞行,这样,只要用户发起起飞控制,无论无人机的机头处于哪个方向,就可以从开始起飞直接进入无头控制模式,方便用户的使用。
[0055] 其中由于系统在实时计算遥控器指向无人机的航向角theta,所以用户利用遥控器控制无人机向左或右飞行时,无人机就会以用户为中心以无人机到用户的距离为半径盘旋飞行。
[0056] 例如,当用户在利用遥控器控制飞机飞行时,用户按下遥控器上的无头控制键,然后用户利用遥控器控制飞机向前飞行,这样无论飞机的机头在哪,都会向人的前方飞行,利用遥控器控制飞机向后飞行,飞机就会向人靠近,当用户利用遥控器控制飞机向左或右飞行,这样飞机就会以用户为中心顺时针或逆时针盘旋飞行。
[0057] 通过上述技术方案,当用户触发无头控制键,或者触发起飞按键通过遥控器控制无人机起飞时,用户利用遥控器控制无人机飞行,无论无人机的机头处于哪个方向,无人机都会以用户的方位进行飞行,并且由于系统在实时计算遥控器指向无人机的航向角,用户利用遥控器控制无人机向左或右飞行时,无人机就会以用户为中心以无人机到用户的距离为半径盘旋飞行。
[0058] 优选地,在所述步骤S1与S2之间还包括:
[0059] Sa,根据遥控器与无人机的实时距离S是否在危险距离范围内,来确定无人机的飞行状态。
[0060] 如图2所示,所述步骤Sa具体包括:
[0061] Sa1,遥控器实时计算遥控器与无人机的实时距离S;
[0062] Sa2,当所述实时距离S大于危险距离时,无人机正常飞行,当所述实时距离S小于或等于危险距离时,无人机悬停。
[0063] 在上述技术方案中,为了保证用户的安全,防止无人机出现故障掉落时伤害到用户,需要为无人机的飞行设置危险距离,这样当用户触发无头控制键后,系统就会实时计算遥控器与无人机的实时距离S,当计算得出的实时距离S小于或等于危险距离(即,在危险距离范围内),就会控制无人机静止悬停在空中,这样无人机不会飞到用户的头顶排除安全隐患,同时,确保在进行无头模式飞行时,确保无人机前后运动时都沿着指向用户位置的半径方向运动。
[0064] 通过上述技术方案,保证了用户的人身安全,提高了无人机的安全系数。
[0065] 优选地,所述步骤Sa1具体包括:
[0066] 实时获取遥控器的纬度lat1和经度lon1,以及无人机的纬度lat2和经度lon2;
[0067] 计算遥控器和无人机的纬度差θ=lat1-lat2,和经度差b=lon1-lon2;
[0068] 根据lat1、lon1、lat2、lon2、θ、b和earth_radius计算遥控器与无人机的实时距离S,其中,earth_radius是地球半径。
[0069] 优选地,所述实时距离S为:
[0070]
[0071] 在上述技术方案中,当用户触发无头控制键时,利用GPS获取遥控器的经纬度lon1和lat1,和无人机的经纬度lon2和lat2,然后计算遥控器和无人机的纬度差θ=lat1-lat2和经度差b=lon1-lon2,这样就可以计算实时距离S了。
[0072] 优选地,所述航向角theta为:
[0073] theta=arctan2f(sin(b)*cos(lat2),cos(lat1)*cos(lat2)*sin(lat2)-sin(lat1)*cos(lat2)*cos(b))。
[0074] 优选地,所述旋转矩阵DCM为:
[0075]
[0076] 其中,pitch=0,roll=0,yaw=theta。
[0077] 在上述技术方案中,根据pitch、roll和yaw计算并得出旋转矩阵DCM,并且将pitch=0,roll=0,yaw=theta赋予到旋转矩阵DCM中,这时,当用户向遥控器输入初始控制量V时,就可以将旋转矩阵DCM赋予到初始控制量V上,得出控制无人机的无头姿态控制量C,无人机就可以根据该无头姿态控制量C进行飞行,这样无论无人机的机头处于哪个方向,经过上述方案后无人机都会按照遥控器(即人)的方位进行飞行,因此,此时就可以认为无人机的机头方向已经改变了,机头变成人的前方方向,这样有利于用户利用遥控器直接控制无人机的飞行。
[0078] 优选地,所述步骤S4具体包括:
[0079] 遥控器接收用户输入的初始控制量V;
[0080] 计算无人机的无头姿态控制量C为:
[0081] C=DCM*V。
[0082] 优选地,所述初始控制量V为:
[0083]
[0084] 其中,Vpitch是遥控器接收的无人机前后移动的控制量,Vroll是遥控器接收的无人机横向移动的控制量,Vthrust是遥控器接收的无人机上下移动的控制量。
[0085] 优选地,所述无人机的无头姿态控制量C为:
[0086]
[0087] 其中,Cpitch是无头控制下的无人机前后移动的姿态控制量,Croll是无头控制下的无人机横向移动的姿态控制量,Cthrust是无头控制下的无人机上下移动的姿态控制量。
[0088] 在上述技术方案中,当接收到用户利用遥控器发出的控制信号后,将控制信号转换成相应的初始控制量V,然后将旋转矩阵DCM与该初始控制量V做乘运算后得出能够控制无人机飞行的无头姿态控制量C,无人机就可以按照该无头姿态控制量C来调整飞行姿态,就可以以用户的方位进行飞行了。
[0089] 通过本发明的技术方案,当用户触发无头控制键时,在用户利用遥控器控制无人机飞行时,无论无人机的机头处于哪个方向,无人机都会以用户的方位进行飞行,并且由于系统在实时计算遥控器指向无人机的航向角用户利用遥控器控制无人机向左或右飞行时,无人机就会以用户为中心以无人机到用户的距离为半径盘旋飞行。
[0090] 或者,当用户触发遥控器上的起飞按键,遥控器就会接收到起飞命令,然后,无人机就会以用户的方位进行飞行,这样,只要用户发起起飞控制,无论无人机的机头处于哪个方向,就可以从开始起飞直接进入无头控制模式,方便用户的使用。
[0091] 上述实施例中的实施方案可以进一步组合或者替换,且实施例仅仅是对本发明的优选实施例进行描述,并非对本发明的构思和范围进行限定,在不脱离本发明设计思想的前提下,本领域中专业技术人员对本发明的技术方案做出的各种变化和改进,均属于本发明的保护范围。