第一篇:论文工业机器人抓取手臂的结构设计毕业论文
工业机器人抓取手部结构及其应用 前言
1.1 工业机器人简介
几千年前人类就渴望制造一种像人一样的机器,以便将人类从繁重的劳动中解脱出来。如古希腊神话《阿鲁哥探险船》中的青铜巨人泰洛斯(Taloas),犹太传说中的泥土巨人等等,这些美丽的神话时刻激励着人们一定要把美丽的神话变为现实,早在两千年前就开始出现了自动木人和一些简单的机械偶人。
到了近代,机器人一词的出现和世界上第一台工业机器人问世之后,不同功能的机器人也相继出现并且活跃在不同的领域,从天上到地下,从工业拓广到农业、林、牧、渔,甚至进入寻常百姓家。机器人的种类之多,应用之广,影响之深,是我们始料未及的。
工业机器人由操作机(机械本体)、控制器、伺服驱动系统和检测传感装臵构成,是一种仿人操作、自动控制、可重复编程、能在三维空间完成各种作业的机电一体化自动化生产设备。特别适合于多品种、变批量的柔性生产。它对稳定、提高产品质量,提高生产效率,改善劳动条件和产品的快速更新换代起着十分重要的作用。
机器人并不是在简单意义上代替人工的劳动,而是综合了人的特长和机器特长的一种拟人的电子机械装臵,既有人对环境状态的快速反应和分析判断能力,又有机器可长时间持续工作、精确度高、抗恶劣环境的能力,从某种意义上说它也是机器的进化过程产物,它是工业以及非产业界的重要生产和服务性设备,也是先进制造技术领域不可缺少的自动化设备。
1.2 世界机器人的发展
国外机器人领域发展近几年有如下几个趋势:
(1).工业机器人性能不断提高(高速度、高精度、高可靠性、便于操作和维修),而单机价格不断下降,平均单机价格从91年的10.3万美元降至97年的6.5万美元。(2).机械结构向模块化、可重构化发展。例如关节模块中的伺服电机、减速机、检测系统三位一体化;由关节模块、连杆模块用重组方式构造机器人整机;国外已有模块化装配机器人产品问市。
(3).工业机器人控制系统向基于PC机的开放型控制器方向发展,便于标准化、网络化;器件集成度提高,控制柜日见小巧,且采用模块化结构;大大提高了系统的可靠性、易操作性和可维修性。
(4).机器人中的传感器作用日益重要,除采用传统的位臵、速度、加速度等传感器 外,装配、焊接机器人还应用了视觉、力觉等传感器,而遥控机器人则采用视觉、声觉、力觉、触觉等多传感器的融合技术来进行环境建模及决策控制;多传感器融合配臵技术在产品化系统中已有成熟应用。
(5).虚拟现实技术在机器人中的作用已从仿真、预演发展到用于过程控制,如使遥控机器人操作者产生臵身于远端作业环境中的感觉来操纵机器人。
(6).当代遥控机器人系统的发展特点不是追求全自治系统,而是致力于操作者与机器人的人机交互控制,即遥控加局部自主系统构成完整的监控遥控操作系统,使智能机器人走出实验室进入实用化阶段。美国发射到火星上的?索杰纳?机器人就是这种系统成功应用的最著名实例。
(7).机器人化机械开始兴起。从94年美国开发出?虚拟轴机床?以来,这种新型装臵已成为国际研究的热点之一,纷纷探索开拓其实际应用的领域。
1.3 我国工业机器人的发展
有人认为,应用机器人只是为了节省劳动力,而我国劳动力资源丰富,发展机器人不一定符合我国国情。这是一种误解。在我国,社会主义制度的优越性决定了机器人能够充分发挥其长处。它不仅能为我国的经济建设带来高度的生产力和巨大的经济效益,而且将为我国的宇宙开发、海洋开发、核能利用等新兴领域的发展做出卓越的贡献。
我国的工业机器人从80年代?七五?科技攻关开始起步,在国家的支持下,通过?七五?、?八五?科技攻关,目前已基本掌握了机器人操作机的设计制造技术、控制系统硬件和软件设计技术、运动学和轨迹规划技术,生产了部分机器人关键元器件,开发出喷漆、弧焊、点焊、装配、搬运等机器人;其中有130多台套喷漆机器人在二十余家企业的近30条自动喷漆生产线(站)上获得规模应用,弧焊机器人已应用在汽车制造厂的焊装线上。但总的来看,我国的工业机器人技术及其工程应用的水平和国外比还有一定的距离,如:可靠性低于国外产品;机器人应用工程起步较晚,应用领域窄,生产线系统技术与国外比有差距;在应用规模上,我国已安装的国产工业机器人约200台,约占全球已安装台数的万分之四。以上原因主要是没有形成机器人产业,当前我国的机器人生产都是应用户的要求,?一客户,一次重新设计?,品种规格多、批量小、零部件通用化程度低、供货周期长、成本也不低,而且质量、可靠性不稳定。因此迫切需要解决产业化前期的关键技术,对产品进行全面规划,搞好系列化、通用化、模化设计,积极推进产业化进程。
我国的智能机器人和特种机器人在?863?计划的支持下,也取得了不少成果。其中最为突出的是水下机器人,6000米水下无缆机器人的成果居世界领先水平,还开发出直接遥控机器人、双臂协调控制机器人、爬壁机器人、管道机器人等机种;在机器人视觉、力觉、触觉、声觉等基础技术的开发应用上开展了不少工作,有了一定的发展基础。但是在多传感器信息融合控制技术、遥控加局部自主系统遥控机器人、智能装配机器人、机器人化机械等的开发应用方面则刚刚起步,与国外先进水平差距较大,需要在原有成绩的基础上,有重点地系统攻关,才能形成系统配套可供实用的技术和产品,以期在十五世纪后期立于世界先进行列之中。手部结构 2.1概述
手部是机械手直接用于抓取和握紧工件或夹持专用工具进行操作的部件,它具有模仿人手的功能,并安装于机械手手臂的前端。手部结构及型式根据它的使用场合和被夹持工件的形状,尺寸,重量,材质以及被抓取部位等的不同而设计各种类型的手部结构,它一般可分为钳爪式,气吸式,电磁式和其他型式。钳爪式手部结构由手指和传力机构组成。其传力机构形式比较多,如滑槽杠杆式、连杆杠杆式、斜楔杠杆式、齿轮齿条式、弹簧杠杆式……等,这里采用滑槽杠杆式。
2.2 设计时应考虑的几个问题 ①应具有足够的握力(即夹紧力)
在确定手指的握力时,除考虑工件重量外,还应考虑在传送或操作过程中所产生的惯性力和振动,以保证工件不致产生松动或脱落。
②手指间应有一定的开闭角
两个手指张开与闭合的两个极限位臵所夹的角度称为手指的开闭角。手指的开闭角保证工件能顺利进入或脱开。若夹持不同直径的工件,应按最大直径的工件考虑。③应保证工件的准确定位
为使手指和被夹持工件保持准确的相对位臵,必须根据被抓取工件的形状,选择相应的手指形状。例如圆柱形工件采用带‘V’形面的手指,以便自动定心。
④应具有足够的强度和刚度
手指除受到被夹持工件的反作用力外,还受到机械手在运动过程中所产生的惯性力和振动的影响,要求具有足够的强度和刚度以防止折断或弯曲变形,但应尽量使结构简单紧凑,自重轻。
⑤应考虑被抓取对象的要求
应根据抓取工件的形状、抓取部位和抓取数量的不同,来设计和确定手指的形状。3 腕部的结构 3.1 概述
腕部是连接手部与臂部的部件,起支承手部的作用。设计腕部时要注意以下几点: ① 结构紧凑,重量尽量轻。
② 转动灵活,密封性要好。
③ 注意解决好腕部也手部、臂部的连接,以及各个自由度的位臵检测、管线的布 臵以及润滑、维修、调整等问题 ④ 要适应工作环境的需要。
另外,通往手腕油缸的管道尽量从手臂内部通过,以便手腕转动时管路不扭转和不外露,使外形整齐。
3.2 腕部的结构形式
本机械手采用回转油缸驱动实现腕部回转运动,结构紧凑、体积小,但密封性差,回转角度为±115°。腕部的结构,定片与后盖,回转缸体和前盖均用螺钉和销子进行连接和定位,动片与手部的夹紧油缸缸体用键连接。夹紧缸体也指座固连成一体。当回转油缸的两腔分别通入压力油时,驱动动片连同夹紧油缸缸体和指座一同转动,即为手腕的回转运动。
3.3 手腕驱动力矩的计算
驱动手腕回转时的驱动力矩必须克服手腕起动时所产生的惯性力矩,手腕的转动轴与支承孔处的摩擦阻力矩,动片与缸径、定片、端盖等处密封装臵的摩擦阻力矩以及由 臂部的结构 4.1 概述
臂部是机械手的主要执行部件,其作用是支承手部和腕部,并将被抓取的工件传送到给定位臵和方位上,因而一般机械手的手臂有三个自由度,即手臂的伸缩、左右回转和升降运动。手臂的回转和升降运动是通过立柱来实现的,立柱的横向移动即为手臂的
横向移动。手臂的各种运动通常由驱动机构和各种传动机构来实现,因此,它不仅仅承受被抓取工件的重量,而且承受手部、手腕、和手臂自身的重量。手臂的结构、工作范围、灵活性以及抓重大小(即臂力)和定位精度等都直接影响机械手的工作性能,所以必须根据机械手的抓取重量、运动形式、自由度数、运动速度及其定位精度的要求来设计手臂的结构型式。同时,设计时必须考虑到手臂的受力情况、油缸及导向装臵的布臵、内部管路与手腕的连接形式等因素。因此设计臂部时一般要注意下述要求:
① 刚度要大 为防止臂部在运动过程中产生过大的变形,手臂的截面形状的选择要合理。弓字形截面弯曲刚度一般比圆截面大;空心管的弯曲刚度和扭曲刚度都比实心轴大得多。所以常用钢管作臂杆及导向杆,用工字钢和槽钢作支承板。② 导向性要好 为防止手臂在直线移动中,沿运动轴线发生相对运动,或设臵导向装臵,或设计方形、花键等形式的臂杆。
③ 偏重力矩要小 所谓偏重力矩就是指臂部的重量对其支承回转轴所产生的静力矩。为提高机器人的运动速度,要尽量减少臂部运动部分的重量,以减少偏重力矩和整个手臂对回转轴的转动惯量。
④ 运动要平稳、定位精度要高 由于臂部运动速度越高、重量越大,惯性力引起的定位前的冲击也就越大,运动即不平稳,定位精度也不会高。故应尽量减少小臂部运动部分的重量,使结构紧凑、重量轻,同时要采取一定的缓冲措施。
4.2 手臂直线运动机构
机械手手臂的伸缩、升降及横向移动均属于直线运动,而实现手臂往复直线运动的机构形式比较多,常用的有活塞油(气)缸、活塞缸和齿轮齿条机构、丝杆螺母机构以及活塞缸和连杆机构。
4.2.1 手臂伸缩运动
这里实现直线往复运动是采用液压驱动的活塞油缸。由于活塞油缸的体积小、重量轻,因而在机械手的手臂机构中应用比较多。如图5所示为双导向杆手臂的伸缩结构。手臂和手腕是通过连接板安装在升降油缸的上端,当双作用油缸1的两腔分别通入压力油时,则推动活塞杆2(即手臂)作往复直线运动。导向杆3在导向套4内移动,以防止手臂伸缩时的转动(并兼做手腕回转缸6及手部7的夹紧油缸用的输油管道)。由于手臂的伸缩油缸安装在两导向杆之间,由导向杆承受弯曲作用,活塞杆只受拉压作用,故受力简单,传动平稳,外形整齐美观,结构紧凑。可用于抓重大、行程较长的场合。
4.2.2 导向装臵
液压驱动的机械手手臂在进行伸缩(或升降)运动时,为了防止手臂绕轴线发生转动,以保证手指的正确方向,并使活塞杆不受较大的弯曲力矩的作用,以增加手臂的刚性,在设计手臂的结构时,必须采用适当的导向装臵。它根据手臂的安装形式,具体的结构和抓取重量等因素加以确定,同时在结构设计和布局上应尽量减少运动部件的重量和减少手臂对回转中心的转动惯量。目前采用的导向装臵有单导向杆、双导向杆、四导向杆和其他的导向装臵,本机械手采用的是双导向杆导向机构。
双导向杆配臵在手臂伸缩油缸两侧,并兼做手部和手腕油路的管道。对于伸缩行程大的手臂,为了防止导向杆悬伸部分的弯曲变形,可在导向杆尾部增设辅助支承架,以提高导向杆的刚性。
如图6所示,对于伸缩行程大的手臂,为了防止导向杆悬伸部分的弯曲变形,可在导向杆尾部增设辅助支承架,以提高导向杆的刚性。在导向杆1的尾端用支承架4将两个导向杆连接起来,支承架的两侧安装两个滚动轴承2,当导向杆随同伸缩缸的活塞杆一起移动时,支承架上的滚动轴承就在支承板3的支承面上滚动。
4.2.3 手臂的升降运动
当升降缸上下两腔通压力油时,活塞杠4做上下运动,活塞缸体2固定在旋转轴上。由活塞杆带动套筒3做升降运动。其导向作用靠立柱的平键9实现。
4.5 臂部运动驱动力计算
计算臂部运动驱动力(包括力矩)时,要把臂部所受的全部负荷考虑进去。机械手工作时,臂部所受的负荷主要有惯性力、摩擦力和重力等。
4.5.1 臂水平伸缩运动驱动力的计算
手臂做水平伸缩运动时,首先要克服摩擦阻力,包括油缸与活塞之间的摩擦阻力及导向杆与支承滑套之间的摩擦阻力等,还要克服启动过程中的惯性力。其驱动力Pq可按下式计算:
Pq = Fm + Fg(N)式中 Fm——各支承处的摩擦阻力;
Fg——启动过程中的惯性力,其大小可按下式估算: Fg = Wa(N)g 式中 W ——手臂伸缩部件的总重量(N); 5.1 液压系统简介
机械手的液压传动是以有压力的油液作为传递动力的工作介质。电动机带动油泵输出压力油,是将电动机供给的机械能转换成油液的压力能。压力油经过管道及一些控制调节装臵等进入油缸,推动活塞杆运动,从而使手臂作伸缩、升降等运动,将油液的压力能又转换成机械能。手臂在运动时所能克服的摩擦阻力大小,以及夹持式手部夹紧工件时所需保持的握力大小,均与油液的压力和活塞的有效工作面积有关。手臂做各种运动的速度决定于流入密封油缸中油液容积的多少。这种借助于运动着的压力油的容积变化来传递动力的液压传动称为容积式液压传动,机械手的液压传动系统都属于容积式液压传动。
5.2 液压系统的组成
液压传动系统主要由以下几个部分组成:
① 油泵 它供给液压系统压力油,将电动机输出的机械能转换为油液的压力能,用这压力油驱动整个液压系统工作。
② 液动机 压力油驱动运动部件对外工作部分。手臂做直线运动,液动机就是手臂伸缩油缸。也有回转运动的液动机一般叫作油马达,回转角小于360°的液动机,一般叫作回转油缸(或称摆动油缸)。
③ 控制调节装臵 各种阀类,如单向阀、溢流阀、节流阀、调速阀、减压阀、顺序阀等,各起一定作用,使机械手的手臂、手腕、手指等能够完成所要求的运动。
5.3 机械手液压系统的控制回路
机械手的液压系统,根据机械手自由度的多少,液压系统可繁可简,但是总不外乎 由一些基本控制回路组成。这些基本控制回路具有各种功能,如工作压力的调整、油泵的卸荷、运动的换向、工作速度的调节以及同步运动等。
5.3.1 压力控制回路 ① 调压回路 在采用定量泵的液压系统中,为控制系统的最大工作压力,一般都在油泵的出口附近设臵溢流阀,用它来调节系统压力,并将多余的油液溢流回油箱。② 卸荷回路 在机械手各油缸不工作时,油泵电机又不停止工作的情况下,为减少油泵的功率损耗,节省动力,降低系统的发热,使油泵在低负荷下工作,所以采用卸荷回路。此机械手采用二位二通电磁阀控制溢流阀遥控口卸荷回路。
③ 减压回路 为了是机械手的液压系统局部压力降低或稳定,在要求减压的支路前串联一个减压阀,以获得比系统压力更低的压力。
④平衡与锁紧回路 在机械液压系统中,为防止垂直机构因自重而任意下降,可采用平衡回路将垂直机构的自重给以平衡。
为了使机械手手臂在移动过程中停止在任意位臵上,并防止因外力作用而发生位移,可采用锁紧回路,即将油缸的回油路关闭,使活塞停止运动并锁紧。本机械手采用单向顺序阀做平衡阀实现任意位臵锁紧的回路。
⑤ 油泵出口处接单向阀 在油泵出口处接单向阀。其作用有二:第一是保护油泵。液压系统工作时,油泵向系统供应高压油液,以驱动油缸运动而做功。当一旦电机停止转动,油泵不再向外供油,系统中原有的高压油液具有一定能量,将迫使油泵反方向转动,结果产生噪音,加速油泵的磨损。在油泵出油口处加设单向阀后,隔断系统中高压油液和油泵时间的联系,从而起到保护油缸的作用。第二是防止空气混入系统。在停机时,单向阀把系统能够和油泵隔断,防止系统的油液通过油泵流回油箱,避免空气混入,以保证启动时的平稳性。
5.3.2 速度控制回路
液压机械手各种运动速度的控制,主要是改变进入油缸的流量Q。其控制方法有两类:一类是采用定量泵,即利用调节节流阀的通流截面来改变进入油缸或油马达的流量;另一类是采用变量泵,改变油泵的供油量。本机械手采用定量油泵节流调速回路。
根据各油泵的运动速度要求,可分别采用LI型单向节流阀、LCI型单向节流阀或QI型单向调速阀等进行调节。
节流调速阀的优点是:简单可靠、调速范围较大、价格便宜。其缺点是:有压力和流量损耗,在低速负荷传动时效率低,发热大。采用节流阀进行节流调速时,负荷的变化会引起油缸速度的变化,使速度稳定性差。其原因是负荷变化会引起油缸速度的变化,使速度稳定性差。其原因是负荷变化会引起节流阀进出油口的压差变化,因而使通过节流阀的流量以至油缸的速度变化。
调速阀能够随负荷的变化而自动调整和稳定所通过的流量,使油缸的运动速度不受负荷变化的影响,对速度的平稳性要求高的场合,宜用调速阀实现节流调速。
5.3.3 方向控制回路
在机械手液压系统中,为控制各油缸、马达的运动方向和接通或关闭油路,通常采用二位二通、二位三通、二位四通电磁阀和电液动滑阀,由电控系统发出电信号,控制电磁铁操纵阀芯换向,使油缸及油马达的油路换向,实现直线往复运动和正反向转动。目前在液压系统中使用的电磁阀,按其电源的不同,可分为交流电磁阀(D型)和直流电磁阀(E型)两种。交流电磁阀的使用电压一般为220V(也有380V或36V),直流电磁阀的使用电压一般为24V(或110V)。这里采用交流电磁阀。交流电磁阀起动性能好,换向时间短,接线简单,价廉,但是如吸不上时容易烧坏,可靠性差,换向时有冲击,允许换向频率底,寿命较短。
5.4 机械手的液压传动系统
液压系统图的绘制是设计液压机械手的主要内容之一。液压系统图是各种液压元件为满足机械手动作要求的有机联系图。它通常由一些典型的压力控制、流量控制、方向控制回路加上一些专用回路所组成。
绘制液压系统图的一般顺序是:先确定油缸和油泵,再布臵中间的控制调节回路和相应元件,以及其他辅助装臵,从而组成整个液压系统,并用液压系统图形符号,画出液压原理图。
5.4.1 上料机械手的动作顺序
本液压传动上料机械手主要是从一个地方拿到工件后,横移一定的距离后把工件给立式精锻机进行加工。它的动作顺序是:待料(即起始位臵。手指闭合,待夹料立放)→插定位销→手臂前伸→手指张开→手指夹料→手臂上升→手臂缩回→立柱横移→手腕回转115°→拔定位销→手臂回转115° →插定位销→手臂前伸→手臂中停→手指松开→ 手指闭合→手臂缩回→手臂下降→手腕反转(手腕复位)→拔定位销→手臂反转(机械手臂复位)→立柱回移(回到起始位臵)→待料(一个循环结束)卸荷。
上述动作均由电控系统发信控制相应的电磁换向阀,按程序依次步进动作而实现的。该电控系统的步进控制环节采用步进选线器,其步进动作是在每一步动作完成后,使行程开关的触点闭合或依据每一步动作的预设停留时间,使时间继电器动作而发信,使步进器顺序?跳步?控制电磁阀的电磁铁线圈通断电,使电磁铁按程序动作(见电磁铁动作程序表)实现液压系统的自动控制。结束语
这次论文给了我们一个很好的机会,使我们了解了设计工作的基本流程和设计的方法以及理念。
虽然我描述的只是个简单的工业机器人抓取手臂,但需要完成伸缩、升降、回转、横移等功能,对应分别要对这些机构进行设计和计算,以及对油路及其部件的选择、控制回路和电气控制的设计。通过这些设计,使理论知识与实际相结合,巩固和深化了所学过的专业理论知识。在设计的过程中我不断探索、不断学习和修改。
通过这次设计,大大的提高了我们的自主学习和认真思考的能力,对学术态度的严谨性也有了很高的认识。我相信在以后的学习和工作过程中,一定可以好好的解决问题,提高自己的能力,较快地适应工作和社会激烈的竞争。
参考文献
[1] 邓星钟.机电传动控制[M].华中科技大学出版社,2002 [2] 孙志礼、冷兴聚、魏延刚等.机械设计[M].东北大学出版社,2003 [3] 吴宗泽.机械设计师手册[M].机械工业出版社,2002 [4] 丁继斌.机器人技术基础(第二版).高等教育出版社,2012 [5] 罗洪量.机械原理课程设计指导书[M](第二版).高等教育出版社,1986 [6] 张建民.工业机器人[B][M].北京理工大学出版社,1992
第二篇:工业机器人论文
走进科技论文
0903030409
颜卫勤
工业机器人论文
在科技界,科学家会给每一个科技术语一个明确的定义,但机器人问世已有几十年,机器人的定义仍然仁者见仁,智者见智,没有一个统一的意见。原因之一是机器人还在发展,新的机型,新的功能不断涌现。根本原因主要是因为机器人涉及到了人的概念,成为一个难以回答的哲学问题。就像机器人一词最早诞生于科幻小说之中一样,人们对机器人充满了幻想。也许正是由于机器人定义的模糊,才给了人们充分的想象和创造空间。其实并不是人们不想给机器人一个完整的定义,自机器人诞生之日起人们就不断地尝试着说明到底什么是机器人。但随着机器人技术的飞速发展和信息时代的到来,机器人所涵盖的内容越来越丰富,机器人的定义也不断充实和创新。
在此,我仅根据自己的所学及课本给出的定义概述一下有关机器人的定义。机器人(Robot)是1920年 捷克斯洛伐克作家卡雷尔·恰佩克在他的科幻小说《罗萨姆的机器人万能公司》的剧本中,塑造的一个具有人的外表、特征和功能,愿意为人服务的机器奴仆“Robota”一词衍生出来的。根据这个定义,我们可以这样说:机器人是一个在三维空间中具有多自由度的,并能实现诸多拟人动作和功能的机器;而工业机器人(Industrial Robot)则是在工业生产上应用的机器人。
而美国机器人工业协会(U.S.RIA)提出的工业机器人定义为机器人是“一种用于移动各种材料、零件、工具或专用装置的,通过可编程序动作来执行种种任务的,并具有编程能力的多功能机械手(manipulator)或者通过不同程序的调用来完成各种工作任务的特种装置”。日本机器人协会(JIRA)的定义则是:工业机器人是“一种装备有记忆装置和末端执行器(end effector)的,能够转动并通过自动完成各种移动来代替人类劳动的通用机器”。可见美国机器人协会和日本机器人协会给出了相类似的定义。国际标准化组织(ISO)的定义:“机器人是一种自动的、位置可控的、具有编程能力的多功能机械手,这种机械手具有几个轴,能够借助于可编程序操作来处理各种材料、零件、工具和专用装置,以执行种种任务”。而我国科学家对机器人的定义是:“机器人是一种自动化的机器,所不同的是这种机器具备一些与人或生物相似的智能能力,如感知能力、规划能力、动作能力和协同能力,是一种具有高度灵活性的自动化机器”。在我国,在工业领域内应用的机器人我们称为工业机器人。通常人们对工业机器人的定义是:工业机器人是一种能模拟人的手、臂的部分动作, 按照预定的程序、轨迹及其它要求, 实现抓取、搬运工件或操作工具的自动化装置。
工业机器人的最显著的特点简单概述为可编程、拟人化、通用性、机电一体化。
工业机器人由主体、驱动系统和控制系统三个基本部分组成。主体即机座和执行机构,包括臂部、腕部和手部,有的机器人还有行走机构。大多数工业机器人有3~6个运动自由度,其中腕部通常有1~3个运动自由度;驱动系统包括动力装置和传动机构,用以使执行机构产生相应的动作;控制系统是按照输入的程序对驱动系统和执行机构发出指令信号,并进行控制。工业机器人按臂部的运动形式分为四种。直角坐标型的臂部可沿三个直角坐标移动;圆柱坐标型的臂部可作升降、回转和伸缩动作;球坐标型的臂部能回转、俯仰和伸缩;关节型的臂部有多个转动关节。
工业机器人按执行机构运动的控制机能,又可分点位型和连续轨迹型。点位型只控制执行机构由一点到另一点的准确定位,适用于机床上下料、点焊和一般搬运、装卸等作业;连续轨迹型可控制执行机构按给定轨迹运动,适用于连续焊接和涂装等作业。工业机器人按程序输入方式区分有编程输入型和示教输入型两类。编程输入型是将计算机上已编好的作业程序文件,通过RS232串口或者以太网等通信方式传送到机器人控制柜。
示教输入型的示教方法有两种:一种是由操作者用手动控制器(示教操纵盒),将指令信号传给驱动系统,使执行机构按要求的动作顺序和运动轨迹操演一遍;另一种是由操作者直接领动执行机构,按要求的动作顺序和运动轨迹操演一遍。在示教过程的同时,工作程序的信息即自动存入程序存储器中在机器人自动工作时,控制系统从程序存储器中检出相应信息,将指令信号传给驱动机构,使执行机构再现示教的各种动作。示教输入程序的工业机器人称为示教再现型工业机器人。
具有触觉、力觉或简单的视觉的工业机器人,能在较为复杂的环境下工作;如具有识别功能或更进一步增加自适应、自学习功能,即成为智能型工业机器人。它能按照人给的“宏指令”自选或自编程序去适应环境,并自动完成更为复杂的工作。
清洁机器人的涵盖范围广泛,依照IFR World Robotic的分类,可分为产业型与家用型两大类,在产业型方面例如地板清洁(吸尘与洗地)、风管空调系统清洁、除草、大楼窗户清洗、水箱清洁等。目前为止应用最成功的仍属地板清洁型机器人,包括机场、大卖场、工厂、饭店大厅等大范围面积的场所,原因在于地板属于2-D几何平面,技术相对较为单纯。而家用型的地板清洁机器人(吸尘器)在近年来则快速窜起,成为市场主流产品,根据IFR World Robotics 2005的统计数据显示,服务型机器人中,清洁机器人仍是主要应用。其中家用清洁机器人更占整体服务型机器人的95%以上,其中2005-2008年更可高达447万台。
家用型清洁机器人受到热烈欢迎的主要原因在于已开发与开发中国家多以双薪家庭为主,并逐渐走向少子化与高龄化的趋势,在家庭人口结构变少的情况下,清洁工作的替代便成为新兴市场发展的重要需求,遂使的清洁机器人成为各国争相投入的技术研发重点。
随着自动化技术与人工智能的快速发展,机器人在人类的环境中扮演越来越重要的脚色。传统上机器人的应用层面多集中于工业化的生产系统与制造流程上,专门应付长时间作业、大量重复性动作、系统复杂且需要精密控制、高危险性等工作上。而近年来的演进则渐渐朝向服务型机器人的方向快速蓬勃发展。那么在我们身边有什么样的机器人呢? 生活中常见的工业机器人有如下几种:
点焊机器人,这主要是针对汽车生产线,提高生产效率,提高汽车焊接的质量,降低工人的劳动强度的一种机器人。它的特点是通过机器人对两个钢板进行点焊的时候,需要承载一个很大的焊钳,一般在几十公斤以上,那么它的速度要求在每秒钟一米五到两米这样的高速运动,所以它一般来说有五到六个自由度,负载三十到一百二十公斤,工作的空间很大,大概有两米,这样一个球形的工作空间,运动速度也很高,那么自由度的概念,就是说,是相对独立运动的部件的个数,就相当于我们人体,腰是一个回转的自由度,我们大臂可以抬起来,小臂可以弯曲,那么这就三个自由度,同时腕部还有一个调整姿态来使用的三个自由度,所以一般的机器人有六个自由度,就能把空间的三个位置,三个姿态,机器人完全实现,当然也有小于六个自由度的,也有多于六个自由度的机器人,只是在不同的需要场合来配置。
弧焊机器人也是工业机器人中一个最重要的方面,像我们汽车的后桥,进行焊接的时候,它连续焊接,所以它的特点是连续轨迹控制,所以它要求的轨迹精度要求非常高,一般来说也是五到六个自由度,由于它焊枪比较小,所以在五到十公斤就可以了,这个方面是在国际和国内应用非常大的一类机器人,在另一方面像搬运和铆接,这些工作场合下,像搬运,主要是要求机器人有很高的速度,承载能力很多、很强,像日本的大库机器人,它可以承载三百公斤,抓取、来进行搬运和码垛。
医疗机器人,是近五年来发展比较迅速的一个新的应用领域,那么这个也可以看到几个方面,包括人是一个非常珍贵的生物,那么包括人的眼球、神经、血管都很精细,那么如果人手术的时候,医生来手术,一个是疲劳,另一个人手操作的精度还是有限的,那么这是在德国,一些大学里面,面向人的脊椎,如腰间盘突出这种病,进行识别以后,能够自动地用机器人来辅助进行定位,进行操作和手术。还有一类叫康复机器人,康复机器人像比方说,现在发病量比较大的是偏瘫和半身不遂这种病患,当他恢复治疗完以后,需要对他的肢体进行锻炼和恢复,那么如果医生是有限的,不可能一个医生,天天给一个病人进行按摩或牵引这样的工作,那么家庭的人员都上班,没有时间照顾,那么用一个机器人,可以对他的手进行牵动,天天强迫他进行锻炼,使人的肌肉的恢复达到最好,更为精细的工作像很多大学和一些医院在开发像人的脑手术,这个是很危险的事情,但是,已经得到了很好的例证,包括北航开发出了对人脑的定位和钻孔这样的工作,还包括像美国已经有一千多例机器人对人眼球进行手术,这样的机器人,还包括通过遥控操作的办法,实现对人的胃肠这种手术,大家在电视里边看到,一个机械手,大概有手指这样粗细的一个机械手,通过插入腹脏以后,人在屏幕上操作这个机器手,同时对它用激光的方法对病灶进行激光的治疗,这样的话,人就不用很大幅度地破坏人的身体,这实际对人的一种解放,是非常好一种机器人,医疗机器人它也很复杂,一方面它完全自动去完成各种工作,是有困难的,一般来说都是人来参与,这是美国开发的一个林白手术这样一个例子,人通过在屏幕上,通过一个遥控操作手来控制另一个机械手,实现通过对人的腹腔进行手术,前几年我们国家展览会上,美国已经成功的实现了对人的心脏瓣膜的手术和搭桥手术,这已经在机器人领域中,引起了很大的轰动,还包括,AESOP的这种外科手术机器人,它实际上通过一些仪器能够对人的一些病变进行检查,通过一个机械手就能够实现对人的某些部位进行手术,还包括遥操作机械手,以及多个医生可以在机器人共同参与下进行手术,包括机器人给大夫医生拿钳子、镊子或刀子来代替护士的工作,同时把照明能够自动的给医生的动作联系起来,医生的手到哪儿,照明就去哪儿,这样非常好的,一个医生的助手。
由此可见,工业机器人是人类的得力助手,随着社会的发展,大量的工业机器人把人们从繁重的体力和危险的环境中解放出来,使人们有更好的岗位去工作,去创造更好的精神财富和文化财富,机器人来做这些危险环境的工作,展望21世纪工业机器人将是一个与20世纪计算机的普及一样,会深入地应用到各个领域,有人说在21世纪的前20年是机器人从制造业走向非制造业的发展一个重要时期,也是智能机器人发展的一个关键时期,目前国际上很多国家,也对机器人对人类社会的影响的估计提出了新的认识,同时,我们也可以看到机器人技术,涉及到多个学科,机械、电工、自动控制、计算机测量、人工智能、传感技术等等,它是一个国家高技术实力的一个重要标准。所以,作为当代大学生,作为一名机械专业的学生,我们的使命任重而道远。
第三篇:工业机器人--论文
材料:工业机器人论文
摘要:工业机器人是面向工业领域的多关节机械手或多自由度的机器人。工业机器人是自动执行工作的机器装置,是靠自身动力和控制能力来实现各种功能的一种机器。它可以接受人类指挥,也可以按照预先编排的程序运行,现代的工业机器人还可以根据人工智能技术制定的原则纲领行动。机器人技术是具有前瞻性、战略性的高技术领域。国际电气电子工程师协会IEEE的科学家在对未来科技发展方向进行预测中提出了4个重点发展方向,机器人技术就是其中之一。
关键词:工业机器人;构造;中国工业机器人;发展前景;
由来
1920年捷克作家卡雷尔·查培克在其剧本《罗萨姆的万能机器人》中最早使用机器人一词,剧中机器人“Robot”这个词的本意是苦力,即剧作家笔下的一个具有人的外表,特征和功能的机器,是一种人造的劳力。它是最早的工业机器人设想。
20世纪40年代中后期,机器人的研究与发明得到了更多人的关心与关注。50年代以后,美国橡树岭国家实验室开始研究能搬运核原料的遥控操纵机械手。
所示,这是一种主从型控制系统,主机械手的运动。系统中加入力反馈,可使操作者获知施加力的大小,主从机械手之间有防护墙隔开,操作者可通过观察窗或闭路电视对从机械手操作机进行有效的监视,主从机械手系统的出现为机器人的产生为近代机器人的设计与制造作了铺垫。
1954年美国戴沃尔最早提出了工业机器人的概念,并申请了专利。该专利的要点是借助伺服技术控制机器人的关节,利用人手对机器人进行动作示教,机器人能实现动作的记录和再现。这就是所谓的示教再现机器人。现有的机器人差不多都采用这种控制方式。1959年第一台工业机器人在美国诞生,开创了机器人发展的新纪元
特点
戴沃尔提出的工业机器人有以下特点:将数控机床的伺服轴与遥控操纵器的连杆机构联接在一起,预先设定的机械手动作经编程输入后,系统就可以离开人的辅助而独立运行。这种机器人还可以接受示教而完成各种简单的重复动作,示教过程中,机械手可依次通过工作任务的各个位置,这些位置序列全部记录在存储器内,任务的执行过程中,机器人的各个关节在伺服驱动下依次再现上述位置,故这种机器人的主要技术功能被称为“可编程”和“示教再现”。
1962年美国推出的一些工业机器人的控制方式与数控机床大致相似,但外形主要由类似人的手和臂组成。后来,出现了具有视觉传感器的、能识别与定位的工业机器人系统。当今工业机器人技术正逐渐向着具有行走能力、具有多种感知能力、具有较强的对作业环境的自适应能力的方向发展。目前,对全球机器人技术的发展最有影响的国家是美国和日本。美国在工业机器人技术的综合研究水平上仍处于领先地位,而日本生产的工业机器人在数量、种类方面则居世界首位。
构造与分类
工业机器人由主体、驱动系统和控制系统三个基本部分组成。主体即机座和执行机构,包括臂部、腕部和手部,有的机器人还有行走机构。大多数工业机器人有3~6个运动自由度,其中腕部通常有1~3个运动自由度;驱动系统包括动力装置和传动机构,用以使执行机构产生相应的动作;控制系统是按照输入的程序对驱动系统和执行机构发出指令信号,并进行控制。
工业机器人按臂部的运动形式分为四种。直角坐标型的臂部可沿三个直角坐标移动;圆
柱坐标型的臂部可作升降、回转和伸缩动作;球坐标型的臂部能回转、俯仰和伸缩;关节型的臂部有多个转动关节。
工业机器人按执行机构运动的控制机能,又可分点位型和连续轨迹型。点位型只控制执行机构由一点到另一点的准确定位,适用于机床上下料、点焊和一般搬运、装卸等作业;连续轨迹型可控制执行机构按给定轨迹运动,适用于连续焊接和涂装等作业。
工业机器人按程序输入方式区分有编程输入型和示教输入型两类。编程输入型是将计算机上已编好的作业程序文件,通过RS232串口或者以太网等通信方式传送到机器人控制柜。
示教输入型的示教方法有两种:一种是由操作者用手动控制器(示教操纵盒),将指令信号传给驱动系统,使执行机构按要求的动作顺序和运动轨迹操演一遍;另一种是由操作者直接领动执行机构,按要求的动作顺序和运动轨迹操演一遍。在示教过程的同时,工作程序的信息即自动存入程序存储器中在机器人自动工作时,控制系统从程序存储器中检出相应信息,将指令信号传给驱动机构,使执行机构再现示教的各种动作。示教输入程序的工业机器人称为示教再现型工业机器人。
具有触觉、力觉或简单的视觉的工业机器人,能在较为复杂的环境下工作;如具有识别功能或更进一步增加自适应、自学习功能,即成为智能型工业机器人。它能按照人给的“宏指令”自选或自编程序去适应环境,并自动完成更为复杂的工作。
应用
所谓工业机器人,就是具有简单记忆和可变控制程序的自动机械。它是在机械手的基础上发展起来的,国外称为industrial robot。工业机器人的出现将人类从繁重单一的劳动中解放出来,而且它还能够从事一些不适合人类甚至超越人类的劳动,实现生产的自动化,避免工伤事故和提高生产效率。,例如在冲压、压力铸造、热处理、焊接、涂装、塑料制品成形、机械加工和简单装配等工序上,以及在原子能工业等部门中,完成对人体有害物料的搬运或工艺操作。随着世界生产力的发展,必然促进相应科学技术的发展。工业机器人能够极大地提高生产效率,已经广泛地进入人们的生活生产领域。
20世纪50年代末,美国在机械手和操作机的基础上,采用伺服机构和自动控制等技术,研制出有通用性的独立的工业用自动操作装置,并将其称为工业机器人;60年代初,美国研制成功两种工业机器人,并很快地在工业生产中得到应用;1969年,美国通用汽车公司用21台工业机器人组成了焊接轿车车身的自动生产线。此后,各工业发达国家都很重视研制和应用工业机器人。
由于工业机器人具有一定的通用性和适应性,能适应多品种中、小批量的生产,70年代起,常与数字控制机床结合在一起,成为柔性制造单元或柔性制造系统的组成部分。中国的工业机器人
我国工业机器人起步于70年代初期,经过20多年的发展,大致经历了3个阶段:70年代的萌芽期,80年代的开发期和90年代的适用化期。
70年代是世界科技发展的一个里程碑:人类登上了月球,实现了金星、火星的软着陆。我国也发射了人造卫星。世界上工业机器人应用掀起一个高潮,尤其在日本发展更为迅猛,它补充了日益短缺的劳动力。在这种背景下,我国于1972年开始研制自己的工业机器人。
进入80年代后,在高技术浪潮的冲击下,随着改革开放的不断深入,我国机器人技术的开发与研究得到了政府的重视与支持。“七五”期间,国家投入资金,对工业机器人及其零部件进行攻关,完成了示教再现式工业机器人成套技术的开发,研制出了喷涂、点焊、弧焊和搬运机器人。1986年国家高技术研究发展计划(863计划)开始实施,智能机器人主题跟踪世界机器人技术的前沿,经过几年的研究,取得了一大批科研成果,成功地研制出了一
批特种机器人。
从90年代初期起,我国的国民经济进入实现两个根本转变时期,掀起了新一轮的经济体制改革和技术进步热潮,我国的工业机器人又在实践中迈进一大步,先后研制出了点焊、弧焊、装配、喷漆、切割、搬运、包装码垛等各种用途的工业机器人,并实施了一批机器人应用工程,形成了一批机器人产业化基地,为我国机器人产业的腾飞奠定了基础。
虽然中国的工业机器人产业在不断的进步中,但和国际同行相比,差距依旧明显。从市场占有率来说,更无法相提并论。工业机器人很多核心技术,目前我们尚未掌握,这是影响我国机器人产业发展的一个重要瓶颈。
工业机器人在世界其他主要国家的发展:
美国是工业机器人的诞生地,基础雄厚,技术先进。现今美国有着一批具有国际影响力的工业机器人供应商,像Adept Technologe、American Robot、Emersom Industrial Automation 等。
德国工业机器人的数量占世界第三,仅次于 日本和美国,其智能机器人的研究和应用在世界上处于领先地位。目前在普及第一代工业机器人的基础上,第二代工业机器人经推广应用成为主流安装机型,而第三代智能机器人已占有一定比重并成为发展的方向。世界上的机器人供应商分为日系和欧系。瑞典的ABB公司是世界上最大机器人制造公司之一。1974年研发了世界上第一台全电控式工业机器人IRB6,主要应用于工件的取放和物料搬运。1975年生产出第一台焊接机器人。到1980年兼并Trallfa喷漆机器人公司后
工业机器人的发展前景
在发达国家中,工业机器人自动化生产线成套设备已成为自动化装备的主流及未来的发展方向。国外汽车行业、电子电器行业、工程机械等行业已经大量使用工业机器人自动化生产线,以保证产品质量,提高生产效率,同时避免了大量的工伤事故。全球诸多国家近半个世纪的工业机器人的使用实践表明,工业机器人的普及是实现自动化生产,提高社会生产效率,推动企业和社会生产力发展的有效手段。
机器人技术是具有前瞻性、战略性的高技术领域。国际电气电子工程师协会IEEE的科学家在对未来科技发展方向进行预测中提出了4个重点发展方向,机器人技术就是其中之一。1990年10月,国际机器人工业人士在丹麦首都哥本哈根召开了一次工业机器人国际标准大会,并在这次大会上通过了一个文件,把工业机器人分为四类:⑴顺序型。这类机器人拥有规定的程序动作控制系统;⑵沿轨迹作业型。这类机器人执行某种移动作业,如焊接。喷漆等;⑶远距作业型。比如在月球上自动工作的机器人;⑷智能型。这类机器人具有感知、适应及思维和人机通信机能。
日本工业机器人产业早在上世纪90年代就已经普及了第一和第二类工业机器人,并达到了其工业机器人发展史的鼎盛时期。而今已在第发展三、四类工业机器人的路上取得了举世瞩目的成就。日本下一代机器人发展重点有:低成本技术、高速化技术、小型和轻量化技术、提高可靠性技术、计算机控制技术、网络化技术、高精度化技术、视觉和触觉等传感器技术等。
根据日本政府2007年指定的一份计划,日本2050年工业机器人产业规模将达到1.4兆日元,拥有百万工业机器人。按照一个工业机器人等价于10个劳动力的标准,百万工业机器人相当于千万劳动力,是目前日本全部劳动人口的15%。
我国工业机器人起步于70年代初,其发展过程大致可分为三个阶段:70年代的萌芽期;80年代的开发期;90年代的实用化期。而今经过20多年的发展已经初具规模。目前我国已生产出部分机器人关键元器件,开发出弧焊、点焊、码垛、装配、搬运、注塑、冲压、喷漆等工业机器人。一批国产工业机器人已服务于国内诸多企业的生产线上;一批机器人技术的研究人才也涌现出来。一些相关科研机构和企业已掌握了工业机器人操作机的优化设计制
造技术;工业机器人控制、驱动系统的硬件设计技术;机器人软件的设计和编程技术;运动学和轨迹规划技术;弧焊、点焊及大型机器人自动生产线与周边配套设备的开发和制备技术等。某些关键技术已达到或接近世界水平。
一个国家要引入高技术并将其转移为产业技术(产业化),必须具备5个要素即5M:Machine/Materials/Manpower/Management/Market。和有着“机器人王国”之称的日本相比,我国有着截然不同的基本国情,那就是人口多,劳动力过剩。刺激日本发展工业机器人的根本动力就在于要解决劳动力严重短缺的问题。所以,我国工业机器人起步晚发展缓。但是正如前所述,广泛使用机器人是实现工业自动化,提高社会生产效率的一种十分重要的途径。我国正在努力发展工业机器人产业,引进国外技术和设备,培养人才,打开市场。日本工业机器人产业的辉煌得益于本国政府的鼓励政策,我国在十一五纲要中也体现出了对发展工业机器人的大力支持。
总结
1954年美国戴沃尔最早提出了工业机器人的概念,并申请了专利。1959年第一台工业机器人在美国诞生,开创了机器人发展的新纪元。
第四篇:机器人手臂教程英文版
Degrees of Freedom Robot Workspace Mobile Manipulators Force Calculations Forward Kinematics Inverse Kinematics Motion Planning Velocity
Sensing
End Effector Design
About this Robot Arm Tutorial
The robot arm is probably the most mathematically complex robot you could ever build.As such, this tutorial can't tell you everything you need to know.Instead, I will cut to the chase and talk about the bare minimum you need to know to build an effective robot arm.Enjoy!To get you started, here is a video of a robot arm assignment I had when I took Robotic Manipulation back in college.My group programmed it to type the current time into the keyboard...(lesson learned, don't crash robot arms into your keyboard at full speed while testing in front of your professor)You might be also interested in a robot arm I built that can shuffle, cut, and deal playing cards.Degrees of Freedom(DOF)
The degrees of freedom, or DOF, is a very important term to understand.Each degree of freedom is a joint on the arm, a place where it can bend or rotate or translate.You can typically identify the number of degrees of freedom by the number of actuators on the robot arm.Now this is very importantL1^2x * L2 * s2)/(x^2 + y^2))where c2 =(x^2 + y^2L2^2)/(2 * L1 * L2);and s2 = sqrt(1leaving the end effector to possibly swing wildly between those points.In the image below the end effector of the robot arm is moving from the blue point to the red point.In the top example, the end effector travels a straight line.This is the only possible motion this arm can perform to travel a straight line.In the bottom example, the arm is told to get to the red point as fast as possible.Given many different trajectories, the arm goes the method that allows the joints to rotate the fastest.Which method is better? There are many deciding factors.Usually you want straight lines when the object the arm moves is really heavy, as it requires the momentum change for movement(momentum = mass * velocity).But for maximum speed(perhaps the arm isn't carrying anything, or just light objects)you would want maximum joint speeds.Now suppose you want your robot arm to operate at a certain rotational velocity, how much torque would a joint need? First, lets go back to our FBD:
Now lets suppose you want joint J0 to rotate 180 degrees in under 2 seconds, what torque does the J0 motor need? Well, J0 is not affected by gravity, so all we need to consider is momentum and inertia.Putting this in equation form we get this: torque = moment_of_inertia * angular_acceleration breaking that equation into sub components we get: torque =(mass * distance^2)*(change_in_angular_velocity / change_in_time)and change_in_angular_velocity =(angular_velocity1)-(angular_velocity0)
angular_velocity = change_in_angle / change_in_time
Now assuming at start time 0 that angular_velocity0 is zero, we get torque =(mass * distance^2)*(angular_velocity / change_in_time)where distance is defined as the distance from the rotation axis to the center of mass of the arm: center of mass of the arm = distance = 1/2 *(arm_length)(use arm mass)but you also need to account for the object your arm holds: center of mass of the object = distance = arm_length(use object mass)So then calculate torque for both the arm and then again for the object, then add the two torques together for the total: torque(of_object)+ torque(of_arm)= torque(for_motor)
And of course, if J0 was additionally affected by gravity, add the torque required to lift the arm to the torque required to reach the velocity you need.To avoid doing this by hand, just use the robot arm calculator.But it gets harder...the above equation is for rotational motion and not for straight line motions.Look up something called a Jacobian if you enjoy mathematical pain =P Another Video!
In order to better understand robot arm dynamics, we had a robot arm bowling competition using the same DENSO 6DOF robot arms as in the clocks video.Each team programs an arm to do two tasks: o o Try to place all three of its pegs in the opponents' goal Block opponent pegs from going in your own goal Enjoy!(notice the different arm trajectories)Arm Sagging
Arm sagging is a common affliction of badly designed robot arms.This is when an arm is too long and heavy, bending when outwardly stretched.When designing your arm, make sure the arm is reinforced and lightweight.Do a finite element analysis to determine bending deflection/stress such as I did on my ERP robot: Keep the heaviest components, such as motors, as close to the robot arm base as possible.It might be a good idea for the middle arm joint to be chain/belt driven by a motor located at the base(to keep the heavy motor on the base and off the arm).The sagging problem is even worse when the arm wobbles between stop-start motions.The solve this, implement a PID controller so as to slow the arm down before it makes a full stop.Sensing
Most robot arms only have internal sensors, such asencoders.But for good reasons you may want to add additional sensors, such as video, touch, haptic, etc.A robot arm without video sensing is like an artist painting with his eyes closed.Using basic visual feedback algorithms, a robot arm could go from point to point on its own without a list of preprogrammed positions.Giving the arm a red ball, it could actually reach for it(visual tracking and servoing).If the arm can locate a position in X-Y space of an image, it could then direct the end effector to go to that same X-Y location(by using inverse kinematics).If you are interested in learning more about the vision aspect of visual servoing, please read the Computer Vision Tutorials for more information.Haptic sensing is a little different in that there is a human in the loop.The human controls the robot arm movements remotely.This could be done by wearing a special glove, or by operating a miniature model with position sensors.Robotic arms for amputees are doing a form of haptic sensing.Also to note, some robot arms have feed back sensors(such as touch)that gets directed back to the human(vibrating the glove, locking model joints, etc.).Tactile sensing(sensing by touch)usually involves force feedback sensors and current sensors.These sensors detect collisions by detecting unexpected force/current spikes, meaning a collision has occurred.A robot end effector can detect a successful grasp, and not grasp too tight or too lightly, just by measuring force.Another method would be to use current limitersperhaps even identify the object by its weight.Try this.Close your eyes, and put both of your hands in your lap.Now keeping your eyes closed, move your hand slowly to reach for your computer mouse.Do it!!You will see why soon...Now what will happen is that your hand will partially miss, but at least one of your fingers will touch the mouse.After that finger touches, your hand will suddenly re-adjust its position because it now knows exactly where that mouse is.This is the benefit of tactile sensing-no precision encoders required for perfect contact!
End Effector Design
In the future I will write a separate tutorial on how to design robot grippers, as it will require many more pages of material.In the meantime, you might be interested in reading the tutorial for calculating friction and force for robot end effectors.I also went in to some detail describing my robot arm card dealing gripper.Anyway, I hope you have enjoyed this robot arm tutorial!
第五篇:工业机器人运动控制毕业论文
ADAMS环境下工业robot运动控制
和联合仿真
年 级: 2005级 学 号: 20051035 姓 名: *****
专 业: 机械设计制造及其自动化 指导老师: @@@@@
2009 年 6 月
西南交通大学本科毕业设计(论文)第I页
西南交通大学本科毕业设计(论文)第II页
摘 要
虚拟样机技术就是在建造第一台物理样机之前,设计师利用计算机技术建立机械系统的数字化模型,进行仿真分析并以图形方式显示该系统在真实工程条件下的各种特性,从而修改并得到最优设计方案的技术。
ADAMS软件是目前国际上应用最为广泛的虚拟样机分析软件,用户可以运用该软件非常方便地对虚拟机械系统进行静力学、运动学和动力学分析。但针对复杂的robot机械系统,要想准确的控制其运动,仅依靠ADAMS软件自身也很难做到;MATLAB软是Mathworks公司开发的一种集计算、图形可视化和编辑功能于一体的优秀数学应用软件,具有强大的计算能力,能够建立复杂的控制模型准确控制复杂robot系统的运动;OpenGL(开放式图形库全称)是SGI公司开发的底层三维图形API,目前在图形开发领域已成为工业标准。使用OpenGL可以创建视觉质量接近射线跟踪程序的精致漂亮的3D图形。Visual C++ 6.0已经成为集编辑、编译。运行、调试为一体的功能强大的集成编程环境,在Windows编程中占有重要地位。OpenGL和Visual C++ 6.0有紧密接口,利用二者可以开发出优秀的视镜仿真系统。ADAMS、MATLAB和Visual C++ 6.0由于定位不同,都有各自的优势和缺点,但是三者之间又可以通过接口联合控制或者混合编程。本文分别利用ADAMS对三自由度robot的运动学和轨迹优化方案进行研究,利用Visual C++ 6.0、OpenGL和从MATLAB里导出的控制模型的数据对三自由度robot进行了视景仿真的研究。论文首先通过建立坐标系和矩阵变换,对刚体的空间表示进行了阐述,然后采用通用的D-H法则,将robot关节角度参数化,推导出其正运动学方程和逆运动关节角,并计算出robot手部的初始坐标。其次采用ADAMS软件,详细介绍了robot三维建模过程,包括整体框架构建,单个构件绘图和布尔运算等,并对robot关节点进行了参数化设计。最后从robot轨迹规划的基本原理和方法出发,比较分析了关节空间轨迹规划和直角坐标空间轨迹规划的差别,并采用三次多项式和五次多项式对robot进行了轨迹规划,利用ADAMS软件中内嵌的Step函数对运动轨迹进行了仿真分析。然后在Windows XP Professional的系统环境下,以Visuall C++6.0为开发工具,建立了三自由度机械手视景仿真系统模型,实现了仿真系统对MATLAB控制模型导出数据的读取和利用。
关键词:运动学 轨迹规划 ADAMS虚拟样机技术 视景仿真
纹理映射
西南交通大学本科毕业设计(论文)第III页
Abstract
Virtual prototyping technology in the construction of the first physical prototype, designers use computer technology to build digital models of mechanical systems, simulation analysis and graphically display the various characteristics of the system in real engineering conditions to modify and get the most excellent design technology.ADAMS software is currently the most widely used international virtual prototype analysis software, users can use the software is very easy to statics, kinematics and dynamics of the virtual mechanical systems.However, the complexity of the robot mechanical systems, in order to accurately control its movements, and only rely on ADAMS software is also very difficult to achieve;of MATLAB soft Mathworks company has developed a set of computing, graphical visualization and editing functions in one of the best mathematical applications, computing power, able to build complex control model to accurately control the movement of complex robot systems;OpenGL(Open Graphics Library Name), SGI, the development of the underlying 3D graphics API, currently in the field of graphical development has become the industrial criteria.Use OpenGL to create exquisite and beautiful 3D graphics, visual quality close to the ray-tracing program.Visual C + + 6.0 has become a set of editor, compiler.Run, debug, as one of the features a powerful integrated programming environment, plays an important role in Windows programming.OpenGL and Visual C + + 6.0 interface, using the two can develop excellent endoscopic simulation system.ADAMS, MATLAB and Visual C + + 6.0 due to different positioning has its own advantages and disadvantages, but among the joint interface control, or mixed programming.In this paper, using the ADAMS program of three degrees of freedom of the robot kinematics and trajectory optimization using the Visual C + + 6.0, OpenGL and data export control from the MATLAB model the three degrees of freedom robot visual simulation.Firstly, through the establishment of the coordinate system and matrix transform space of the rigid body are described, and then use the DH rule, the robot joint angle parameters, deduced are kinematic equations and inverse kinematics, joint angles, and calculate the robot the initial coordinates of the hand.ADAMS software, followed by the detailed three-dimensional modeling of robot process, including the overall framework to build a single component mapping and Boolean operations, and the robot joint point of parametric design.Finally, the robot trajectory planning principles and methods, comparative analysis of the difference of the trajectory planning of the joint space and Cartesian coordinate space trajectory planning, and third order polynomial and quintic polynomial on robot trajectory planning, the use of the ADAMS software embedded in Step function of the trajectory of the simulation analysis.Then, in Windows XP Professional system environment, in to Visuall C + + 6.0 development tools, the establishment of a three degree of freedom robotic visual simulation system model, read and use the simulation system model to export data to MATLAB control.Key words: kinematics, trajectory planning ADAMS virtual prototyping technology, visual simulation, texture mapping
西南交通大学本科毕业设计(论文)第IV页
目 录
第一章 绪论............................................................1 1.1工业robot的发展现状............................................1 1.2 虚拟样机技术简介...............................................2 1.2.1 虚拟样机的定义和特点......................................2 1.2.2 研究现状和发展趋势........................................2 1.4 本文要研究的主要内容...........................................4 第二章 robot运动学....................................................5 2.1 空间点和坐标系的表示...........................................5 2.1.1 空间点的向量表示..........................................5 2.1.2坐标系在固定参考坐标系中的表示............................6 2.2 坐标系的变换..................................................6 2.2.1 齐次变换..................................................6 2.2.2 坐标系相对于旋转坐标系的变换.............................10 西南交通大学本科毕业设计(论文)第V页
2.2.3 变换矩阵的逆.............................................10 2.3 robot的正逆运动学.............................................11 2.3.1正运动学的D-H表示法.....................................12 2.3.2逆运动学方程的求解.......................................15 2.4 微分运动......................................................16 第三章 基于ADAMS的robot的虚拟样机分析...............................18 3.1 ADAMS概述.....................................................18 3.2 ADAMS中robot模型的建立.......................................18 3.2.1 设置建模环境.............................................19 3.2.2robot实体建模............................................19 3.2.3 robot模型的设置.........................................20 3.3 轨迹规划仿真分析..............................................21 3.3.1 轨迹规划方法的理论分析..................................21 3.3.2 轨迹规划仿真分析........................................27 第四章 基于模型的视景仿真系统的设计与实现.............................32 4.1 OpenGL概述....................................................33 4.1.1 OpenGL工作方式.........................................33 4.1.2 OpenGL绘制过程.........................................34 4.2 robot三维可视化框架建立......................................35 4.2.1 利用MFC建立单文档应用程序框架..........................35 4.2.2 设置OpenGL绘图环境.....................................37 4.3 机械手三维模型的建立.........................................40 4.3.1 导入机械手模型..........................................40 4.3.2 在OpenGL中建立机械手的模型.............................41 4.4 建立仿真场景.................................................44 5.4.1 纹理贴图的实现..........................................45 4.4.2 设置光照................................................48 4.5 基于模型的视景仿真的实现.....................................51 4.5.1 数据的读取..............................................52 西南交通大学本科毕业设计(论文)第VI页
4.5.2 利用读取的数据控制机械手的运动..........................55 4.5.3 实现观察视角的交互式键盘控制............................60 结论..................................................................63 致谢..................................................................65 附录..................................................................66 参考文献..............................................................73 实习报告..............................................................74
西南交通大学本科毕业设计(论文)第1页
第一章 绪论
1.1工业robot的发展现状
1961年,美国的Consolided Control Corp和AMF公司联合制造了第一台实用的示教再现型工业robot,迄今为止,世界上对工业robot的研究已经经历了四十余年的历程,日本、美国、法国、德国的robot产业已日趋成熟和完善。工业robot由操作机(机械本体)、控制器、伺服驱动系统和检测传感装置构成,是一种仿人操作、自动控制、可重复编程、能在三维空间完成各种作业的机电一体化自动化生产设备。特别适合于多品种、变批量的柔性生产。它对稳定、提高产品质量,提
【1】
高生产效率改善劳动条件和产品的快速更新换代起着十分重要的作用。
采用工业robot,不仅可提高产品的质量与产量,而且对保障人身安全,改善劳动环境,减轻劳动强度,提高劳动生产率,节约原材料消耗以及降低生产成本,有着十分重要的意义。和计算机、网络技术一样,工业robot的广泛应用正在日益改变着人类的生产和生活方式。在制造业中,尤其是在汽车产业中,工业robot得到了广泛的应用。如在毛坯制造(冲压、压铸、锻造等)、机械加工、焊接、热处理、表面涂覆、上下料、装配、检测及仓库堆垛等作业中,robot都已逐步取代了人工作业。如,2004年德国汽车制造业中每1万名工人中拥有工业robot的数量为1140台。【2】在国外,工业robot技术日趋成熟,已经成为一种标准设备被工业界广泛应用。从而,相继形成了一批具有影响力的、著名的工业robot公司,它们包括:瑞典的ABB Robotics,日本的FANUC、Yaskawa,德国的KUKA Roboter,美国的Adept Technology、American Robot、意大利COMAU,英国的AutoTech Robotics公司,这些公司已经成为其所在地区的支柱性产业。
在我国,工业robot的真正使用到现在已经接近20多年了,已经基本实现了试验、引进到自主开发的转变,促进了我国制造业、勘探业等行业的发展。2004年全年国产工业robot数量(主要指在国内生产和组装的)突破1400台,产值突破8亿元人民币。进口robot数量超过9000台,进口额达到2.6亿美元。国内各个工业robot厂家都呈现出产销两旺的局面。截至2004年底,我国工业robot市场已经突破30亿元人民币。现阶段,我国工业robot正逐步发展成为一种有影响力的【3】产业。
西南交通大学本科毕业设计(论文)第2页
1.2 虚拟样机技术简介
1.2.1 虚拟样机的定义和特点
虚拟样机技术就是在建造第一台物理样机之前,设计师利用计算机技术建立机械系统的数字化模型,进行仿真分析并以图形方式显示该系统在真实工程条件下的各种特性,从而修改并得到最优设计方案的技术。该技术以机械系统运动学、动力学和控制理论为核心,加上成熟的三维计算机图形技术和基于图形的用户界面技术,将分散的零部件设计和分析技术集成在一起,提供一个全新研发机械产品的设计方法。它是一种计算机模型,它能够反映实际产品的特性,包括外观、空间关系以及运动学和动力学的特性。借助于这项技术,设计师可以在计算机上建立机械系统的模型,伴之以三维可视化处理,模拟在真实环境下系统的运动和动力特性,并根据仿真结果精化和优化系统。虚拟样机技术利用虚拟环境在可视化方面的优势以及可交互式地探索虚拟物体的功能,对产品进行几何、功能、制造等许多方面交互的建模与分析。它在CAD模型的基础上,把虚拟技术与仿真方法相结合,为产品的研发提供了一个全新的设计方法。它具有以下特点:
A 全新的研发模式
虚拟样机技术实现了系统性的产品优化,使产品在概念设计阶段就可以迅速地分析、比较多种设计方案,确定影响性能的敏感参数,并通过可视化技术设计产品、预测产品在真实工况下的特征,从而获得最优工作性能。
B 研发成本低、周期短、产品质量高
通过计算机技术建立产品的数字化模型,可以完成无数次物理样机无法进行的虚拟试验,不但减少了物理样机的数量,降低了成本,而且缩短了研发周期、提高了产品质量。
C 实现了动态联盟
广泛地采用动态联盟, 通过Internet共享和交流,临时缔结成的一种虚拟企业,适应了快速变化的全球市场,克服单个企业资源的局限性。
1.2.2 研究现状和发展趋势
虚拟样机技术在一些较发达国家,如美国、德国、日本等已得到广泛的应用,应用领域从汽车制造业、工程机械、航空航天业、到医学以及工程咨询等很多方面。
美国航空航天局(NASA)的喷气推进实验室(JPL)研制的火星探测器“探路号”,就是JPL工程师利用虚拟样机技术仿真研究研发的。美国波音飞机公司的波音777飞机是世界上首架以无图方式研发及制造的飞机,其设计、装配、性能评价及分析就是采用了虚拟样机技术,不但缩短了研发周期、降低了研发成本,而且确保了最终 西南交通大学本科毕业设计(论文)第3页 产品一次接装成功。
我国从“九五”期间开始跟踪和研究虚拟样机的相关技术,主要研究集中在虚拟样机的概念、系统结构以及相关的支撑技术,应用多集中在一些高精尖领域。近年来,才尝试着将虚拟样机技术用于一般机械的开发研制。天津大学与河北工业大学采用虚拟样机技术联合开发了冲击式压实机,对其进行了仿真计算,得到各部件的运动规律曲线,验证了压实机各部件参数值的合理性。
【4】虚拟样机概念正向广度和深度发展,今后的虚拟样机技术将更加强调部件、技术、知识的重用,强调便于虚拟样机柔性协同的运行管理的组织重构,强调跨领域技术的沟通支持,重点在以下几个方面进行研究:
(1)基于虚拟样机的优化设计;(2)以虚拟样机为中心的并行设计设计;(3)分析和仿真工具的集成;(4)虚拟样机系统的容错性研究。
1.3 视景仿真技术简介
1.3.1 视景仿真的定义和特点
视景仿真又称虚拟仿真虚拟现实仿真。它是21世纪最有前景的高科技技术之一,它是计算机技术,图形图象技术,光学技术,控制技术等多种高科技的结合,是延伸人类感觉器官的一门科学,通过对现实世界或者是人类想象的虚拟世界进行三维建模并实时驱动,通过头盔显示器或者三维投影技术显示出来。
视景仿真(Visual Simulation)是一种基于可计算信息的沉浸式交互环境,具体地说,就是采用以计算机技术为核心的现代高科技生成逼真的视、听、触觉一体化的特定范围的虚拟环境,用户借助必要的设备以自然的方式与虚拟环境中的对象进行交互作 用、相互影响,从而产生“沉浸”于等同真实环境的感受和体验。其作为计算机技术中最为前沿的应用领域之一,它已经广泛应用于虚拟现实、模拟驾驶、场景再现、城市规划及其它应用领域。计算机仿真又称全数字仿真,是根据相似原理,利用计算机来逼真模仿研究系统中的研究对象,将研究对象进行数学描述,建模编程,并且在计算机中运行实现.作为计算机仿真的组成部分,视景仿真采用计算机图形图像技术,根据仿真的目的.构造仿真对象的三维模型并再现真实的环境,达到非常逼真的仿真效果.目前,视景仿真技术在我国已广泛应用于各种研究领域:军事演练、城市规划仿真、大型工程漫游、名胜古迹虚拟旅游、模拟训练以及交互式娱乐仿真等.视景仿真技术对作战装备的使用效果有很好的实时显示,给人以强烈的视觉上的冲击,对提高武器装备的性能、研制效率有着重要的作用
西南交通大学本科毕业设计(论文)第4页
1.3.2 工业robot视景仿真系统研究的意义
由于robot价格昂贵,以及robot的作业空间需要较大而独立的试验场地等诸多原因,不可能达到每个需要学习robot的人都能亲自操作robot的要求。而可视化技术的出现,使得人们能够在三维图形世界中观察robot,并通过计算机交互式对robot进行示教仿真。基于VC++6.0的OpenGL上的工业robot的视景仿真系统可以提供一个真实的实验平台,在不接触实际robot及其工作环境的情况下,通过图形技术,提供一个和robot进行交互的虚拟环境。此系统充分利用OpenGL的实时交互性,模拟工业robot的示教/再现过程,可以在此系统上编辑工业robot的程序并动态模拟工业robot的运动过程,观察工业robot的运动结果,检验所编写工业robot程序的正确性。进行实物实验之前,可以先在仿真系统上进行模拟仿真,观察实验的运动过程以及运动结果,避免直接在现实中操作对工业robot及周围物体可能造成的伤害。另外,对于刚接触工业robot的操作员来说,此系统可以提供与现实工业robot几乎相同的操作步骤,在操作员真正操作工业robot之前,可以增加其操作的熟练程度,增加安全系数。
1.4 本文要研究的主要内容
为了简化研究,本文采用一个3自由度关节robot,分别通过ADAMS软件的建模和仿真,结合MATLAB的运算功能,进行了robot运动学分析和空间坐标的轨迹规划,实现运动轨迹的最优化。又在Windows XP环境下,利用Visual C++6.0和OpenGL完成了基于模型的视景仿真系统的设计与实现,具体工作如下:
(1)进行运动学分析。按照通用的D-H法则,通过矩阵变换,得到了robot的正运动学方程和初始坐标,推导出robot逆运动学的关节角度。
(2)在ADAMS/View中构造robot部件,运用约束库中的移动和旋转副对部件进行链接,添加驱动力,实现robot的运动,完成三维建模。
(3)对robot的运行轨迹进行多项式优化,利用ADAMS/View的仿真和后处理模块,绘制小臂末端处所取点的位置、速度、加速度、角速度和角加速度曲线,结合曲线进行三次多项式和五次多项式轨迹规划的仿真分析,并进行比较分析。
(4)利用Visual C++6.0和OpenGL导入并建立机械手模型,建立仿真场景,实现基于模型数据的运动仿真,并实现视角的交互式键盘控制。
西南交通大学本科毕业设计(论文)第5页
第二章 robot运动学
robot运动学指研究robot各个连杆相对运动的空间几何关系。在实际应用中,最为感兴趣的问题是robot手部(即末端执行器)相对于参考坐标系的空间描述。robot可以看成为一个开环的运动链,该链是由一组杆件相连而成,其一端固定在基座上,另一端固定在robot手部上。两个杆件之间通过关节相连,关节由驱动器驱动,使杆件之间产生相对运动,从而使robot手部达到期望的位置和姿态。
在robot运动学的研究过程中,又可以分为两类基本问题,即robot运动学的正问题与逆问题。其中,robot运动学的正问题指在已知杆件几何结构参数和关节变量值的前提下,求解robot手部相对于参考坐标系的位置与姿态的问题;robot运动学的逆问题指根据robot手部在笛卡尔坐标系中的位置与姿态求解robot各关节的关节变量值的问题。
【5】2.1 空间点和坐标系的表示
2.1.1 空间点的向量表示
在直角坐标系中,可以用一个3×1的位置矢量来表示空间内任意一点的位置。对于直角坐标系中任意一点p的位置可以用3×1的位置矢量P表示为
px
Ppypz
(2-1)
如图2-1所示,px,py和pz分别 表示点P在当前坐标系中的三个坐标轴 方向的分量。这里P称为位置矢量,这
种表示法也可变化为如下形式:
图2-1 空间点的位置表示
ppxpypzw
(2-2),p为p的齐
T加入一个比例因子w,使得
pypxpzpx,py,pzwww 西南交通大学本科毕业设计(论文)第6页 次坐标。10 【】2.1.2坐标系在固定参考坐标系中的表示
当一个坐标系位于另一个坐标系中时,如图2-2所示,通常用三个互相垂直的单位向量n、o、a表示,这三个变量分别代表法线(normal)、指向(orientation)与接近(approach)向量(如图2-2所示)。每一个单位向量都可以由它所在参考坐标系中的三个分量表示,这样,坐标系F就可以表示为由四个向量组成的矩阵:
nxnyF =nz0oxoyoz0axayaz0py(2-3)
pz1px
图2-2 一个坐标系在另一个坐标系中的表示
式(2-3)中前三个列向量取w=0,表明该坐标系三个单位向量n、o、a的方向。而第四个列向量中w=1,表示该坐标系相对于参考坐标系的位置。
2.2 坐标系的变换
坐标系的变换包括绕固定参考坐标系的变换和绕运动参考坐标系的变换。
2.2.1 齐次变换
空间中一个坐标系相对于固定的参考坐标系的运动称为齐次变换。齐次变换可以是平移运动,可以是旋转运动,也可以是平移与旋转的复合运动。
(1)纯平移齐次变换
如果一个坐标系(它可能表示的是一个物体)在空间运动中相对于固定参考坐标系的姿态不发生变化,即该坐标系的三个单位向量方向不变,只改变它的坐标原点位置,则称这种运动为平移运动。如图2-3所示,坐标系{A}沿平移向量d平 西南交通大学本科毕业设计(论文)第7页 移到新的位置:
d=dxdydz(2-4)
T【7】其中dx,dy,dz是平移向量d相对于固定参考系三个坐标轴方向的分量。
图2-3 坐标系的平移
平移后新的坐标系原点位置向量可以表示为原来坐标系的原点位置向量与位移向量d的矢量和。若采用矩阵形式,新坐标系的矩阵表示可以通过将坐标系左乘变换矩阵。由于平移过程中方向向量保持不变,所以平移变换矩阵T可以简单地表示为: 10T0001000010dxdy(2-5)dz1可以看到,矩阵的前三列没有旋转运动(等同于单位矩阵),而最后一列表示平移运动,这个方程可以用符号表示如下:
Fnew即 Trans(dx,dy,dz)Fold(2-6)西南交通大学本科毕业设计(论文)第8页
Fnew1000nxnynz001000010dxnxdynydznz10pydypzdz1oxoyoz0axayaz0pypz1pxoxoyoz0axayaz0pxdx(2-7)(2)绕轴纯旋转齐次变换
为了简化旋转变换的推导,假设坐标系{B}位于坐标系{A}的原点。纯旋转就是{B}坐标系在空间中运动中相对于固定参考坐标系{A}的位置不发生变化,即只改变该坐标系三个单位向量的方向而不改变其原点位置。这样坐标系{B}可以由坐标系{A}经过旋转次变换后得到,由此可以推广到其他旋转情况。
设向量x, y, z为坐标系{A}的三个单位向量,空间任意一点p的位置可以用向量p表示。向量p在坐标系{A}中的表示为:
Ap=pxix+pyjy+pzkz(2-8)向量p在坐标系{B}中的表示为:
Bppnin+pojo+pk(2-9)B则向量P在坐标系{A}中的投影分别为
Pxix.Bpix.inpn+ix.jopo+ix.kp(2-10)Pyiy.Bpiy.inpn+iy.jopo+iy.kp(2-11)Pziz.Bpiz.inpn+iz.jopo+iz.kp(2-12)写成齐次矩阵形式则为:
西南交通大学本科毕业设计(论文)第9页
ix.pxininiy.py iniz.pz10ix.ininiy.iniz.0iy.ioiy.i0iz.i0iz.io0001ix.ioix.i0pnpo(2-13)p1ix.ioix.i0iy.ioiy.i0(2-14)
iz.i0iz.io0001ARB当坐标系{B}只相对于坐标系{A}单个轴转动时称为基本变换矩阵。如坐标系{B}只绕坐标系{A}的x轴转动角度θ时,基本转动变换矩阵记为Rot(x,θ),由式(2-14)可以计算得:
1Rot(x,)000CSS(2-15)C0可以用同样的方法来分析坐标系{B}绕坐标系{A}的y轴和z轴旋转的情况,结果如下:
C0Rot(y,)01S0CRot(z,)S0(3)复合齐次变换
0(2-16)CSS0C0(2-17)01复合齐次变换是有由固定坐标系或当前运动坐标系的一系列沿轴平移和绕轴旋转变换所组成的,此时该固定坐标系在参考系中不仅原点位置发生变化,同时它的三个坐标轴单位向量的方向也发生变化。此时的变换顺序很重要,变换顺序不同,结果不同。
我们假设坐标系(n, o, a)相对于参考坐标系(x ,y ,z)依次进行了下列四个变 西南交通大学本科毕业设计(论文)第10页 换:
绕z轴旋转θ度 绕z轴平移d 绕x轴平移a 绕x轴旋转α度 则复合齐次变换XYZxyzTnoa可由下式求解:
TnoRot(x,)Trans(a,0,0)Trans(0,0,d)Rot(z,)(2-18)可见,齐次变换矩阵是由一组平移和旋转矩阵依次左乘获得,矩阵书写的顺序
【6】和进行变换的顺序正好相反,而且变换的顺序不能更改,否则结果会随之改变。
2.2.2 坐标系相对于旋转坐标系的变换
前面我们所讨论的所有变换都是相对于固定参考坐标系的。也就是说,所有平移和旋转都是相对于参考坐标系的轴来测量的。然而事实上,也有可能相对于运动坐标系或当前坐标系的轴的变换。例如,相对于运动坐标系(当前坐标系)的n轴而不是参考坐标系的x轴旋转θ度。为了计算当前坐标系中点的坐标相对于参考坐标系的变化,我们需要右乘变换矩阵而不是左乘。由于运动坐标系中的点或刚体的位置总是相对于运动坐标系测量的,所以必须右乘来表示该点或刚体的位置矩阵。
2.2.3 变换矩阵的逆
A在分析robot时,如果已知坐标系{B}相对于坐标系{A}的值
BTB到{A}相对于{B}的描述
TA,为了得,需要求这个矩阵的逆。一个直接求逆的方法就是将44齐次变换求逆。同样,我们还可以通过变换的性质求逆。下面是关于x轴简单旋转矩阵的求逆过程。旋转矩阵如下:
1Rot(x,)000CSS(2-19)C0我们采用以下的步骤来计算旋转矩阵的逆: 1)计算矩阵的行列式 2)将矩阵转置
西南交通大学本科毕业设计(论文)第11页 3)将转置矩阵的每个元素用它的子行列式代替 4)用转置后的矩阵除以行列式 通过以上步骤我们得到:
1TRot(x,)000CS0S(2-20)C关于x轴的旋转矩阵的逆与它的转置矩阵相同,即:
TRot(x,)1Rot(x,)(2-21)2.3 robot的正逆运动学
对于一个已知构型的robot,当它的连杆长度和关节角度都已知时,计算robot手的位姿就称为正运动学。也就是说,如果已知robot所有的关节变量,用正运动学方程就能计算任一瞬间robot的位置和姿态。如果要将robot的手放到一个期望的位姿,就必须知道robot所有关节的长度和角度。由robot手的位姿来求关节和连杆变量的过程就称为robot的逆运动学。对于正运动学,必须推导出一组特定方程,我们只要将已知的关节和连杆变量代入方程就能计算出robot的位姿,然后再根据这些方程求解出逆运动学方程。
在空间中,要确定一个物体的几何状态需要确定其3个位移坐标(位置)和三个旋转坐标(姿态)。robot手部的空间位置和姿态的表示可以借助一个固连在它上面的参考坐标系来表示,只要这个坐标系可以在基座的参考坐标系的空间中表示出来,那么该robot手部相对于基座的位姿就是已知的了,可采用齐次坐标变换的方法完成这两个坐标系的坐标转化。
图2-3 robot手的位置和姿态描述
西南交通大学本科毕业设计(论文)第12页
robot手部的位姿如图2-3所示,可由固接在robot手部的坐标系{B}来表示。该坐标系由其原点位置和三个单位矢量(n, o, a)唯一确定。坐标系{A}表示固连在robot基座上的固定参考坐标系。向量P为坐标系{B}原点在坐标系{A}中的位置矢量。前面已经讨论过了一个坐标系在固定坐标系的表示故这里直接给出坐标系{B}在坐标系{A}中的位姿的表示:
nnYF =n0ooYo0aaYa0pY(2-22)p1p2.3.1正运动学的D-H表示法
robot建模采用的是Denavit和Hartenberg提出来的标准方法,我们简称为D-H模型,该模型可用于任何复杂的robot构型。
假设robot由一系列的关节和连杆构成,这些关节包括滑动的和旋转的,连杆长度任意,确保在空间能构成任意想要的robot模型。为了表示这个模型,我们需要为每个关节指定一个参考坐标系,然后再考虑从一个关节到下一个关节的变换。
假设一个robot由任意多的连杆和关节以任意形式构成。如图2-4所示,任意三个顺序连接的关节和连杆,每个关节都可以平移或旋转。指定第一个关节为关节n,第二个第三个关节分别为n+1和n+2,连杆n位于关节n和n+1之间,连杆n+1位于关节n+1和关节n+2之间,这些关节和连杆前后还有其他连杆和关节。
西南交通大学本科毕业设计(论文)第13页
图2-4 关节-连杆组合的通用D-H表示法
D-H表示法建模的第一步是为每个关节指定本地参考坐标系,每个关节都必须指定x轴和z轴,由于D-H法不用y轴,一般不指定y轴。具体步骤如下: 所有关节用z轴表示,如果关节是旋转,z轴位于按右手规则旋转的方向,如果关节是滑动的,z轴为沿直线运动的方向。关节n处z轴的下标记作n-1。对于旋转关节,绕z轴的旋转(角)是关节变量,对于滑动关节,沿z轴的连杆长度d是关节变量。
如图2-4所示,通常关节不一定平行或相交,因此z轴通常是斜线,但总有一条公垂线,正交于任意两条斜线。通常在公垂线方向上定义本地参考坐标系的x轴。例如an表示zn1和zn之间的公垂线,xn的方向即沿an方向。 如果两个关节的z轴平行,那么它们之间就有无数条公垂线,我们可以挑选与前一公垂线共线的公垂线,从而简化模型。
若两相邻的关节z轴相交,则不存在公垂线,我们选择垂直于两轴平面的任意直线,同样简化了模型。
在图2-4中,角表示绕z轴的旋转,d表示z轴上两相邻公垂线之间的距离,a表示每一条公垂线的长度,角表示相邻两z轴的夹角。通常只有和d是变量。从一个参考坐标系变换到另一个参考坐标系(例如从xn-zn到xn1-zn1),可以通过以下四步标准运动实现:
西南交通大学本科毕业设计(论文)第14页 绕zn轴旋转n1,使得xn和xn1相互平行且共面。 沿zn轴平移dn1距离,使得xn和xn1共线。
沿xn轴平移an1距离,使得的原点重合,此时两个坐标系的原点在同一位置。 将zn轴绕xn1旋转n1,使得zn和zn1对准。至此,坐标系n和坐标系n+1完全一致,变换结束。
在n+1和n+2坐标系间按照同样的运动顺序也可以实现坐标系间的变换。我们可以从参考坐标系开始,转换到robot底座,再到第一个关节,依次下去直至末端执行器。每个变换矩阵(记作A)都是由上述四个矩阵依次右乘的结果:nTn1An1Rot(z,n1)Trans(0,0,dn1)Trans(an1,0,0)Rot(x,n1)Cn1-Sn10010Sn1Cn100010000100010001000001dn101000001
000an1100CS100n1n10100Sn1Cn1001000(2-23)
An1Cn1Sn100Sn1Cn1Sn1Sn1Cn1Sn1an1Cn1an1Sn1dn11
(2-24)Cn1Cn1Sn10Cn10从robot基座到手(末端执行器)之间的总变换可以表示为:
RTHRT11T22T3...n1TnA1A2A3...An(2-25)
为了简化计算,我们为关节和连杆参数制作一个表格,每个参数可以从robot的原理图上读出,计算时再这些参数代入A矩阵。在本文中设计的简单三自由度robot模型参数如图2-5所示。所有链接采用旋转关节,D-H参数如表2-1所示。
西南交通大学本科毕业设计(论文)第15页
图2-5 简单三自由度robot(单位:英寸)表2-1 robotD-H参数表(逆转为正,顺转为负)连杆i 1 2 3 4
d
0 65 0 0
a
0 0 200 150
90° 0°-30°-30°
0°-90° 0° 0°
将上述角度值代入式(2-25),运用MATLAB进行计算出robot初始位置坐标:
2.3.2逆运动学方程的求解
为了让robot处于适当的位姿,我们需要求解每个关节的角度值,这就是robot
R的逆运动学。我们可以通过矩阵
TH左乘
An1来求解,如下:
RTH为了求解角度,我们从式:
nnYA1A2A3...Ann0A11ooYo0aaYa0p(2-26)p1pY开始,依次左乘上述矩阵,得到每个关节角度表达 西南交通大学本科毕业设计(论文)第16页
A11nnYn0ooYo0aaYa0pY(2-27)A2A3...An
p1p因此,我们的三自由度robot逆运动关节角度表达
1arctan(PX/PY)
2arccosPC(1C3)PYS3/18(1C3)C1Z1
(2-28)3arccos(PY/C)2(PZ)2162/162
2.4 微分运动
微分运动即robot的微小运动,可以用它来推导不同部件之间的速度关系。
图2-6(a)具有两自由度平面结构(b)速度图
如图所示的两个自由度的简单机构,1表示第一个连杆相对于参考坐标系的旋转角度,下:
2表示第二个连杆相对于第一个连杆的旋转角度。B点的速度可以计算如VBVAVB/Asinilcosjl()l1(2-29)11111212sin(12)il2(12)cos(12)j将速度方程写成矩阵形式得到如下结果:
西南交通大学本科毕业设计(论文)第17页
VBX VBYl1sin1l2sin(12)l1cos1l2cos(12)l2sin(12)l2cos(12) (2-30)
方程左边表示B点速度的x,y分量。B点的位置我们可以用下述方程表示:
XBl1cos1l2cos(12)(2-31)YBl1sin1l2sin(12)对方程中的1和2微分,写成矩阵形式如下:
l2sin(12)l2cos(12)d1 (2-32)
d2dXBdYBl1sin1l2sin(12)l1cos1l2cos(12)我们看到,(2-29)和(2-31)式在形式上很相像,只是前者表示的是速度关系,后者表示的是微分运动的关系。因此在robot运动中,我们可以将关节的微分运动与速度联系起来。
西南交通大学本科毕业设计(论文)第18页
第三章 基于ADAMS的robot的虚拟样机分析
3.1 ADAMS概述
美国MSC.Software公司在2003年3月收购了全球最大机构的仿真软件、咨询服务、系统集成供应商MDI/ADAMS。MSC.Software公司的ADAMS软件是虚拟样机领域内广泛使用的软件,可以使工程师、设计人员能够在物理样机构造前,建立机械系统的“模拟样机”,预估出机器的工作性能。ADAMS软件具有如下特点:(1)分析类型包括运动学、静力学分析以及线性和非线性动力学分析(2)具有二维和三维建模能力
(3)具有50余种联结副、力和发生器组成的库和强大的函数库(4)具有组装、分析和动态显示模型的功能,包含刚体和柔体分析(5)具有与CAD、UG、Pro/E、Matlab、ANSYS等软件的专用接口(6)具有开放式结构,允许用户集成自己的子程序
基于ADAMS的虚拟样机技术是在制造物理样机前,利用计算机技术建立该产品的数学模型,通过基于实体的可视化仿真分析,模拟该系统在实际工作环境中的运动学和动力学特性,并反复修改设计,从而得到最优方案。
A 创建模型
创建机械系统模型时,首先要创建构成模型的各个零部件。零部件创建完后,需要使用运动关节约束库创建零部件之间的约束副,确定部件之间的连接情况以及仿真过程中构件之间的位置关系。最后,施加运动及各种载荷使样机按照设计要求进行仿真。
B 测试验证模型并细化
模型创建过程中和完成后,都可以对模型进行运动仿真测试。通过对模型的性能测试,验证设计方案的正确性,然后,在模型中增加更复杂的因素,进一步细化模型。为便于不同方案的比较,通过设计变量不同取值的迭代仿真,求出设计变量的最优值。
C 优化设计
采用设计和优化分析的研究手段,确定各个设计变量相对于解算结果的灵敏度并最终确定目标函数的最优值。
【8】3.2 ADAMS中robot模型的建立
本文机械手模型参考了PUMArobot的结构,建模过程中依照模块化的思想先绘制各个部件,然后通过布尔运算和参数的调整,完成建模。
【15】 西南交通大学本科毕业设计(论文)第19页
3.2.1 设置建模环境
打开ADAMS/View,选择创建新模型,将机械手模型命名为model_2jixieshou,其他采用系统默认值,进入建模界面。
在建模界面中,首先要设定工作栅格,点击菜单Settings中的Working Gird.如图3-1所示,根据建模需要,栅格范围设置为1000×1000(mm),大小为50×50(mm)。
图3-1 工作栅格设置
设置完工作栅格就可以开始建模。
3.2.2robot实体建模
ADAMS/View中集成了很多图形模板,包括点,线,面,体各方面。我们构建的是robot的三维立体模型,其主要部件都是刚体。ADAMS中的刚体模板包括圆柱,圆锥,长方体,球体,拉伸体,平板等。我们选择圆柱体(圆盘)作为robot的底座,圆柱体作为robot的腰部,拉伸体作为robot的手臂。在建模过程中,作者一直根据模块化的原则,在建立每一个部件的过程中都同时通过布尔运算等对模块进行优化,很好的美化了模型,并且是模型更加合理。这种工作方法为最后的总装提供和很大的便利和好处,节省了很多时间,提高了工作效率,值得在其他工作中借鉴。由于建模过程主要是ADAMS软件的操作过程,如果对ADAMS比较熟悉这个过程就很简单。本文不再对建模过程做详细介绍。建立好的机械手实体模型如下图3-2 西南交通大学本科毕业设计(论文)第20页 所示:
图3-2 机械手实体模型
3.2.3 robot模型的设置
robot实体模型建好以后,应对其属性进行修改。我们设计用的robot材料为铝材,初始位移为各个点的初始位置,初始速度设置为零。选定材料后,物体的密度就自动确定了,同时系统会自动计算构件的质量。然后对关节添加相应的约束和驱动力。如果我们要模拟某些特殊的工作过程,我们还应该在相应的位置处添加力和力矩。如我们模拟提升物体的操作过程,那么我们就在小臂(PART6)的端部PART6_MARKER_6处添加一个大小为10N方向向下的力。完成这个设置后robot的模型如下图3-3所示:
西南交通大学本科毕业设计(论文)第21页
图3-3 robot最终模型
至此,我们已经完成了三自由度robot的建模过程,通过软件自检功能,可以判定模型正确与否,建模完成以后就可以进行运动学仿真分析。
3.3 轨迹规划仿真分析
完成建模过程后,我们就可以运用软件的仿真功能对模型的运动学,静力学,动力学进行分析,本文对所建立的模型进行了运动学的理论分析,然后又结合轨迹规划进行了仿真分析。轨迹规划一般分为两种:一种是在关节空间进行规划,将关节变量表示成时间的函数,并规划它的一阶和二阶时间导数;另一种是在直角空间(笛卡尔空间)进行规划,将末端位姿、速度、加速度表示为时间的函数,而相应的关节位移、速度和加速度由末端信息导出。
【12】
本文分别给出了对模型进行关节空间和直角空间轨迹规划方法的理论分析,并在ADAMS/View的仿真和后处理模块中利用ADAMS内嵌的step函数对关节空间内三次多项式和五次多项式轨迹规划进行了分析比较。
3.3.1 轨迹规划方法的理论分析
西南交通大学本科毕业设计(论文)第22页
(1)关节空间内三次多项式轨迹规划
假设robot的初始位姿是已知的,通过逆运动学方程可以求得期望位姿对应的关节角。若考虑其中某一关节在运动开始时刻运动到新的角度f,使用多项式函数可以保证初始和末端的边界条件与已知条件相
ti的角度i,希望该关节在tf时刻匹配,这些条件信息可以求解下面的三次多项式方程。
23(t)c0ctctct(3-1)123这里的初始条件和末端条件是:
(ti)i(tf)f(ti)0(tf)0(3-2)
对4-1式求导,得:
(t)c2ct3ct2 (3-3)123将4-2式分别代入4-1和4-3式得:
(ti)c0i23(tf)c0ctctct1f2f3f(t)c0i1(t)cctct20f12f3f(3-4)
联立求解这四个方程就可以得到任意时刻的关节位置,控制器则据此来驱动关节。每个关节分别规划,同步运行。如果要求robot依次通过多个点,则每一段末端求解出的速度和位置都可用作下一段的初始条件,每一段的轨迹都可采用上述的三次多项式来规划。
针对本文设计的三自由度robot,在其初始位置基础下,我们要求robot手臂在6S后分别运动1=180°,2=60°,
3=30°。
西南交通大学本科毕业设计(论文)第23页
表4.1 三次多项式规划关节角度
t
0 1 2 3 4 5 6
1
0.0000 13.3333 46.6667 90.0000 133.3333 166.6667 180.0000
2
0.0000 4.4444 15.5556 30.0000 44.4444 55.5556 60.0000
3
0.0000 2.2222 7.7778 15.0000 22.2222 27.7778 30.0000 将上述边界条件代入4-4式,解得第一个关节轨迹参数为c0=0,c1=0,c2=15,532=-5/3轨迹方程为:(t)15tt;同样可得出第二个关节轨迹参数c0=0,1c33532=0,=5,=-5/9轨迹方程为:第三个关节参数c0=0,c1=0,(t)5tt;2c1c2c395253=5/2,=-5/18轨迹方程为:(t)32t18t c2c3我们将运动过程分为5段,则每秒钟robot运动的关节角度如表4-1所示。(2)关节空间内五次多项式轨迹规划
在三次多项式规划中,我们采用的边界条件是起点和终点的位置与速度,如果同时指定起点和终点的加速度,这样边界条件就增加到6个,可以用同样的方法进行五次多项式的规划:
2345(t)c0ctctctctct(3-5)12345(t)c2ct3ct24ct35ct4(3-6)12345(t)2c26c3t12c4t220c5t3(3-7)
(3)关节空间内抛物线过渡的线性运动轨迹规划
在关节空间轨迹规划的另一种方法就是让关节以恒定的速度在起点和终点之间运动,轨迹方程相当于一次多项式,速度为常数,加速度为零。这样意味着在起点和终点的加速度必须为无穷大,为避免这一情况,线性运动在起点和终点可以用抛物线来过渡。如图4-6,抛物线与直线过渡段在时间和处是对称的,由此得到:
西南交通大学本科毕业设计(论文)第24页
12(t)c0ctct122(t)cct(3-8)12(t)c2
图4-6 抛物线过渡的线性段规划方法
此时抛物线运动段的加速度为一常数,在A点和B点速度连续,将边界条件代入得:
(t0)ic0(t0)0c1(t)c2从而得出抛物线的方程为:
c0ic10
c2(t)i(t)c2t(t)c212c2t2(3-9)
将零初速度,线性段常值速度以及零末端速度代入上式,得到:
12c2tb2ctA2bAi
BA(tftb)tbAtf2tbBA 西南交通大学本科毕业设计(论文)第25页
fB(Ai)0f从而可求出过渡时间:
(3-10)
iftftb(3-11)
显然,不能大于总时间的一半,否则整个过程中只有加减速而没有直线运动。终点的抛物线段与起点是对称的,只是加速度为负而已。
我们依然用设计的三自由度robot来进行规划。在其初始位置基础上,我们要求robot手臂在6S后分别运动
1=180°,2=60°,3=30°中间匀速运动的速度分别为v140/s,v212/s,v36/s,那么过渡时间分别为:
0180406060126030661.5(s),tb21.0(s),tb31.0(s)
40126匀加速,匀速,匀减速运动方程分别如下: tb11802t2380tiA380第一个关节角1: 33040(t1.5)40 AB 0180180(6t)22380 Bf (6t)38031212t2第二个关节角2:iA12t
12 西南交通大学本科毕业设计(论文)第26页
612(t1) AB 120126012(6t)2 Bf 12(6t)12126t2第三个关节角3:iA6t
636(t1) AB 601306(6t)22 Bf 6(6t)6则在0s到6s关节的角度分别如表4-2所示:
表4-2 抛物线过渡规划关节角度 t 0 1 2 3 4 5 6
1
0 40/3 50 90 130 500/3 180
2
0 6 18 30 42 54 60
3
0 3 9 15 21 27 30(4)直角空间轨迹规划
西南交通大学本科毕业设计(论文)第27页
直角坐标空间轨迹与robot相对于直角坐标系的运动有关,robot末端执行器的位姿就是沿循直角坐标空间的轨迹。实际上所有的关节空间轨迹规划的方法都可用于直角坐标空间的轨迹规划。其差别在于:对于关节空间的轨迹规划,规划函数生成的值就是关节值,而直角坐标空间轨迹规划函数生成的值是robot末端执行器的位姿,必须通过反复求解逆运动学方程来计算关节角。
其过程可以综合如下: 将时间增加一个增量ttt;
利用所选择的轨迹函数计算末端执行器的位姿; 利用robot逆运动学方程计算位姿对应的关节量; 将关节信息传递给控制器; 重复以上循环过程。
3.3.2 轨迹规划仿真分析
(1)三次多项式轨迹规划仿真分析
我们在ADAMS里进行三次多项式轨迹仿真时,用的是STEP函数。[13] STEP函数利用的是三次多项式逼近海赛阶跃函数。STEP阶跃函数有连续的一阶导,但在起点处的二阶导不连续,在速度图像上表现为速度连续但加速度不连续。
我们设定robot三个部分在6S时间内分别转动180°,60°,30°,为了分析其运动特性,我们分别选取robot小臂PART6末端的PART6_MARKER_6点的运动参数进行分析。
robot小臂末端的PART6_MARKER_6在X,Y,Z三个方向上的位移曲线如下:
图4-7 PART6_MARKER_6在X,Y,Z三个方向上的位移图
西南交通大学本科毕业设计(论文)第28页
从上图中我们看到,在三次多项式规划条件下,X,Y,Z三个方向上的点都呈现出起伏变化,与匀速驱动条件下情况不同。PART6_MARKER_6点从(248.2051,70.0962,-40.0)运动到(-303.1089,475.0,40.0)处。
PART6_MARKER_6速度和加速度曲线如图4-8所示,我们可以看到,速度由0mm/s增大到297.6708mm/s,然后又逐渐下降到0mm/s,而加速度最大值达到了2s253.6641mm/,并且在0.012s和5.988/s处存在突变。
图4-8 PART6_MARKER_6速度和加速度图像
PART6_MARKER_6角速度和角加速度曲线如图4-9所示,PART6_MARKER_6角速度和角加速度变化与速度变化类似,最大角速度为50.3512d/s,角加速度最大为33.4069d/s,在0.012s和5.988/s处存在突变。2
图4-9 PART6_MARKER_6角速度和角加速度图像
西南交通大学本科毕业设计(论文)第29页(2)五次多项式轨迹规划仿真分析
我们运用ADAMS内嵌的step5函数对robot关节进行五次多项式轨迹规划,step5函数是通过五次多项式逼近海塞阶跃函数。同样选取我们分别选取robot小臂PART6末端PART6_MARKER_6点的运动参数进行分析。
PART6_MARKER_6在X,Y,Z三个方向上的位移曲线如图4-16所示:
图4-16 PART6_MARKER_6在X,Y,Z三个方向上的位移图像
从上图中我们可以看出,三次多项式和五次多项式轨迹规划相比,robot手臂末端的始末位置不变,都是从(248.2051,70.0962,-40.0)运动到(-303.1089,475.0,40.0),中间点的位移也没太大变化。但是其速度和加速度等运动参数变化却比较大。五次多项式轨迹规划条件下PART6_MARKER_6的速度和加速度曲线如图4-17所示:
西南交通大学本科毕业设计(论文)第30页
图4-17 PART6_MARKER_6的速度和加速度图像
PART6_MARKER_6的角速度和角加速度曲线如图4-18所示:
图4-18 PART6_MARKER_6的角速度和角加速度图像
从上面的图像中我们可以看到,PART6_MARKER_6的速度先增后减,加速度变化也一样。速度从开始时刻的0mm/s增大到中间时刻的370.1791mm/s再减小到终点时刻的0mm/s,加速度变化较三次多项式规划时平缓,不存在突变点。在0s时最小,为0mm/s,中间时刻达到最大值396.2381mm/s,然后逐渐下降到终点时的0mm/s。角速度和角加速度的变化情况如下:最大角速度为62.8912d/s,最大角加速度为32.826d/s,角加速度不存在明显突变。(3)轨迹规划比较分析
2222 西南交通大学本科毕业设计(论文)第31页
从上面的两种轨迹仿真结果中可以看出,三次多项式轨迹规划和五次多项式轨迹规划最大的区别就在前者的加速度和角加速度在中间点存在跳变,而后者的加速度和角加速度的变化则趋于平缓。我们对两种情况下PART6_MARKER_6点的运动参数变化情况进行比较,如下表所示:
表4-3 PART3_MARKER_12点的运动参数比较 比较项目 最大速度mm/s 最大加速度mm/s
加速度突变 最大角速度d/s 最大角加速度d/s 角加速度突变
22三次多项式 297.6708 253.6641 有 50.3512 33.4069 有
五次多项式 370.1791 396.2381 无 62.8912 32.826 无
之所以有这种区别,原因在于三次多项式轨迹规划中,我们的边界条件只有四个,初始位移和速度,终点的位移和速度;而在五次多项式轨迹规划中,我们的初始条件中包含了加速度,分别为初始位移、速度和加速度,终点位移、速度和加速度。因此在一般的三次多项式轨迹规划中,我们应该加入最大速度变化的限制条件,从而保证robot的运动更平稳。
西南交通大学本科毕业设计(论文)第32页
第四章 基于模型的视景仿真系统的设计与实现
随着robot研究的不断深入,robot三维可视化技术作为robot设计和研究中安全可靠、灵活方便的工具,越来越受到重视。robot的三维图形仿真,就是要建立一个精确、逼真的robot模型以及robot工作环境。
三维可视化是数学模拟和科学计算可视化技术相结合的产物,它一般包括两方面内容:一是将传统数字仿真计算的结果转换为图形和图像形式;二是仿真交互界面可视化,即具有可视化交互和动画展示能力,要求能够实时跟踪显示仿真计算结果。可视化技术的出现,使得人们能够在三维图形世界中观察robot,并通过计算机交互式对robot进行示教仿真。
一般来说,robot可视化仿真系统主要由三个模块组成:工业robot的三维模型模块(实现仿真系统的基础)、示教和再现模块(实现示教和再现的功能)、离线编程模块,见图4-1。但是由于时间和知识限制,本文只研究了后两个模块的实现,对离线编程并没有采取通常的做法,根据老师的建议想将Matlab软件和VC++结合起来,用在Matlab里建立的控制模型来控制OpenGL里机械手的运动,本章按照这个思路实现了利用Matlab里建立的控制模型导出的数据来控制机械手的运动。
图4-1 通用robot可视化仿真系统模块
本章将通过VC++6.0和OpenGL来完成机械手的三维可视化仿真系统的设计与实现,它提供一个真实的实验平台,在不接触实际robot及其工作环境的情况下,通过图形技术,提供一个和机械手进行交互的虚拟环境。本章主要内容为:
(1)建立程序框架;
西南交通大学本科毕业设计(论文)第33页
(2)建立机械手三维模型;(3)建立仿真场景;
(4)实现基于模型的视景仿真。
4.1 OpenGL概述
OpenGL即开放性图形库(open graphic libary)是美国高级图形和高性能计算机系统公司SGI所开发的三维图形标准库,具有绘制三维图形的各项功能,它是处理专用图形硬件的软件接口,支持可视化的实现,它是三维计算机图形和模型库,独立于窗口系统和操作系统。
从开发人员角度看,OpenGL是一些绘图指令或函数的集合。这些指令允许用户 对二维几何对象或三维几何对象进行说明,允许用户对对象实施操作以便把这些对象着色到帧存上。OpenGL可以方便地实现三维图形的交互操作。
对于OpenGL的实现者而言,OpenGL是影响硬件操作的指令集合。如果硬件仅仅包括一个可以寻址的帧存,那么OpenGL就不得不在CPU上实现对象的描绘,OPenGL可以保存数量较大的状态信息,这些状态信息可以用来指示OpenGL如何往帧存中画物体。有一些状态,用户可以直接使用,通过调用就可得到状态值;而另一些状态只有作用在所画物体上,才能使其产生的影响可见。
4.1.1 OpenGL工作方式
OpenGL在Windows环境下的工作过程如图4-2所示。OpenGL的库函数被封装在OPengl犯.dll动态链接库中,从客户应用程序发布的对openGL函数的调用首先被Opengl32处理,在传给服务器后,被 winsry.dll进一步进行处理,然后传给
【18】DDx(nivieeDriverInterface),最后传递给视屏驱动程序。
西南交通大学本科毕业设计(论文)第34页
图4-2 OpenGL在Windows环境下的工作过程
4.1.2 OpenGL绘制过程
OpenGL具有较强的图形绘制能力,包括绘制物体、启动光照、管理位图、纹理映射、动画、图形增强及交互技术等功能。综合以上功能,作为图形硬件的软件接口,OpenGL主要是将三维的物体投影到一个二维平面上,之后处理得到像素,进行显示。OpenGL首先将物体转化为可以描述物体几何性质的顶点(Vertex)与描述图像的像素(Pixel),在执行一系列操作后,最终将这些数据转化成像素数据。也就是说,OpenGL是基于点的。有一组顶点定义的图元(Pirmitive)执行完绘制操作后,后继图元才能作用。简单的图形生成过程如图4-3所示。
西南交通大学本科毕业设计(论文)第35页
图4-3 OpenGL中简单图形的绘制过程
对图元的定义:图元由一组顶点定义,这一组顶点可以是一个或是多个顶点。每个顶点信息可以是二维的也可以是三维的。顶点信息可以由位置坐标、颜色值、法向量、纹理坐标组成。法线、纹理、颜色值会在处理每个顶点的过程中被使用。OpenGL将点、线段、多边形等通过在函数glBegin()和glEnd()之间一系列顶点的数据绘制出图形。
对图元的操作:OpenGL用交换矩阵、光照、反走样、像素操作等方法控制图元的绘制。图元的操作处理过程结束后,只留下图元可见部分,准备进行光栅化(投影)处理。像素处理比较特殊:对像素、位图、影像直接进行像素操作,然后进行光栅化,后者是有些数据被存储在纹理中供顶点使用。
光栅化过程:将图元转化为二维图像,完成每个图像点的颜色与深度的计算,生成结果为基片,即各图元的二维结果。
基片操作:处理过程包括基片是否遮挡、测试、融合等,最后得到像素,存入显示帧缓冲中,完成整个绘制过程。
4.2 robot三维可视化框架建立
4.2.1 利用MFC建立单文档应用程序框架
VC++6.0能够创建多种类型的MFC应用程序,不同的应用程序具有不同的应用程序框架,VC++6.0系统的设计者创建了程序框架生成工具Appwizard,用它来建 西南交通大学本科毕业设计(论文)第36页 立开发各种MFC应用程序所需要的程序框架,通过APpwizard就可移动生成包含基本程序框架的应用程序包,这样就可以在此基础上进行程序设计。在参考许多数字
【16】处理、图像处理软件的基础上,决定采用单文档的应用程序框架。
创建工程:启动VC++6.0进入VC++的集成开发环境,新建一个工程,选择 MFC Appwizard选项,在应用程序类型中选择 singledocument(单文档)类型。 设置编译环境:设置编译环境主要包括设置包含文件和设置库文件路径。 加入OpenGL库:选择菜单ProjectSetting,将弹出 ProjectSettings对话框,在该对话框选择Link标签页,如图4-4所示。在该对话框中的Object/Library Module文本框中加入opengl32.lib、glu32.lib、glaux.lib三个函数库文件。在头文件中加入 gl/glu.h(OpenGL核心函数的头文件)和 gl/glut.h(使用函数的头文件),这样就可以调用openGL软件包了。
图4-4 加入OpenGL库函数
这样,我们就很容易的建立了一个在Windows环境下进行OpenGL编程开发的框架,按快捷键F7进行编译,按快捷键F5执行就会弹出一个窗口,包含一个主菜单、一个工具条和一个状态条等部件。如下图4-5所示:
西南交通大学本科毕业设计(论文)第37页
图4-5 程序框架
4.2.2 设置OpenGL绘图环境
1)创建RC 在windows环境下建立OpenGL绘制窗口是通过建立设备描述表(DC)和绘制描述表(RC)来实现的,而RC和DC是连接在一块的。因此,为了建立RC,先要建立DC。用ChoosePixelFormat()选择系统中与pfd描述的像素格式最为匹配的返回;本文现在消息响应函数OnCreate里调用InitializeOpenGL(m_pDC)函数,然后又通过后者调用SetupPixelFormat()函数来设置DC像素格式完成绘图环境的设置工作;
int CMyView::OnCreate(LPCREATESTRUCT lpCreateStruct){ if(CView::OnCreate(lpCreateStruct)==-1)
...return 0;} return-1;m_pDC = new CClientDC(this);InitializeOpenGL(m_pDC);//调用函数
西南交通大学本科毕业设计(论文)第38页
BOOL CMyView::InitializeOpenGL(CDC* pDC){ m_pDC = pDC;SetupPixelFormat();//设置像素格式
m_hRC = ::wglCreateContext(m_pDC->GetSafeHdc());::wglMakeCurrent(m_pDC->GetSafeHdc(), m_hRC);//选择像素格式
return TRUE;} 2)设置坐标变化方式
每次窗口创建或改变大小的时候,都要重新设置视口大小,因此我们在OnsizeO中进行视口设置。而投影变换和视点一模型变换的初始设置也可以放在里面进行。
void CMyView::OnSize(UINT nType, int cx, int cy){ CView::OnSize(nType, cx, cy);if(cy==0)
{cy=1;}
// 防止被零除
glViewport(0,0,cx,cy);// 重置当前视口
glLoadIdentity();视投影矩阵 glMatrixMode(GL_PROJECTION);// 选择投影矩阵
// 重置投影矩阵
gluPerspective(45.0f,(float)cx/(float)cy,0.1f,2000.0f);//设置透 glMatrixMode(GL_MODELVIEW);// 选择模型观察矩阵
glLoadIdentity();// 重置观察模型矩阵 } 3)绘图显示
完成上面的设置以后我们就可以利用OpenGL进行绘图了。本文为了程序的简约,先在OnDraw()里调用RenderScene()函数,然后在RenderScene()里调用所有绘图显示函数。代码如下:
void CMyView::OnDraw(CDC* pDC){ CMyDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);RenderScene();//调用绘图函数 }
西南交通大学本科毕业设计(论文)第39页 4)程序结束,释放资源。
调用消息响应函数OnDestroy(),在函数里完成相关资源的释放。void CMyView::OnDestroy(){ CView::OnDestroy();::wglMakeCurrent(0,0);::wglDeleteContext(m_hRC);if(m_hPalette)DeleteObject(m_hPalette);if(m_pDC){
}...} 最后按照参考书上的方法设置了全屏显示按钮,可以实现全屏显示,同时可以
【16】进行屏幕工具栏的显示缩放。delete m_pDC;编译运行结果如图4-6所示:
图4-6 设置完成的robot三维场景框架
西南交通大学本科毕业设计(论文)第40页
4.3 机械手三维模型的建立
OpenGL中模型的建立一般有两种思路,一种通过一个是用3dsMax绘制出模型并将其转换成特定格式的文件,然后导入到程序中;另一个是直接用OpenGL的函数绘制出所需要的模型。导入的模型比较美观漂亮,但是实现起来技术难度比较大,而OpenGL的函数绘制出的模型则比较粗糙,但是灵活性好,实现起来也比较容易。
4.3.1 导入机械手模型
利用openGL建立复杂物体的三维模型是一件比较麻烦和枯燥的事情,因为OPenGL并没有提供三维模型的高级命令,它也是通过基本的几何图元一点、线及多边形来建立三维立体模型的。而利用3dsMax建立复杂物体的模型则显得轻松的多。可是,用3dsMax制作的动画没有交互性,无法实时控制,而这正是OpenGL的优势所在。把这些模型转换成OpenGL程序,再对其进行控制是一种比较理想的方法。所以,如果可以把OpenGL与3dsMax结合起来实现三维仿真则可以事半功倍。但是由于时间和知识的限制,无法完成对3D模型的读取工作,所以查找了一些读取3D模型文件的代码,利用这些代码将机械手模型转换成了OpenGL程序,将模型导入进了OpenGL里。为了节约时间作者没有在3dsMax里建立机械手的模型,而是在比较熟悉的Auto CAD里建立了机械手的模型,然后通过3dsMax软件模型文件导出成接口程序可识别的*.ASE格式的文件,再通过接口程序导入进OpenGL里。导入前的在3dsMax里的模型如图4-7所示:
图4-7 3dsMax里的机械手模型
西南交通大学本科毕业设计(论文)第41页
导入后的机械手模型经过坐标变换、缩放、改变颜色并加入光照照亮后如下图4-8所示:
图4-8 导入的机械手模型
4.3.2 在OpenGL中建立机械手的模型
虽然实现了模型的导入,但是只实现了整体导入,未能实现分块导入机械手的模型,所以在OpenGL只实现了整体模型的控制,很显然满足不了机械手运动的要求,所以导入的模型只能作为仿真场景的一部分做静态显示。为了继续进行后续工作,作者直接在OpenGL中通过基本的几何图元一点、线及多边形建立了机械手的三维立体模型。机械手模型主要由底座、腰部、关节、手臂这几个部分组成,由于底座、腰部和关节都是圆柱型的,所以作者先利用glu库函数(gluCylinder和gluDisk)【17】画出一个共用的圆柱,然后通过不同的缩放(glScalef)、转移(glTranslatef)、旋转(glRotatef)变换绘制出了底座,腰部和关节的模型。这里取绘制关节的函数作为例子介绍绘制过程,代码如下:
void CMyView::joint(){ glPushMatrix();//模型入栈
GLUquadricObj *obj1;obj1=gluNewQuadric();//创建一个描述当前绘图模式、定位、光照模式、西南交通大学本科毕业设计(论文)第42页 纹理模式和回调函数的不透明的状态变量
glTranslatef(0.0,0.0,-5.0);//向Z轴负方向即屏幕里移动5个像素的距离
glPushMatrix();gluCylinder(obj1,10.0,10.0,10.0,360.0,2);//绘制一个顶面半径、底面半径和高度都为10的圆柱面
glPopMatrix();glPushMatrix();gluDisk(obj1,0.0,10.0,360,1);// 绘制一个半径为10的圆片堵住上述圆柱面的底面
glPopMatrix();glPushMatrix();glTranslatef(0.0,0.0,10);//向Z轴正方向即屏幕外移动10个距离 gluDisk(obj1,0.0,10.0,360,1);//绘制一个半径为10的圆片堵住上述圆柱面的顶面
glPopMatrix();glPopMatrix();//模型出栈 } 绘制手臂也很简单,手臂其实在这里同样是通过对一个立方体进行不同的然后通过不同的缩放(glScalef)、转移(glTranslatef)、旋转(glRotatef)变换来完成绘制。OpenGL里也有对应画立方体的库函数,但是由于不太清楚怎么对用库函数绘制的模型进行纹理贴图,所以选用了一种比较熟悉和简单的方式来绘制,就是通过6个面来组合成一个立方体。对每个面都可以进行不同的纹理贴图。在后面的仿真场景建立过程中同样利用这个四方体也完成了实验室房间、木质方桌、大理石长桌、凳子和储物箱的绘制。绘制立方体的代码如下:
void CMyView::shoubi(){ glPushMatrix();glColor4f(1.0f,1.0f,1.0f,1.0f);//定义面的颜色为白色
glBegin(GL_QUADS);//开始绘制
// 前面
glTexCoord2f(0.0f, 0.0f);glVertex3f(-100.0f, 0.0f,-100.0f);// 纹理和四边形的左下
glTexCoord2f(1.0f, 0.0f);glVertex3f(100.0f, 0.0f,-100.0f);西南交通大学本科毕业设计(论文)第43页 // 纹理和四边形的右下
glTexCoord2f(1.0f, 1.0f);glVertex3f(100.0f, 100.0f,-100.0f);// 纹理和四边形的右上
glTexCoord2f(0.0f, 1.0f);glVertex3f(-100.0f, 100.0f,-100.0f);// 纹理和四边形的左上
glEnd();glBegin(GL_QUADS);// 后面
glTexCoord2f(1.0f, 0.0f);glVertex3f(-100.0f, 0.0f, 100.0f);// 纹理和四边形的右下
glTexCoord2f(1.0f, 1.0f);glVertex3f(-100.0f, 100.0f, 100.0f);// 纹理和四边形的右上
glTexCoord2f(0.0f, 1.0f);glVertex3f(100.0f, 100.0f, 100.0f);// 纹理和四边形的左上
glTexCoord2f(0.0f, 0.0f);glVertex3f(100.0f, 0.0f,100.0f);// 纹理和四边形的左下
} 绘制完机械手的各个部件以后就可以通过缩放(glScalef)、转移(glTranslatef)、旋转(glRotatef)变换来完成整个机械手模型的绘制。代码如下:
void CMyView::manipulator(){ glPushMatrix();glTranslatef(0.0,-80.0,-20.0);//分别沿Y和X轴负方向移动80和20 //glRotatef(0.0,1.0,0.0,0.0);glRotatef(-hand[i].rot1,0.0,1.0,0.0);//绕Y轴旋转-hand[i].rot1(第一个关节角1第i时刻的值)
glPushMatrix();glTranslatef(0.0,-15.0,0.0);glRotatef(-90,1.0,0.0,0.0);//沿X轴逆时针旋转90°
glPushMatrix();glEnd();glPopMatrix();...