XY Interpolation Algorithms
XY Interpolation Algorithms
XY Interpolation Algorithms
Kenneth and Melvin Goldberg 3913 Pine Street, Apt. F Philadelphia, Pennsylvania 19104
A microcomputer can be used to control the motion of numerical control machines. This article describes a straightforward method for approximating diagonal lines and circular motion on an XY plane. Many numerical control machines are powered by stepping motors. When a pulse is sent to a stepping motor, the stepping motor alters its position by a unit step. Two motors can be used to control the XY movements of an arm or tool over a working plane. If the pulses are generated by a device which can remember or generate a specified train of pulses, repetitive operations such as grinding, painting, or cutting can be performed hundreds of times with virtually no variation. A microcomputer is an obvious choice to generate and remember the pulses. Since stepper motors can move only in discrete steps, we must approximate the actual curve by a series of small XY motions. Many algorithms rely upon parametric functions such as sine and cosine to perform the necessary calculations. Parametric functions, however, typically require a high degree of numeric precision. Calculating sine aild cosine values with a microcomputer can be too time-consuming to be useful in a realtime application. The following two algorithms require no parametric functions. This makes them ideally suited to the computation and memory capacities 22
ROBOTICS AGE MaY/June 1983
of microcomputers. Since these algorithms do not require a large amount of complex mathematical calculation, they are fast enough to be used in real-time applications. The program shown in listing 1 is written
Listing 1.
1 2: 3:
in C for fast execution, portability, and ease of modification. The program, as shown, does not actually control any stepping motors; rather, it provides a screen display consisting of + 1, -1, and O.In an actual control
f********************************************************f
f* f* PROGRAt1 STEER
*f (C)M.M. and K.Y. GOLDBERG *f Control Program uses linear *f 5: f* interpolation to provide a flow of output *f 6: f* pulses which can be used to steer an xy table *f 7: f**********************************************************f 8: #include <bdscio.h> f* micro 'c' function package *f 9: 10: char templ[5],temp2[5],temp3[5],temp4[5],temp5[5], 11: char eia[lO], 12 : int feedrate,drag,oil, f* vars dealing with feedrate and delay func. *f 13: int xl,yl, f* starting point *f 14: int x2,y2, f* relative position *f 15: int x3,y3, f* endpoint *f 16 : int xo,yo, f* direction of output: +1, -I, or 0 *f 17: int dX,dy, f* differentials of x and y *f 18: int stepnum, 19 : int fxy, f* value of function *f 20: 21: int rad,radrad,f,a,b,d, 22: main(argc,argv) 23: int argc, 24: char *argv[], 25: [ 26 : printf (" STI3ER: A llUMr::RICALCONTROL PROGRAM\n"), 27: printf("\nInput Command line (ie, 'GOl (0,0,10,20) 100')\n: "), 28: scanf ("%s (~s, %s, %s, %s) %s", eia, tempI. temp2, temp3, temp4, tempS) 29 : feedrate ~ atoi(temp5), 30: xl ~ atoi(templ), 31: yl ~ atoi(temp2), 32: x3 ~ atoi(temp3), 33: y3 ~ atoi(temp4), 34: 35: if ( ! strcmp (eia, "GOI " ) ) doline () , 36: else docircle(), . 37 : 38: ] 39 : 40: dOline() f* interpolates impulses for a straight line *f 41: [ 42: printf("\n\nFor EIA code '%s' with feedrate ~d",eia,feedrate), 43 : printf("\nGoing from (%d,%d) to (%d,%d):\n",xl,yl,x3,y3), 44: 45: stepnum ~ x2 y2 fxy ~ 46: drag ~ 100, oil ~ 1, setdirection(), 47: 48: printf("\nStep\tFXY\tX2\tY2\t\tXO\tYO"), 49: while ( (x2 !~ dx) II (y2 I~ dy)) f* at endpoint? *f 50: ( 51: delay(), 52 : printf("\n%d\t%d\t%d\t%d\t\t",stepnum++,fxy,x2,y2), 53: if(fxy > 0)
4: f*
This Numerical
0,
54: ( printf("ld",xo); ++x2, fxy = fxy - dy, ) 55: else 56: [ printf("\tld",yo), ++y2; fxy = fxy + dx; ) 57: 58: 59: ) 60: 61: setdirection() /* sets output directions and initial fxy value for line */ 62: ( 63: dy = y3 - yl, 64: if(dy < 0) yo = -1; 65: else yo = 1; 66: dy = abs(dy); 67: 68: dx = x3 - xl, 69 : if(dx < 0) xo = -I, 70: else xo = I, 71: dx = abs(dx); 72: 73: fxy = dx - dy, 74: ) 75: 76: docircle() /* Circle Routine */ 77: [ 78: stepnum = A, 79 : x2 = xl, y2 = yl, 80: d = x3, rad = y3, 81 : radrad = rad * rad; 82 : 83: printf("\n\nFor EIA code 'Is' with feedrate = %d",eia,feedrate), 84: printf("\nCircling from (ld,ld) in direction Id with radius Id:", 85: xl, yl ,d, rad) , 86 : 87: a b d xo yo\n"), printf("\nStep\tx2\ty2\tradius\tfxy\tdx\tdy\tf do 88 : 89 : ( 90: delay(), 91: fxy = (x2*x2) + (y2*y2) - (radrad), 92: dx = 2*x2, 93: dy = 2*y2, 94: f = (fxy < 0) ? a : 1; 95: a = ( dx < 0) ? a : 1i 96: b = ( dy < 0) ? a : I, 97: 98: getdir( ) , 99 : 100: Id printf("\n%d\tld\tld\tld\tld\tld\tld\t%d Id Id Id %d", 101: stepnum++,x2,y2,rad,fxy,dx,dy,f,a,b,d,xo,yo), 102: 103: x2 = x2 + xo, 104: y2 = y2 + yo; ) 105: 106: whllex2 != xl) II (y2 1= yl), 107: 108: ) 109: 110: Ill: delay() /* delay loop: feedrate approx = # steps/minute */ 112: ( . 113: int i,i = 0; 114: while (++i != feedrate + drag) / 30continue, 115 : if(drag > 0) /* drag increases the delay at the beginning */ 116: /* to allow for inertia in machine startup */ 117: { 118: drag = drag (oil * oil); /* falls off exponentially */ 119 : --oil,if (drag < 0) drag = 0; 120: ) 121: ) 122: 123: 124: getdir() /* creates 'mock' binary representation of d,f,a,b */ 125: /* and uses this to determine best output */ 126: ( 127: int binrep, 128: binrep = A' 129: xo = yo = 0, 130: if(d)binrep = binrep + 8; 131: if(f)binrep = binrep + 4, 132: if(a)binrep = binrep + 2, 133: if(b)binrep = binrep + I, 134: 135: switch(binrep) 136: ( 137: case 0: yo = -1 ;break, case 1: 138: xo = -1 ,break, 139 : case 2: xo = 1 ;break; 140: case 3: yo = 1 ;break; 141: case 4: xo = 1 ,break, case 5: 142: yo = -1 ,break, 143: case 6: yo = 1 ,break, 144: case 7: xo = -1 ,break; case 8: 145: xo = -1 ,break, 146: case 9: yo = 1 ,break; 147: case 10: yo = -1 ,break, case 11: 148: xo = 1 ,break; case 12: 149: yo = 1 ,break; case 13: 150: xo = 1 ,break, case 14: 151: xo = -1 ,break, 152: case 15: yo = -1 ,break, 153: ) 154: )
be
B>steer STEER:
: GOI
A NUHERICAL
CONTROL 'GOI
PROGRAM
line
300
(ie,
(O,O,lO,20)
100')
(O,O,3,-7)
Interpolation. Approxdiagonal lines with unit steps dimensions can be accomwith the following algorithm.
For EIA code 'GOl' with feedrate Going from (O,O) to (3,-7): Step 0 1 2 3 4 5 6 7 8 9 FXY -4 -1 2 -5 -2 1 -6 -3 0 3 X2 0 0 0 1 1 1 2 2 2 2 Y2 0 1 2 2 3 4 4 5 6 7
= 300 XO 1 -1 -1 1 -1 -1 -1 1 YO -1 -1
1. Define the starting position (Xl,Yl) and ending position (X3,Y3). Define the feed rate (f). Feed rate is the speed at which the tool being controlled moves. The Electronic Industries Association (ElA) recommends the following notation for linear interpolation:
Gal (Xl, Yl, X3, Y3) f
Table 1. A sample program run which draws a line between points (0,01 and (3, -71. The tool moves with a feed rate of 300.
D 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 Table 2. The 16 possible tion algorithm. arrangements 1:= 0 0 0 0 1 1 1 1 0 0 0 0 1 1 1 1 DX 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 of values DY 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 which xwr 0 -1 1 0 1 0 0 -1 -1 0 0 1 0 1 -1 0 YOU'l' -1 0 0 1 0 -1 1 0 0 1 -1 0 1 0 0 -1 by the circular interpola-
where Xl,Yl is starting position X3,Y3 is ending position f is feed rate 2. Initialize variables. Set the current relative position (X2,Y2) of the
are generated
B>steer STE8R:
Input Command line (ie, 'GO1 (0,0,10,20) 100') : G03 (25,0,0,25) 100 For EIA code 'G03' with feedrate = 100 Circling from (25,0) in direction 0 with radius 25: dx radius dy x2 y2 fxy Step 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 25 24 24 24 24 24 24 24 24 23 23 23 23 22 22 22 21 21 21 20 20 19 19 19 18 13 0 0 1 2 3 4 5 6 7 7 8 9 10 10 11 12 12 13 14 14 15 15 16 17 17 18 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 25 0 -49 -48 -45 -40 -33 -24 -13 0 -47 -32 -15 4 -41 -20 3 -40 -15 12 -29 0 -39 -8 25 -12 23 50 48 48 48 48 48 48 48 48 46 46 46 46 44 44 44 42 42 42 40 40 38 38 38 36 36 0 0 2 4 6 8 10 12 14 14 16 18 20 20 22 24 24 26 28 28 30 30 32 34 34 36
f 1 0 0 0 0 0 0 C1 1 0 0 0 1 0 0 1 0 0 1 0 1 0 0 1 0 1
a 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
xo -1 0 0 0 0 0 0 0 -1 C1 0 0 -1 0 0 -1 0 0 -1 0 -1 0 0
yo
1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0
0 1 1 1 1 1 1 1 0 1 1 1 0 1 1 0 1 1 0 1 0 1 1 -1 0 1 0 -1 0
Table 3. Output generated by the circular interpolation algorithm for a circular curve.
step is taken in the X direction, the absolute value of DY is subtracted from FXY. When FXY becomes negative, a step is taken in the Y direction, and the absolute value of DX is added to FXY. The sign of FXY determines the appropriate step needed to approximate a straight line. 6. A delay loop controls the feed rate. This loop may include extra delay for the initial steps. "Ramping up" the feed rate in this manner is useful in real-world situations where the inertia of a machine may have a significant effect on the system.
50
40
30
20 Table 1 shows the output generated when a starting point of (0,01,an ending point of (3, -71, and a feed rate of . 300 are given to the program shown in listing 1. 10
Circular Interpolation. A conceptually similar nonparametric algorithm can provide the necessary XY steps for approximating a circular path. The equation for a circle is:
40
50
FXY=XZ + yz - RZ FXY =positive when (X,Y)is outside circle a when (X,Y) is on circumference negative when (X,YI is inside circle DX =2X DY = 2Y The variable FXY determines the direction in which the tool is moved at each point on the circle. The motion is always perpendicular to the instantaneous circular radius. The tangent to a circle is always perpendicular to the radius. The X and Y components of the radius are defined by the partial derivatives of FXY. We propose to step the machine tool around the circle by comparing the current tool position to the ideal radius. .We perform this comparison by tracking the value of FXY. We know that the tool has crossed the circumference and must be corrected
100"
when the sign of FXY changes. The appropriate correction (:t X, :t Y) depends on the quadrant in which the tool is located. This algorithm's simplicity lies in the fact that the only information required to determine the proper output is the sign of FXY, its derivatives, and the direction of rotation. (0= clockwise, 1= counterclockwisel. If we denote positive by 1 and negative by 0, then we can organize the 16 possible combinations of values as shown in table 2. Table 3 shows the output generated for a typical circular approximation. Figure 1 demonstrates the raggedness found in part of an enlarged path of a typical circle. The raggedness is greatly decreased in largediameter circles. With a radius of
1000 steps, a circle will appear smooth to the naked eye. Summary. These two examples demonstrate that regular figures can be approximated by simple, nontrigonometric algorithms. The algorithms presented here can be extended to other forms such as an ellipse. The examples also show that the best approach to a real-world problem may well be an approximate arithmetic solution, rather than a mathematically precise solution.
Acknowledgements The authors are indebted to Frank Francisco for program assistance, Alan Krigman of ICON Information for providing hardware facilities, and to Eric Gray for supplying a typewriter. ROBOTICS AGE May/June 1983 ,25
,...---