CN112870595B - 一种举高消防机器人控制方法、装置及系统 - Google Patents
一种举高消防机器人控制方法、装置及系统 Download PDFInfo
- Publication number
- CN112870595B CN112870595B CN202011620629.8A CN202011620629A CN112870595B CN 112870595 B CN112870595 B CN 112870595B CN 202011620629 A CN202011620629 A CN 202011620629A CN 112870595 B CN112870595 B CN 112870595B
- Authority
- CN
- China
- Prior art keywords
- fire
- container
- height
- target
- joint
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- A—HUMAN NECESSITIES
- A62—LIFE-SAVING; FIRE-FIGHTING
- A62C—FIRE-FIGHTING
- A62C27/00—Fire-fighting land vehicles
-
- A—HUMAN NECESSITIES
- A62—LIFE-SAVING; FIRE-FIGHTING
- A62C—FIRE-FIGHTING
- A62C31/00—Delivery of fire-extinguishing material
-
- A—HUMAN NECESSITIES
- A62—LIFE-SAVING; FIRE-FIGHTING
- A62C—FIRE-FIGHTING
- A62C31/00—Delivery of fire-extinguishing material
- A62C31/28—Accessories for delivery devices, e.g. supports
-
- A—HUMAN NECESSITIES
- A62—LIFE-SAVING; FIRE-FIGHTING
- A62C—FIRE-FIGHTING
- A62C37/00—Control of fire-fighting equipment
- A62C37/36—Control of fire-fighting equipment an actuating signal being generated by a sensor separate from an outlet device
- A62C37/38—Control of fire-fighting equipment an actuating signal being generated by a sensor separate from an outlet device by both sensor and actuator, e.g. valve, being in the danger zone
- A62C37/40—Control of fire-fighting equipment an actuating signal being generated by a sensor separate from an outlet device by both sensor and actuator, e.g. valve, being in the danger zone with electric connection between sensor and actuator
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02A—TECHNOLOGIES FOR ADAPTATION TO CLIMATE CHANGE
- Y02A40/00—Adaptation technologies in agriculture, forestry, livestock or agroalimentary production
- Y02A40/10—Adaptation technologies in agriculture, forestry, livestock or agroalimentary production in agriculture
- Y02A40/28—Adaptation technologies in agriculture, forestry, livestock or agroalimentary production in agriculture specially adapted for farming
Landscapes
- Health & Medical Sciences (AREA)
- Public Health (AREA)
- Business, Economics & Management (AREA)
- Emergency Management (AREA)
- Fire-Extinguishing By Fire Departments, And Fire-Extinguishing Equipment And Control Thereof (AREA)
Abstract
本发明公开了一种举高消防机器人控制方法、装置及系统,该系统包括车体、塔臂、联动臂、主臂和伸缩臂;该方法包括控制塔臂与车体关节旋转角度,调节消防炮粗对准消防目标方向;联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,使消防炮精确对准消防目标。本发明对举高消防机器人的调节不需要人为手动控制,通过顺序控制关节运动,实现举高臂运动路径平稳可控。
Description
技术领域
本发明涉及一种举高消防机器人控制方法、装置及系统,属于消防控制技术领域。
背景技术
随着经济不断地发展,人们生活水平越来越提高,机器人应用开始出现在各行各业中,协助工作人员解决各类问题。特别是消防行业,机器人不仅能协助消防人员获取更多现场信息,还能代替消防人员进入危险领域进行消防工作,提升了消防工作人员灭火救援的能力和效率,更能大大减少工作人员作业危险系数,有效保障相关人员的生命安全。
消防机器人种类繁多,其中举高机器人是为最常见的一种。举高机器人通常在举高臂的末端安装风炮、水炮等消防设备;甚至可以在举高末端安装救援台,将救援台升到指定高度救援高处被困人员。传统的举高消防机器人是通过人员手动操纵操作杆一个个关节进行控制,使得举高臂到达目标高度,这种控制方式操作繁琐,人为误操作概率高,造成控制效率低下,控制精度低;并且需要培训专业人员操纵,培训成本高。中国专利申请号201210398019.7公开了一种举高消防车臂架控制系统及控制方法,该控制方法是根据预先设定的臂架目标位置参数,以及检测装置所检测到实时臂长度和角度,同时控制所有的执行机构完成臂架全部动作,不进行单独控制每个臂运动。虽然同时发出控制每个臂运动可以对控制流程简单化,缩短控制时间,但由于同时发出控制每个臂运动,只关注初始状态和目标状态,举高臂的中间运动姿态无法控制,中间路点无法得到控制,路径不可控容易产生自身碰撞以及与环境物体发生碰撞,造成了严重的事故,作业过程得不到安全保障。
发明内容
本发明所要解决的技术问题是克服现有技术的缺陷,提供一种举高消防机器人控制方法、装置及系统,不需要人为手动控制,通过顺序控制关节运动,举高臂运动路径实现平稳可控。
为解决上述技术问题,本发明采用的技术方案如下:
本发明提供一种举高消防机器人控制系统,包括:车体、塔臂、联动臂、主臂和伸缩臂;所述车体与塔臂之间以转动关节形式链接,所述塔臂和联动臂以联动关节形式链接,所述联动臂和主臂之间以转动关节链接,所述主臂和伸缩臂之间以平移关节链接,所述消防炮台与伸缩臂之间以关节形式链接;所述消防炮台用于安装消防炮。
本发明还提供一种举高消防机器人控制方法,包括:
控制塔臂与车体关节旋转角度,调节消防炮粗对准消防目标方向;
联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;
控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,使消防炮最终对准消防目标。
进一步的,所述调节消防炮粗对准消防目标方向,包括:
获取消防目标点位置,计算得到消防目标点相对于车体位置(Xt,Yt,Hc),
其中,Xt,Yt,Hc分别为X轴,Y轴和Z轴坐标,以右手定则为基础,车头方向X轴方向,垂直于车体为Y轴方向,Z轴为高度;
如果Xt>0,则控制塔臂相对车体转动角度为:Jt0=arctan(Yt/Xt);
如果Xt<0,则控制塔臂相对车体转动角度为:Jt0=Pi+arctan(Yt/Xt);
其中,Jt0为塔臂相对车体转动角度,Pi为圆周率。
进一步的,所述调节消防炮举高高度,包括:
获取举高消防机器人当前关节状态初始信息并储存为当前容器Jc,以及获取目标高度Ht;Jc=(Jc0,Jc1,Jc2,...,Jcn),其中0,1,2,…,n为关节序号;
根据当前容器Jc中的元素计算举高消防机器人当前高度Hc,以及根据当前容器Jc的元素计算目标高度对应的举高消防机器人的初步目标关节状态并存储为目标容器Jt,Jt=(Jt0,Jt1,Jt2,...,Jtn);
根据目标高度和当前高度选择控制策略,如果目标高度大于当前高度,则选择上升控制策略,反之选择下降控制策略。
进一步的,所述上升控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从大到小进行排序;
第二步:基于排序后的差值容器Ja获取最大元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否大于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步;
所述下降控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从小到大进行排序;
第二步:基于排序后的差值容器Ja获取最小元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否小于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步。
进一步的,
所述根据当前容器Jc中的元素计算举高消防机器人当前高度Hc,包括:
对当前容器Jc存储的关节状态进行正向运动学求解,得到举高消防机器人当前高度Hc;
所述根据当前容器Jc的元素计算目标高度对应的举高消防机器人的初步目标关节状态,包括:
对当前容器Jc存储的关节状态进行逆向运动学求解,得到目标高度对应的举高消防机器人的初步目标关节状态。
进一步的,所述上升控制策略和所述下降控制策略还包括:
预先构建测试容器,将当前容器Jc中的元素复制到测试容器Jb中,对测试容器进行初步赋值。
进一步的,所述上升控制策略中,对差值容器Ja内的元素按照从大到小进行排序,包括:
采用冒泡法或对比法将差值容器Ja内的元素进行从大到小排序。
进一步的,所述调节消防炮俯仰角,包括:
获取消防炮的消防物喷射轨迹;
计算消防物喷射轨迹落地点与消防目标距离值;
根据距离值进行自动或人工控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角。
本发明还提供一种举高消防机器人控制装置,包括:
第一调节模块,用于控制塔臂与车体关节旋转角度,调节消防炮粗对准消防目标方向;
第二调节模块,用于联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;
以及,
第三调节模块,用于控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,使消防炮最终对准消防目标。
进一步的,所述第一调节模块具体用于,
获取消防目标点位置,计算得到消防目标点相对于车体位置(Xt,Yt,Hc),
其中,Xt,Yt,Hc分别为X轴,Y轴和Z轴坐标,以右手定则为基础,车头方向X轴方向,垂直于车体为Y轴方向,Z轴为高度;
如果Xt>0,则控制塔臂相对车体转动角度为:Jt0=arctan(Yt/Xt);
如果Xt<0,则控制塔臂相对车体转动角度为:Jt0=Pi+arctan(Yt/Xt);
其中,Jt0为塔臂相对车体转动角度,Pi为圆周率。
进一步的,所述第二调节模块具体用于,
获取举高消防机器人当前关节状态初始信息并储存为当前容器Jc,以及获取目标高度Ht;Jc=(Jc0,Jc1,Jc2,...,Jcn),其中0,1,2,…,n为关节序号;
根据当前容器Jc中的元素计算举高消防机器人当前高度Hc,以及根据当前容器Jc的元素计算目标高度对应的举高消防机器人的初步目标关节状态并存储为目标容器Jt,Jt=(Jt0,Jt1,Jt2,...,Jtn);
根据目标高度和当前高度选择控制策略,如果目标高度大于当前高度,则选择上升控制策略,反之选择下降控制策略。
进一步的,
所述上升控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从大到小进行排序;
第二步:基于排序后的差值容器Ja获取最大元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否大于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步;
所述下降控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从小到大进行排序;
第二步:基于排序后的差值容器Ja获取最小元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否小于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步。
进一步的,所述第三调节模块具体用于,
获取消防炮的消防物喷射轨迹;
计算消防物喷射轨迹落地点与消防目标距离值;
根据距离值进行自动或人工控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角。
本发明所达到的有益效果:
本发明对举高消防机器人进行调节控制,按顺序逐一对对关节进行寻优最优,能快速求解得到最优解,通过顺序控制关节运动,举高臂运动路径实现可控,解决了运动中间状态为不可控,出现有的臂需要回收有的需要伸展,举高臂末端容易出现上下振荡运动现象,运动不平稳,控制精度低等问题;本发明大大减少了对工作人员培训成本,大大降低了劳动强度,提高劳动效率和作业的规范性。
附图说明
图1为本发明的举高消防机器人控制系统示意图;
图2为本发明的举高消防机器人控制方法流程图;
图3为本发明的举高消防机器人控制方法的下降控制策略流程图;
图4为本发明的举高消防机器人控制方法的上升控制策略流程图。
具体实施方式
下面对本发明作进一步描述。以下实施例仅用于更加清楚地说明本发明的技术方案,而不能以此来限制本发明的保护范围。
本发明实施例提供一种举高消防机器人控制系统,参见图1,包括:车体1、塔臂2、联动臂3、主臂4和伸缩臂5。其中车体1与塔臂2之间以转动关节形式链接,塔臂2和联动臂3以联动关节形式链接,联动臂3随塔臂2运动而动,联动臂3和主臂4之间以转动关节链接,主臂4和伸缩臂5之间以平移关节链接,消防炮台6与伸缩臂5之间以关节形式链接,消防炮台用于安装消防炮,调节消防炮俯仰角。
通过控制塔臂与车体关节旋转角度,用于调节消防炮粗对准消防目标方向;
通过联合控制塔臂、联动臂、主臂和伸缩臂,用于调节消防炮举高高度,高度对准消防目标,实现进一步精准对准消防目标;
通过控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,进一步精准对准消防目标。
本发明实施例还提供一种举高消防机器人控制方法,包括:
调节塔臂与车体关节旋转角度,使消防炮粗对准消防目标方向;
通过联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;
通过控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,完成消防炮调节。
具体的,调节塔臂与车体关节旋转角度,使消防炮粗对准消防目标方向,包括:
(1)通过传感器或人工获取消防目标点位置,进行数据处理分析得到消防目标点相对于车体位置(Xt,Yt,Hc),其中以右手定则为基础,车头方向X轴方向,垂直与车体为Y轴方向,Z轴为高度。
其中,传感器可以是视觉传感器、红外传感系统或者其他传感设。
(2)如果(Xt>0),则控制塔臂相对车体转动角度为:Jt0=arctan(Yt/Xt);
如果(Xt<0),则控制塔臂相对车体转动角度为:Jt0=Pi+arctan(Yt/Xt);
其中Pi为圆周率。
具体的,通过联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标,参见图2,包括:
第一步:获取初始信息。
具体的,包括:接收目标高度Ht,获取举高消防机器人当前关节状态并储存为当前容器Jc=(Jc0,Jc1,Jc2,...,Jcn),其中0,1,2,…,n为关节序号。
第二步:计算举高消防机器人当前高度Hc。
具体为,通过对当前容器Jc关节状态进行正向运动学求解,得到举高消防机器人当前高度Hc。
第三步:计算目标高度对应的举高消防机器人的初步目标关节。
具体为,通过对当前容器Jc关节状态进行逆向运动学求解,得到目标高度Ht的初步目标关节,存储为目标容器Jt=(Jt0,Jt1,Jt2,...,Jtn),其中0,1,2,…,n为关节序号。
第四步:将初步目标关节与当前关节差值进行比较。
具体为,将目标容器Jt与当前容器Jc进行关节状态相减,存储为差值容器Ja=(Ja0,Ja1,Ja2,...,Jan),其中0,1,2,…,n为关节序号。
第五步:根据目标高度和当前高度选择控制策略。
具体为,如果目标高度大于当前高度,即控制举高臂上升,即选择上升控制策略;反之则选择下降控制策略。
具体的,下降控制策略参见图3,包括:
第一步:构建测试容器并进行初步赋值。
具体为,将当前关节容器Jc中元素复制到测试容器Jb中,对测试容器进行初步赋值。
第二步:对差值容器进行排序。
具体为,将差值容器Ja内元素采用冒泡法或对比法等排列方法进行从小到大进行排序,最小元素值记为Jai,其中i为最小元素的关节号。
第三步:对测试容器再次赋值,求解测试高度。
具体为,把测试容器Jb中的第i关节号元素替换成目标容器Jt的第i关节号元素值,即Jbi=Jti;
然后对测试容器Jb进行正向运动学计算得到测试高度Hb。
第四步:判断测试高度Hb是否等于目标高度Ht。
如果相等,则记录第i关节控制状态Jti以堆栈形式放入控制容器C中。再按进入堆栈控制容器C的先后顺序,发送相对应的关节控制状态使举高消防机器人运动到达相应位置。结束完成控制。
如果测试高度Hb不等于目标高度Ht,则跳到第五步。
第五步:判断测试高度Hb是否小于目标高度Ht。
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm。跳到第三步。
如果测试高度Hb大于目标高度Ht,记录第i关节控制状态Jti以堆栈形式放入控制容器C中;
然后将差值容器Ja内的第i关节号元素删除。跳到第二步。
具体的,上升控制策略参见图4,包括:
第一步:构建测试容器并进行初步赋值。
具体为,将当前关节容器Jc中元素复制到测试容器Jb中,对测试容器进行初步赋值。
第二步:对差值容器进行排序。
具体为,将差值容器Ja内元素采用冒泡法或对比法等排列方法进行从大到小进行排序,最大元素值记为Jai,其中i为最大元素的关节号。
第三步:对测试容器再次赋值,求解测试高度。
具体为,把测试容器Jb中的第i关节号元素替换成目标容器Jt的第i关节号元素值,即Jbi=Jti;
然后对测试容器Jb进行正向运动学计算得到测试高度Hb。
第四步:判断测试高度Hb是否等于目标高度Ht。
如果相等,则记录第i关节控制状态Jti以堆栈形式放入控制容器C中。再按进入堆栈控制容器C的先后顺序,发送相对应的关节控制状态使举高消防机器人运动到达相应位置。结束完成控制。
如果测试高度Hb不等于目标高度Ht,则跳到第五步。
第五步:判断测试高度Hb是否大于目标高度Ht。
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm。跳到第三步。
如果测试高度Hb小于目标高度Ht,记录第i关节控制状态Jti以堆栈形式放入控制容器C中;
然后将差值容器Ja内的第i关节号元素删除。跳到第二步。
具体的,通过控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角包括:
通过视觉传感器或其他方法获取消防炮的消防物喷射轨迹,计算喷射轨迹落地点与消防目标距离值,进行自动或人工控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角。
本发明实施例还提供一种举高消防机器人控制装置,包括:
第一调节模块,用于控制塔臂与车体关节旋转角度,调节消防炮粗对准消防目标方向;
第二调节模块,用于联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;
以及,
第三调节模块,用于控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,使消防炮最终对准消防目标。
具体的,第一调节模块具体用于,
获取消防目标点位置,计算得到消防目标点相对于车体位置(Xt,Yt,Hc),
其中,Xt,Yt,Hc分别为X轴,Y轴和Z轴坐标,以右手定则为基础,车头方向X轴方向,垂直于车体为Y轴方向,Z轴为高度;
如果Xt>0,则控制塔臂相对车体转动角度为:Jt0=arctan(Yt/Xt);
如果Xt<0,则控制塔臂相对车体转动角度为:Jt0=Pi+arctan(Yt/Xt);
其中,Jt0为塔臂相对车体转动角度,Pi为圆周率。
具体的,第二调节模块具体用于,
获取举高消防机器人当前关节状态初始信息并储存为当前容器Jc,以及获取目标高度Ht;
Jc=(Jc0,Jc1,Jc2,...,Jcn),其中0,1,2,…,n为关节序号;
根据当前容器Jc计算举高消防机器人当前高度Hc;以及根据当前容器Jc计算目标高度对应的举高消防机器人的初步目标关节状态存储为目标容器Jt,Jt=(Jt0,Jt1,Jt2,...,Jtn);
计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan);
基于差值容器Ja选择控制策略;所述控制策略包括上升控制策略和下降控制策略。
具体的,上升控制策略为:
第一步:对差值容器Ja内的元素按照从大到小进行排序;
第二步:基于排序后的差值容器Ja获取最大元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否大于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步;
具体的,下降控制策略为:
第一步:对差值容器Ja内的元素按照从小到到进行排序;
第二步:基于排序后的差值容器Ja获取最小元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否小于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步。
具体的,第三调节模块具体用于,
获取消防炮的消防物喷射轨迹;
计算消防物喷射轨迹与消防目标距离值;
根据距离值进行自动或人工控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角。
值得指出的是,该装置实施例是与上述方法实施例对应的,上述方法实施例的实现方式均适用于该装置实施例中,并能达到相同或相似的技术效果,故不在此赘述。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
最后应当说明的是:以上实施例仅用以说明本发明的技术方案而非对其限制,尽管参照上述实施例对本发明进行了详细的说明,所属领域的普通技术人员应当理解:依然可以对本发明的具体实施方式进行修改或者等同替换,而未脱离本发明精神和范围的任何修改或者等同替换,其均应涵盖在本发明的权利要求保护范围之内。
Claims (9)
1.一种举高消防机器人控制方法,其特征在于,包括:
建立举高消防机器人控制系统,包括:车体、塔臂、联动臂、主臂和伸缩臂;所述车体与塔臂之间以转动关节形式链接,所述塔臂和联动臂以联动关节形式链接,所述联动臂和主臂之间以转动关节链接,所述主臂和伸缩臂之间以平移关节链接,所述消防炮台与伸缩臂之间以关节形式链接;所述消防炮台用于安装消防炮;
控制塔臂与车体关节旋转角度,调节消防炮粗对准消防目标方向;
联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;
控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,使消防炮最终对准消防目标;
所述调节消防炮举高高度,包括:获取举高消防机器人当前关节状态初始信息并储存为当前容器Jc,以及获取目标高度Ht;Jc=(Jc0,Jc1,Jc2,...,Jcn),其中0,1,2,…,n为关节序号;
根据当前容器Jc中的元素计算举高消防机器人当前高度Hc,以及根据当前容器Jc的元素计算目标高度对应的举高消防机器人的初步目标关节状态并存储为目标容器Jt,Jt=(Jt0,Jt1,Jt2,...,Jtn);
根据目标高度和当前高度选择控制策略,如果目标高度大于当前高度,则选择上升控制策略,反之选择下降控制策略;
所述上升控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从大到小进行排序;
第二步:基于排序后的差值容器Ja获取最大元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否大于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步;
所述下降控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从小到大进行排序;
第二步:基于排序后的差值容器Ja获取最小元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否小于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步。
2.根据权利要求1所述的一种举高消防机器人控制方法,其特征在于,所述调节消防炮粗对准消防目标方向,包括:
获取消防目标点位置,计算得到消防目标点相对于车体位置(Xt,Yt,Hc),
其中,Xt,Yt,Hc分别为X轴,Y轴和Z轴坐标,以右手定则为基础,车头方向X轴方向,垂直于车体为Y轴方向,Z轴为高度;
如果Xt>0,则控制塔臂相对车体转动角度为:Jt0=arctan(Yt/Xt);
如果Xt<0,则控制塔臂相对车体转动角度为:Jt0=Pi+arctan(Yt/Xt);
其中,Jt0为塔臂相对车体转动角度,Pi为圆周率。
3.根据权利要求1所述的一种举高消防机器人控制方法,其特征在于,
所述根据当前容器Jc中的元素计算举高消防机器人当前高度Hc,包括:
对当前容器Jc存储的关节状态进行正向运动学求解,得到举高消防机器人当前高度Hc;
所述根据当前容器Jc的元素计算目标高度对应的举高消防机器人的初步目标关节状态,包括:
对当前容器Jc存储的关节状态进行逆向运动学求解,得到目标高度对应的举高消防机器人的初步目标关节状态。
4.根据权利要求1所述的一种举高消防机器人控制方法,其特征在于,所述上升控制策略和所述下降控制策略还包括:
预先构建测试容器,将当前容器Jc中的元素复制到测试容器Jb中,对测试容器进行初步赋值。
5.根据权利要求1所述的一种举高消防机器人控制方法,其特征在于,所述上升控制策略中,对差值容器Ja内的元素按照从大到小进行排序,包括:
采用冒泡法或对比法将差值容器Ja内的元素进行从大到小排序。
6.根据权利要求1所述的一种举高消防机器人控制方法,其特征在于,所述调节消防炮俯仰角,包括:
获取消防炮的消防物喷射轨迹;
计算消防物喷射轨迹落地点与消防目标距离值;
根据距离值进行自动或人工控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角。
7.一种举高消防机器人控制装置,其特征在于,包括:
第一调节模块,用于控制塔臂与车体关节旋转角度,调节消防炮粗对准消防目标方向;
第二调节模块,用于联合控制塔臂、联动臂、主臂和伸缩臂,调节消防炮举高高度,使消防炮高度对准消防目标;
以及,
第三调节模块,用于控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角,使消防炮最终对准消防目标;
所述第二调节模块调节消防炮举高高度具体实现过程为,
获取举高消防机器人当前关节状态初始信息并储存为当前容器Jc,以及获取目标高度Ht;Jc=(Jc0,Jc1,Jc2,...,Jcn),其中0,1,2,…,n为关节序号;
根据当前容器Jc中的元素计算举高消防机器人当前高度Hc,以及根据当前容器Jc的元素计算目标高度对应的举高消防机器人的初步目标关节状态并存储为目标容器Jt,Jt=(Jt0,Jt1,Jt2,...,Jtn);
根据目标高度和当前高度选择控制策略,如果目标高度大于当前高度,则选择上升控制策略,反之选择下降控制策略;
所述上升控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从大到小进行排序;
第二步:基于排序后的差值容器Ja获取最大元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否大于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步;
所述下降控制策略为:
第一步:计算目标容器Jt中元素与当前容器Jc中元素的差值并储存为差值容器Ja,Ja=(Ja0,Ja1,Ja2,...,Jan),对差值容器Ja内的元素按照从小到大进行排序;
第二步:基于排序后的差值容器Ja获取最小元素的关节号i,采用目标容器Jt的第i关节号元素值Jti替换测试容器Jb中的第i关节号元素Jbi,Jbi=Jti,更新预先构建的测试容器Jb,并根据更新后的测试容器Jb求解测试高度Hb;
第三步:将测试高度Hb与目标高度Ht进行对比,
如果相等,则将Jti以堆栈形式放入控制容器C中,再按进入堆栈控制容器C的先后顺序,发送相对应的关节状态至举高消防机器人,使举高消防机器人运动到达相应位置,高度调节结束;
如果不相等,则判断测试高度Hb是否小于目标高度Ht,
如果是,则设置中间变量Jm=(Jti+Jci)/2,把目标容器Jt中的第i关节号元素替换中间变量Jm,即Jti=Jm;跳到第二步;
如果否,则将Jti以堆栈形式放入控制容器C中;然后将差值容器Ja内的第i关节号元素删除;跳到第一步。
8.根据权利要求7所述的一种举高消防机器人控制装置,其特征在于,所述第一调节模块具体用于,
获取消防目标点位置,计算得到消防目标点相对于车体位置(Xt,Yt,Hc),
其中,Xt,Yt,Hc分别为X轴,Y轴和Z轴坐标,以右手定则为基础,车头方向X轴方向,垂直于车体为Y轴方向,Z轴为高度;
如果Xt>0,则控制塔臂相对车体转动角度为:Jt0=arctan(Yt/Xt);
如果Xt<0,则控制塔臂相对车体转动角度为:Jt0=Pi+arctan(Yt/Xt);
其中,Jt0为塔臂相对车体转动角度,Pi为圆周率。
9.根据权利要求7所述的一种举高消防机器人控制装置,其特征在于,所述第三调节模块具体用于,
获取消防炮的消防物喷射轨迹;
计算消防物喷射轨迹落地点与消防目标距离值;
根据距离值进行自动或人工控制消防炮台与伸缩臂关节旋转角度,调节消防炮俯仰角。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011620629.8A CN112870595B (zh) | 2020-12-30 | 2020-12-30 | 一种举高消防机器人控制方法、装置及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011620629.8A CN112870595B (zh) | 2020-12-30 | 2020-12-30 | 一种举高消防机器人控制方法、装置及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112870595A CN112870595A (zh) | 2021-06-01 |
CN112870595B true CN112870595B (zh) | 2022-07-08 |
Family
ID=76046504
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011620629.8A Active CN112870595B (zh) | 2020-12-30 | 2020-12-30 | 一种举高消防机器人控制方法、装置及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112870595B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115957469A (zh) * | 2022-12-28 | 2023-04-14 | 湖南中联重科应急装备有限公司 | 用于消防车的控制方法、存储介质、处理器及消防车 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6434437B1 (en) * | 1999-12-02 | 2002-08-13 | Caterpillar Inc. | Boom extension and boom angle control for a machine |
CN201006212Y (zh) * | 2007-03-09 | 2008-01-16 | 杨绍辉 | 移动式曲臂举高多功能消防炮 |
CN102743832A (zh) * | 2012-06-20 | 2012-10-24 | 中联重科股份有限公司 | 一种消防机械灭火作业的控制方法、装置及系统 |
CN103147577A (zh) * | 2013-02-27 | 2013-06-12 | 中联重科股份有限公司 | 多关节类机械臂架的控制方法、设备、系统及工程机械 |
CN105975795A (zh) * | 2016-05-23 | 2016-09-28 | 湖北工业大学 | 一种高精度的多关节串联机械臂运动学反解解法 |
CN207980227U (zh) * | 2018-02-05 | 2018-10-19 | 四川川消消防车辆制造有限公司 | 一种举高消防车联动臂架及消防车 |
CN110524544A (zh) * | 2019-10-08 | 2019-12-03 | 深圳前海达闼云端智能科技有限公司 | 一种机械臂运动的控制方法、终端和可读存储介质 |
WO2020151406A1 (zh) * | 2019-01-21 | 2020-07-30 | 北京镁伽机器人科技有限公司 | 运动控制方法、装置和系统及存储介质 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP5754454B2 (ja) * | 2013-03-18 | 2015-07-29 | 株式会社安川電機 | ロボットピッキングシステム及び被加工物の製造方法 |
DE102018104491A1 (de) * | 2018-02-27 | 2019-08-29 | Putzmeister Engineering Gmbh | Großmanipulator mit Schwingungsdämpfer |
-
2020
- 2020-12-30 CN CN202011620629.8A patent/CN112870595B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6434437B1 (en) * | 1999-12-02 | 2002-08-13 | Caterpillar Inc. | Boom extension and boom angle control for a machine |
CN201006212Y (zh) * | 2007-03-09 | 2008-01-16 | 杨绍辉 | 移动式曲臂举高多功能消防炮 |
CN102743832A (zh) * | 2012-06-20 | 2012-10-24 | 中联重科股份有限公司 | 一种消防机械灭火作业的控制方法、装置及系统 |
CN103147577A (zh) * | 2013-02-27 | 2013-06-12 | 中联重科股份有限公司 | 多关节类机械臂架的控制方法、设备、系统及工程机械 |
CN105975795A (zh) * | 2016-05-23 | 2016-09-28 | 湖北工业大学 | 一种高精度的多关节串联机械臂运动学反解解法 |
CN207980227U (zh) * | 2018-02-05 | 2018-10-19 | 四川川消消防车辆制造有限公司 | 一种举高消防车联动臂架及消防车 |
WO2020151406A1 (zh) * | 2019-01-21 | 2020-07-30 | 北京镁伽机器人科技有限公司 | 运动控制方法、装置和系统及存储介质 |
CN110524544A (zh) * | 2019-10-08 | 2019-12-03 | 深圳前海达闼云端智能科技有限公司 | 一种机械臂运动的控制方法、终端和可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN112870595A (zh) | 2021-06-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108098738A (zh) | 基于混联机构的移动机械手作业平稳性控制方法及设备 | |
CN105204515B (zh) | 无人机自主着陆的测量解析及控制方法和装置 | |
CN107538508A (zh) | 基于视觉定位的机器人自动装配方法与系统 | |
CN112870595B (zh) | 一种举高消防机器人控制方法、装置及系统 | |
CN112859840B (zh) | 一种变电站足式巡检机器人路径规划方法及系统 | |
CN109933096B (zh) | 一种云台伺服控制方法及系统 | |
CN107966907B (zh) | 一种应用于冗余度机械臂的障碍物躲避解决方法 | |
CN101774170A (zh) | 核电站作业机器人及其控制系统 | |
CN112958959A (zh) | 一种基于三维视觉的自动化焊接和检测方法 | |
CN113362396A (zh) | 一种移动机器人3d手眼标定方法及装置 | |
WO2024077884A1 (zh) | 电池定位方法、装置、设备、存储介质及换电站 | |
TW201924882A (zh) | 表面處理系統之控制方法 | |
JP2023133088A (ja) | 複雑な大型部材用の可動式のフレキシブル測定システム及び測定方法 | |
CN115645043A (zh) | 一种机器人运动轨迹的规划方法 | |
Zeng et al. | Autonomous control design of an unmanned aerial manipulator for contact inspection | |
CN111993414A (zh) | 一种机械臂多关节联动控制方法 | |
CN107263457A (zh) | 分体式机器人及其组合、分离方法 | |
CN102873678B (zh) | 一种控制焊接烟尘进风口姿态和空间位移的装置及方法 | |
CN113074589B (zh) | 适用于导弹的自动装填运动控制系统及方法 | |
CN112847384A (zh) | 一种死鸡捡拾装置及控制系统和控制方法 | |
CN113608464B (zh) | 一种泵车的防倾覆安全控制方法、装置及系统 | |
EP2359202A1 (de) | Verfahren und vorrichtung zur auswahl einer gespeicherten position eines arbeitspunktes eines manipulators | |
CN116620802A (zh) | 一种利用室内施工智能物料运输系统的运输方法 | |
CN116238556A (zh) | 一种基于人工智能的车钩自动摘复方法 | |
CN110092301A (zh) | 一种多行吊系统及其运行控制方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |