找回密码
 注册会员

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 534|回复: 0

六自由度关节式坐标测量机关节零位偏差的标定算法

[复制链接]
发表于 2010-9-11 22:00:53 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转磨削论坛

您需要 登录 才可以下载或查看,没有账号?注册会员

×
1.引言 % e* ~' B3 K2 M3 R

  六自由度关节式坐标测量机是一种新型的非笛卡尔式坐标测量机。它仿照人体关节结构,以角度基准取代长度基准,将六个杆件和一个测头通过六个旋转关节串联连接,一端固定在机座上,另一端(测头)可在空间自由运动,构成一个六自由度的封闭球形测量空间。与传统的笛卡尔式三坐标测量机相比,它具有机械结构简单,体积小,测量范围大,灵活方便等优点,主要应用于CADCAM中三维模型表面数字化和大型零部件几何尺寸的现场检测等领域12
  六自由度关节式坐标测量机在装配过程中,由于角度光电编码器的零位与关节结构的理论零位不重合而产生的角度偏差,称为关节零位偏差。其特点是:各关节的零位偏差各不相同;由于装配工艺误差不可避免,关节零位偏差较大(约±3°);对于每台装配好的关节式坐标测量机,各关节零位偏差值固定不变,属于系统误差。由于杆长的放大作用,关节零位偏差在末端测头处产生很大的位姿误差。因此,为了补偿关节零位偏差,提高测量精度,对关节式坐标测量机进行标定是非常重要的。

/ F- H, |$ s1 T- P2 y

  2.数学模型

! z0 d( b- U/ f# O8 b

) ]6 ^! E; L. a. m8 b

图 六自由度关节式坐

+ g! w$ I( r! v: _- M, F" Q( a' `& v

  标测量机结构模型六自由度关节式坐标测量机从机械结构上可以看成是串联的开式运动链。其结构模型如图所示(各坐标系的Y轴由“右手法则”确定)。
  参见图示,将测头局部坐标系O7-X7Y7X7相对于基座参考坐标系O0-X0Y0Z0的位姿记为T07,这是一个4×4的齐次矩阵,可描述为

_5 a- L- m# s& l4 h

T07A01A12A23A34A45A56A67        (1

B- ]3 s7 _/ D7 [

式中,Ai-1ii1,…,7)是杆件i相对于杆件i1的齐次位姿变换矩阵。DenavitHartenberg1995年提出了两个相互连接且相对运动的构件之间相互关系的分析方法,并给出了相应的齐次变换矩阵3,即

5 _3 T# z: @8 m' F- z; o2 Z5 J8 X

% ~; F: X% Q6 N7 W" i6 r# o

       (2

0 a7 |$ B& @5 K, D

式中,θi是关节的转角,这里是变量,称为关节变量;φi是相邻关节旋转轴线的夹角,这里近似为直角;ai是相邻关节轴线沿空间公垂线的距离,这里近似为0di是相邻杆件坐标原点沿Z轴之间的距离,这里称为杆长。
  对于多关节坐标测量机,测头在空间的姿态并不重要,而测头的空间位置坐标则是需要得到的。将式(1)、(2)合并后,测头位置坐标方程为

) W! ]* S0 v% O/ a O

  P=(R1R2R3R4R5R6q7+(R1R2R3R4R5q6R1R2R3R4q5
    +(R1R2R3q4+(R1R2q3R1q2q1            
3

# N# n7 t( w8 X! j1 A3 X, o G

式中包括三个坐标分量方程,都是关节变量的函数,即

) J* g4 q8 u' ~5 E

PFθ1θ2θ3θ4θ5θ6)       (4

1 _; N9 t% }' m' J, _- M

  为了得到关节零位偏差与测头位置误差之间的关系,假设关节零位偏差足够小,对式(4)求全微分,近似得到测头位置误差方程为4

     5! c' N: t: p- q7 X! |1 X- {

  将式(5)用矩阵方式简单描述,即

9 k3 k' P+ \/ j

ΔPJδΔδ     6

, ^ {5 ?6 G; D, N k

式中 ΔP(ΔPx ΔPy ΔPzT
  
  Δδ=(Δθ1 Δθ2 Δθ3 Δθ4 Δθ5 Δθ6T

- S8 l' y- A0 ~

  由式(4)和式(6)即可得到描述关节零位偏差与测头位置误差之间关系的线性方程。
  3标定算法
  为测定各关节零位偏差值,需要一系列已知标准位置坐标,这些标准位置坐标可以通过高精度的三坐标测量机测得。设有m个标准位置坐标,关节式坐标测量机的测头分别触测这些标准位置,由光电编码器分别得到相应的关节转角,将这些关节转角分别代入方程式(4),计算出测头的理论位置坐标,然后与标准坐标比对,得到m个测头位置误差。把这些数据代入式(6),可得到3×m个位置误差方程,即

) `7 F9 p* J C6 P( V

ΔQGΔδ     7

6 q: d$ O/ }, _+ v

其中

7 w- r3 @' ^, G3 y D

0 N5 z0 w7 I: p6 `

式(7)中有6个未知量,只要3×m6,则可运用最小二乘法求解出关节零位偏差,即

! m8 m! K) r8 A& Z& S+ @

Δδ=(GTG1GTΔQ     8

/ P) i1 l1 n+ v) e$ n' `( u* P, e

  把计算出的关节零位偏差值作为零位偏差的修正量代入式(4),计算出新的测头位置坐标,然后将新的位置误差和新的系数矩阵代入式(7),再重复式(8)的计算。经过以上的反复迭代过程,直到测头位置误差小于设定值,最后获得最优解,即最接近实际的关节零位偏差值。

/ D9 L7 }+ }" o: O7 D- d' h0 S

  4.仿真验算

1 R0 v0 @8 M/ L7 {" k' H& ^3 v3 V

  为了进行计算机仿真验算,首先设定六自由度关节式坐标测量机的结构参数(φiaidi),并假设关节零位偏差(Δθi),具体数值列于表1

1 d, s) n' m$ F7 a0 L

1 六自由度关节式坐标测量机结构参数

/ G+ D$ u, i3 A* ~
0 v$ s3 C! R6 h8 G6 W- K' b" g2 [* C+ `1 k! e2 f8 r& M0 L/ _; |0 \2 x$ ?2 K/ i. a! B$ F5 F# Z% x' z+ k0 A: F8 A4 ^0 J9 q/ |5 l0 f2 |) c3 y' D4 K1 b |: m1 Q" @: c# Q( x4 e7 U& C4 Q4 s* p8 Q4 f, L7 q6 Q$ ]" Q9 W4 f, S; J+ S( D1 F* _9 ~) A" Y; k" W; ~; g' \) D- n* A0 C$ n, ?8 |2 z- r4 `0 M, Y) I% r3 O x- o" g+ ], R1 N: S7 d& {" H% w* [/ a; T8 Q' X0 d, n2 ?# _9 m. X4 x- b- B N/ v! Z* L8 T3 z; |# @, `7 V( p+ h) o& W5 L) N9 Z, g) R( j7 D+ I+ @/ V; d0 ]# x4 U; k9 m* x$ j* ?# } t1 z% q$ X8 [ T2 @0 r0 `& u1 O3 X) o: ]7 f7 f: A' } t6 f" E6 v Z4 r1 T0 V+ I( R1 d7 u( @* [6 v5 {8 p3 O* u: z( w: i. g m, J2 y3 U2 V7 B- S( f2 B& E# w, v( b4 e- A8 A! b2 V n6 \* h+ C6 D) [7 d% }6 p, ?/ b$ O/ y; [+ V! L$ N; l+ s' q6 u( C. U, s- K4 a$ ~6 f! F/ M4 U: ] X+ i. O; ~/ @7 t3 a8 E! v- R1 ~( X% H( P; u3 }5 E% P4 a/ E1 T" ~1 w2 v1 W' j6 c3 ~$ g* r* W& |. d) i! A: \. I/ x3 _* \: B0 K' U9 [7 O9 A! b0 ^+ Z0 }5 Y5 u) Y7 X$ \5 N* ]7 U# Y8 D( G- o4 g( s* g) l1 f3 E% }; t+ h: i" T2 n' \! I1 y, A6 x9 O6 `6 J3 h* G8 L1 o1 Z' Q- q! j1 `9 m6 a, M' X3 x0 B4 v) A5 W# p+ {9 r% o. ?! v0 N6 E( v, [! G* w& r7 W/ p! U1 g" W# |. Z. E1 V0 D+ w8 B. q- a8 y: {7 L; @4 ~2 X3 E( f7 w7 }. F" P, E; _
杆件
序号
φi° aimm dimm 零位偏差
Δθi°
1  -901  001  9985   24
2  9005  002  15138  -205
3  90  -001  4486  -15
4  -899  -003  1011   22
5  -9005  001  3522   12
6  8935  0005  9975  -18
7  0  0  15025   0
; G3 l0 }0 {8 H8 A2 [- U! F: i

% F+ M1 O; k6 k/ W- X% S" j

: x$ N; D: |- |& X! M9 i$ z$ _9 N9 C/ M8 R( c2 }7 l' N4 z- y( t$ `# ]: k
  在验算中,对标定算法重复进行了三次仿真计算。每次随机选取3组关节转角组合,根据表1中的结构参数和关节零位偏差,按式(4)计算出3个标准(实际)的空间坐标矢量。同时,不考虑零位偏差,计算出3个理论坐标矢量,并得到相应的误差矢量。根据式(5)、(6)、(7),可得到9个误差方程。利用式(8)求解出6个关节零位偏差值。为了获得更准确的数据,采用迭代算法,将计算出的关节零位偏差值代入式(4)修正理论模型,重复以上过程,直到空间位置误差小于一设定值(这里设为03mm)。三次仿真计算的结果列于表2 5 A/ `+ _4 t7 x; m; R& f

2 仿真验算结果

; j+ e" Q3 w: a5 U9 R4 E
1 g T! ?' R: M# W T P1 X9 b' E6 |& K4 _6 Q1 A' g1 K7 z9 h1 d3 r B4 v L G8 }/ T- n! b( h$ u; z- X6 ^+ U; e0 _! D6 Z; K( b, K; U) B# c( T1 M4 X9 s/ L# W+ n' ^! g& }2 u2 ~9 C8 z* b: I8 @+ J1 r9 X' `+ ` H# X6 S) i2 N3 }) J6 L2 c1 W/ W I7 T7 E7 A+ G4 Y" e) D1 v$ c" g% t* Z* v2 x8 \5 i- ?/ N$ b+ [5 v/ `* L O5 P$ V' j( ^) B: @# s$ w) z" ]4 J3 K7 L5 B+ }+ Y& R$ [/ Z2 f4 y) Y8 t1 y, J- W. Q+ j7 T+ N# @/ T. I* _1 r, W% b+ `5 s9 o2 H! }) Y9 ]/ N l% C* C. H( d. u1 \ z3 h5 M6 ?4 i' b! d" s6 D; z J* ]: V! h' H" P3 X3 Z" b; W& E2 P+ r3 j( M6 p! j5 Y: h" e9 D/ d' p6 `/ Q; h/ r) r" O, A( G# Z& Z0 D1 H* h: A; F0 s% {- V3 `: ^2 w2 j! o m2 N" [- y+ y) a/ `$ G6 `5 v0 m2 ]+ P0 {5 G3 o' _' p2 t$ G) P, b) a, Z$ `# u& B. z# n/ R1 {6 E, {" G d% _) Y8 l7 B* U, b/ a3 R: u: U" O: X6 A3 p+ J; W' W+ P; f! g8 Z- M3 S2 {. i9 @% o! P9 E7 k2 @* {% `4 n- {, s _8 K- @, S; \3 w4 x* }' y9 v' v! N5 E* n* \6 e( p: H$ s* R4 K& k5 F2 T) U1 V: \0 ~$ R! z7 R9 `& X7 V# { k6 `4 [9 ~- r2 [# R& ]/ L- W0 f- ]! U8 e0 ~; ]( u" J! \) q- v8 c( l: G7 H0 n2 @: ~) \2 P: v4 L5 C* m3 o- N: _, s; W9 g, @8 N4 _; n% N; n% B- V3 L1 N, `6 ]; ~3 l, p% G3 I2 W. J* M9 K" @' @9 j2 P1 e4 K6 n N& z% q0 ?1 n9 l$ F5 T, v, Y7 Y5 i4 z# f& A$ e/ s& I, Z* _/ A: I. L+ G& Z* \' Z) d# v& K1 ^% x Y3 b- O1 ^9 Y9 r+ `0 u" e7 D& B* u; L, f0 v5 @8 }. A6 I/ k7 ?9 T2 z4 l" W+ t7 q& O G+ j3 W$ a1 D5 i9 h" @- A$ ~: Q0 x4 n- Q( j* @5 B, Y( B. g# ^; F" i/ w Q' B& l5 p: c: I& V/ h" i& G. A* a1 B: D7 ~& r, v# t' e- E# p) s7 @& t5 ~2 V' G1 s6 L" W. ~3 S1 A* }! F+ n3 L! m, C; Y) D) j- U* B/ o* b) H) X) F$ M9 D9 p5 |; C* K+ x) |4 t* u* |$ J& |& z+ S% t4 v9 ]) @8 B0 v5 g' Q! a" @4 [2 x* b! p2 @# [3 Y% X" }9 }( b* B. H& t& I& f* t) I! Q8 E% ~" h1 {! ` @3 w: b% z( Y- j- o4 y9 I7 m1 j0 u( }8 Z( l) s8 d% z0 `( l6 i, _6 D, e% f+ \" u7 O' I9 r' t9 C, l2 r: J( z2 @1 |7 X0 Y! ]2 z* B. V0 N1 F: a: n2 ?9 f7 ]1 g2 ?! M# {3 O" Y$ B1 ~5 M4 E+ g+ ~8 l! i a% r% z5 E. y6 y( b8 F' o# n5 X% k! Y$ I) X. G! T9 Y" o! @8 B# W& o2 L; Z1 C3 s2 \: m5 P, A& Y4 C6 R4 q3 I8 v/ D3 f3 ]# D3 @5 i3 v# }$ f: _. ?8 w$ Q- Y$ m) X/ ^; J- F- S+ y2 M H/ m4 T! `* `6 e4 X; C' b9 [5 g% g- N' u+ T' |# C7 W7 `8 r/ d' F1 z8 W* {, r8 B+ _* ]9 \/ }" t/ s" X! i) H F5 ?3 }! M$ u$ o# Z& i6 [6 M4 x4 L' y# y% `2 L0 {( x/ R- `" b- N, _5 |! \+ y5 \+ V% ?( A: p- W+ h9 H! q4 s' X5 P( Y2 n' ]1 g o" P5 Y8 O4 l9 Z3 S4 V& Q0 }. @. j( C$ ~" c6 A' P, ?& m0 n& ]" V; O* O) K. K% L6 k0 h4 R4 B4 y& A" ^9 f, w3 m& g! o" f" }3 A' u7 a9 w' m+ ~* _/ U2 O5 L# m4 c# {- L9 o$ ?; q- B- I, c" f3 n+ y) w: \- z/ p J+ D' ?8 R5 [3 O, [0 j- a7 s0 r* s' s3 h X h4 U/ V& X$ w- f
仿真
次数
关节转角组合
(θ1,…,θ6
°
标准坐
标矢量
mm
位置
误差
mm
迭代1 迭代2 迭代3 迭代4
零位
误差
°
位置
误差
mm
零位
误差
°
位置
误差
mm
零位
误差
°
位置
误差
mm
零位
误差
°
位置
误差
mm
1 -90-90090
090
138558
575
782
-283
282
39968 2406
-2
063
-1
432
2
177
1
776
-1
375
1717 2406
-2
063
-1
490
2
177
1
719
-1
776
1483 2406
-2
063
-1
490
2
177
1
203
-1
776
0148 2406
-2
063
-1
492
2
182
1
203
-1
781
0146
12090120-20
7050
-652092
645
842
202
687
30043 1201 1 C- J1 @$ h' {" U9 x+ Y c; [0955 " L* b8 N0 Y$ \6 h- o0206 7 D1 e& t& B& p- [" \" K/ v2 X' L 0206
-900090
00
14257
522
883
503
83
49592 0732 0801 0244 0232
2 -90101090
1010
61557
434
09
594
691
49319 2521
-1
948
-1
432
2
464
1
146
-1
261
1479 2406
-2
063
-1
490
2
181
1
203
-1
781
0212        
0900-90
090
32085
157
437
-251
305
23654 1155 % C. x& g2 N- G) R% d- n0230 < 6 b3 r9 R0 @( Z2 v" r: p <    
-1201402060
10150
-148998
-518
998
-237
442
3930 2176 0082    
3 50-805040
-6040
-463903
-760
076
176
659
7357 2349
-2
120
-1
432
2
292
1
146
-1
432
0603 2406
-2
063
-1
490
2
180
1.203
-1
781
0068        
108030150
30140
186165
160
292
290
97
26475 0894 2 j5 O# u! f4 `* Y& d; V 0069 < . c! r7 R9 m( t* P4 o- _/ `! R<    
403060150
90-90
17932
102
388
101
179
17161 0898 0122    
. ^' F5 k) I3 J/ E7 @7 P

6 q6 v s) _8 Y- G [

6 ]+ L' d2 e7 b$ U O" R. d* V: j# I8 f% c$ _5 i$ X A/ g# ^8 v/ `+ `: e8 |- }7 M9 K- M
8 J1 g( W" Y, e, X! ^ d2 Y. ?& y3 y

  由仿真验算结果可得出以下结论:
  (1)较小的关节零位偏差会引起很大的测头位置误差,最大可达7357mm
  (2)本文给出的标定算法是正确的,经标定得出的关节零位偏差值与设定的真值近似,最大误差为002°
  (3)迭代算法是收敛的,一般不超过4次迭代;
  (4)三次仿真计算所得结果相同,说明只要在测量空间任取三点,即可准确且唯一地标定出6个关节零位偏差。

; j1 k) }$ c9 m4 ]2 a/ ?- N

  5.结语

2 I1 I; U; F1 ~ s3 S' B

  本文在Denavit-Hartenberg方法基础上,建立了六自由度关节式坐标测量机的数学模型。从模型可以看出,测头末端位置坐标与六个关节角度之间的关系是非线性的,这对于由已知空间坐标值来推算关节零位偏差是相当困难的。因此,我们运用全微分方法,求得了关节零位偏差与测头末端位置误差之间的线性关系,从而大大简化了标定过程。在已知空间点坐标情况下,应用最小二乘法和有限次数的迭代运算,求出最优的关节零位偏差值。最后,通过计算机仿真验算,证明了该算法的正确性。该标定算法也完全适用于其它结构参数误差的标定。该标定算法对提高六自由度关节式坐标测量机的测量精度具有重要意义。

, a/ n* X/ q0 o0 \" j2 T
您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

中国磨床技术论坛
论 坛 声 明 郑重声明:本论坛属技术交流,非盈利性论坛。本论坛言论纯属发表者个人意见,与“中国磨削技术论坛”立场无关。 涉及政治言论一律删除,请所有会员注意.论坛资源由会员从网上收集整理所得,版权属于原作者. 论坛所有资源是进行学习和科研测试之用,请在下载后24小时删除, 本站出于学习和科研的目的进行交流和讨论,如有侵犯原作者的版权, 请来信告知,我们将立即做出整改,并给予相应的答复,谢谢合作!

中国磨削网

QQ|Archiver|手机版|小黑屋|磨削技术网 ( 苏ICP备12056899号-1 )

GMT+8, 2025-3-1 10:17 , Processed in 0.385959 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表