XY Interpolation Algorithms

Download as pdf or txt
Download as pdf or txt
You are on page 1of 4
At a glance
Powered by AI
The document describes algorithms for approximating diagonal lines and circular motion using discrete XY steps from a microcomputer. Linear interpolation and circular interpolation algorithms are presented that require no trigonometric functions.

The linear interpolation algorithm uses the sign of the difference between the current position and the endpoint to determine the direction of each step. The circular interpolation algorithm uses the sign of the function FXY to determine whether a step in the X or Y direction is needed to approximate the circle.

The linear interpolation algorithm steps along the line by subtracting or adding the differentials from the running sum FXY. The circular interpolation algorithm steps around the circle by tracking the sign of FXY and taking steps perpendicular to the radius in the appropriate quadrant.

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: )

situation,these values would

be

B>steer STEER:
: GOI

A NUHERICAL

CONTROL 'GOI

PROGRAM

transferred to.stepper motors or a


Input Command
graphic display.

line
300

(ie,

(O,O,lO,20)

100')

(O,O,3,-7)

Linear imating in two plished

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

tool to(0,0). This effectively sets


the current tool position to the starting point. Set the step count number to zero. 3. Calculate the direction in which to move the tool. When following a straight line from one point to another, all X motion is in the same direction, asisall Y motion. The direction is determined by the sign of the difference (DX and DYj between the ending and the starting positions. DX=X3- Yl. DY = Y3 -Yl. 4. Calculate the difference between the absolute values of DX and DY. This determines FXY, a variable which is used to control the movements along the X and Y axes. FXY=\DX!-jDY\. 5. Generate output pulses to move the tool until the endpoint is reached. This is the heart of the program. The proportionate stream ofXY pulses is generated by manipulating variable FXY. Each time a 24
ROBOTICS AGE May/June 1983

are generated

B>steer STE8R:

A UUM8RICAL CONTROL PROGRAM

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

"G03 (50, 0,0,50)

100"

Figure 1. A portion of a circular path generated by only xy movements.

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

,...---

You might also like