EP0436002A4 - A system for performing linear interpolation - Google Patents

A system for performing linear interpolation

Info

Publication number
EP0436002A4
EP0436002A4 EP19900911465 EP90911465A EP0436002A4 EP 0436002 A4 EP0436002 A4 EP 0436002A4 EP 19900911465 EP19900911465 EP 19900911465 EP 90911465 A EP90911465 A EP 90911465A EP 0436002 A4 EP0436002 A4 EP 0436002A4
Authority
EP
European Patent Office
Prior art keywords
function
value
function value
odd
domain
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.)
Withdrawn
Application number
EP19900911465
Other versions
EP0436002A1 (en
Inventor
Gary H. Newman
Steven Smith Mclafferty
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Eastman Kodak Co
Original Assignee
Eastman Kodak Co
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Eastman Kodak Co filed Critical Eastman Kodak Co
Publication of EP0436002A1 publication Critical patent/EP0436002A1/en
Publication of EP0436002A4 publication Critical patent/EP0436002A4/en
Withdrawn legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/17Function evaluation by approximation methods, e.g. inter- or extrapolation, smoothing, least mean square method

Definitions

  • the invention relates generally to the field of computer systems, and more particularly to computation systems for interpolating between known data points.
  • the value of a function at a desired domain coordinate must be approximated from known values of the function at other points in the domain.
  • air pressure the function
  • location comprising the domain
  • the function is assumed to be piecewise linear between adjacent points in the domain, each identified by a domain coordinate value at which the function values are known.
  • the relation of the interpolated value at a target point in the domain that is, the domain coordinate value of the point in the domain at which the function value is to be interpolated, to the function values at the known points at adjacent domain coordinate value is linearly proportional to (1) the desired domain coordinate's relative distance from the known points, and (2) the difference between the values of the function at the two adjacent known points.
  • this is
  • f ( x d ) f ( x ⁇ ) + (X2 I X1 J ( f ( x 2 ) " f i)) ( Equation 1 )
  • f is the interpolated function
  • x-j_ and 2 are the domain coordinate values of the points at which the function values are known
  • x ⁇ is the domain coordinate value at which the function value is being interpolated.
  • the invention provides a new and improved system for generating an interpolated value.
  • the invention provides, in one aspect, an interpolation system that generates an interpolated value in response to an input value.
  • the interpolation system includes a function value store comprising a plurality of function value storage tables for storing function values for alternating domain coordinate values in a domain.
  • An address generator in response to an input value, generates address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel.
  • An interpolator receives function values transmitted in parallel by the function value storage tables and the input value and generating in response thereto the interpolated value.
  • the invention provides a method of generating an interpolated value in response to an input value comprising the steps of providing a plurality of function value storage tables for storing function values for alternating domain coordinate values in a domain; generating address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel; and receiving function values transmitted by the function value storage tables in parallel and the input value and generating in response thereto the interpolated value.
  • FIG. 1 depicts a functional block diagram of a linear interpolation system according to the invention
  • FIG. 2 depicts a block diagram of an address generator useful in the system depicted in FIG. 1;
  • FIG. 3 depicts a block diagram of an interpolation device useful in the system depicted in FIG. 1;
  • FIGS. 4A and 4B depict a two-dimensional domain useful in understanding multi-dimensional interpolation in accordance with the invention
  • FIG. 5 depicts a functional block diagram of a linear interpolation system for performing linear interpolation in a two-dimensional domain.
  • FIG. 1 shows an illustrative embodiment of a linear interpolation system in accordance with the invention.
  • an interpolation block 70 includes two table memories 30 and 32 that store the function values for the known points. These table memories provide known function values along lines 34 and 35 to an interpolation device 36 in parallel in response to ADRS ODD odd address signals and ADRS EVEN even address signal, respectively, from an address generator 38.
  • the address generator 38 receives a high- order portion of XJN signals along lines 12, defining the high order portion of the domain coordinate value of the target point, that is, the point in the domain at which interpolation is to occur, and generates the ADRS ODD odd address signals and ADRS EVEN even address signals which identify storage locations for function values of known points in the table memories 30 and 32, respectively.
  • address generator 38 generates an SEL select signal which is coupled to interpolation device 36 on a line 40, and is used thereby as described below.
  • Interpolation device 36 receives low order JJJ signals on lines 14, which define the low-order portion of the domain coordinate value of the target point, as well as the function values at known points from table memories 30 and 32 on lines 34 and 35, respectively, and the SEL select signal. Interpolation device 36 uses these signals as inputs to compute an interpolated function value f(XJ.N) f° r the domain coordinate value identified by the XJJJ signals.
  • function values of the known points stored in table memories 30 and 32, are provided for each integer domain coordinate value.
  • the function values stored in table 30 are those associated with odd integer domain coordinate values
  • the function values stored in table 32 are those associated with even integer domain coordinate values.
  • the function values in successive storage locations in each table memory 30 and 32 are stored in ascending order of their respective associated domain coordinate values, and so the address of each function value in the table memories is in direct correspondence to the integer part of the domain coordinate of the function value's respective known point.
  • the function values for the know points are distributed between the two table memories 30 and 32. It will be appreciated that, since function values for odd coordinate values are stored in table memory 30 and function values for even coordinate values are stored in table memory 32 when, during an interpolation operation, the function values for two adjacent domain coordinate values are obtained, one from each of the table memories 30 and 32. Since two table memories 30 and 32 are provided, function values can be obtained from the two table memories simultaneously. As a result, the arrangement depicted in FIG. 1 requires less time to obtain the function values for known points than prior systems using a single table memory.
  • table memory 30 provides on line 34 the function value for the odd domain coordinate value proximate the target point, as identified by the XJJ- signals on line 12, at which interpolation is to occur and table memory 32 provides, on line 35, the function value for the even domain coordinate value proximate the domain coordinate value identified by the XJN signals.
  • the SEL select signal indicates whether the domain coordinate value for the function values provided by the table memories 30 and 32 are, respectively, above or below the domain coordinate value defined by the x ⁇ _- signals, to control use by the interpolation device 36 of the signals on lines 34 and 35, as described below.
  • the SEL select signal indicates which of the ADRS ODD odd address signals or ADRS EVEN even address signals correspond to domain coordinate values x ⁇ and x 2 , and which of the values represented by signals transmitted by the table memories 30 and 32 correspond to function values f(x ⁇ ) and f(x 2 ).
  • FIG. 2 An illustrative embodiment of an address generator 38 is shown in FIG. 2.
  • the address generator 38 generates the ADRS ODD odd address signals and ADRS EVEN even address signals to identify storage locations in the two table memories 30 and 32, respectively.
  • the address generator 38 produces the SEL select signal used by the interpolation device 36.
  • the high- order portion for the XJJ- signal which identifies the integer part of the domain coordinate value of the point in the domain at which the function value is to be interpolated, is coupled to address generator 38 along lines 12.
  • the least significant bit of the binary representation of the integer part of the x ⁇ _- signal determines whether the high order portion of the X jn signal has an even or odd value.
  • the least significant bit of the high order portion of the XJN signal indicates whether the domain coordinate value of the target point in the domain, at which the function value is to be interpolated, is just above an even or odd integer domain coordinate value, and so it is coupled onto line 40 as the SEL select signal.
  • the ADRS ODD odd address signals and ADRS EVEN even address signals are functions of the integer portion of the XJN signals on line 12. More specifically, the address signals are both functions of the integer portion of the XJJJ signals, except for the low-order signal which provides the SEL select signal. Since each table memory 30 and 32 stores function values for one- half of the integer domain coordinate values, that is, those domain coordinate values at which function values are known, the values of the ADRS ODD odd address signals and ADRS EVEN even address signals are functions of the greatest integer of one-half of the integer portion of the domain coordinate represented by the xj n signals.
  • the resulting outputs are such that the known point in the domain with the odd integer domain coordinate value has a higher domain coordinate value than the point in the domain having the even integer domain value. Therefore, the address signals generated by the address generator on lines 50 and 52 should represent the same value when the domain coordinate value of the point in the domain at which the function value is to be interpolated lies just above an even integer domain coordinate value.
  • table memory 32 should be addressed with ADRS EVEN even address signals identifying a location whose address is one greater than the address of the location identified in table memory 30 by the ADRS ODD odd address signals.
  • Address generator 38 generates ADRS ODD odd address signals and ADRS EVEN even address signals that satisfy these criteria.
  • the least significant bit of the integer part of the domain coordinate of the desired point indicates whether the known point in the domain with the lower domain coordinate value has an even or odd domain coordinate value. Therefore, this bit also indicates whether the ADRS ODD odd address signals and ADRS EVEN even address signals identify the same storage locations in table memories 30 and 32.
  • address generator 38 the least significant bit of the integer part of the xj_- signals, defining the domain coordinate value of the target point, provides a carry input to a binary adder 46, where the B INP summing input terminal to the adder 46 receives binary zero on lines 48, and the A INP summing input terminal receives the more significant bits of the integer part of the xjtj signals.
  • the least significant bit of the integer part of the desired point can simply control the least significant bit carried on lines 48 at the B INP summing input terminal.
  • the output of the adder 46 provides the ADRS EVEN even address signals generated by the address generator 38, which are used as the address for table memory 32.
  • the more significant bits of the domain coordinate of the desired point, carried on lines 42, are also used as the ADRS ODD odd address signals of the address generator, which is the address for table memory 30.
  • the value of the ADRS ODD odd address signals equals the value of the ADRS EVEN even address signals when the SEL signal is negated. If the SEL select signal is asserted, the value of the ADRS EVEN even address signals is one greater than the value of the ADRS ODD odd address signal.
  • FIG. 3 A functional block diagram of interpolation device 36 is illustrated in FIG. 3. As shown in FIG. 3, the interpolation device 36 receives the function values from the table memories 30 and 32 along lines 34 and 35. Lines 34 have been labeled “odd” to indicate that they carry function values from table memory 30, which contains the function values for the odd domain coordinate values. Similarly, lines 35 have been labeled "even” to indicate that they carry the function values for the even domain coordinate values from table memory 32.
  • Lines 34 and 35 connect to two multiplexers 20 and 22, both of which are controlled in unison by the SEL select signal so that multiplexer 20 couples the function value of the known point whose domain coordinate value is immediately above that of the target point, as identified by the x ⁇ s ⁇ domain coordinate value, onto lines 37 and multiplexer 22 couples the function value of the known point whose domain coordinate value is immediately below the targeted point onto lines 39.
  • Further circuitry comprising a subtractor 24, a multiplier 26 and a second adder 28, generates the function value at the target point, using the function values represented by the signals on lines 37 and 39 and the low order portion of the XJN signals, denoting the fractional portion of the x ⁇ - signals, on lines 14.
  • the known points are at integer domain coordinate values which simplifies the interpolation computation.
  • the difference between the domain coordinates of the known points that is, the value "(xi+i - xi)f" is always equal to "one,” because the domain coordinate values of the known points always lie at sequential integer domain coordinates.
  • the difference between the domain coordinate of the desired point and the domain coordinate of the lower known point indicated by the expression "( IN * ⁇ xi)" *-- n the equation is simply equal to the fractional part of the domain coordinate value of the target point, which, in turn, corresponds to the low order portion of the XJ J signals on lines 14.
  • the calculation circuitry comprising subtractor 24, multiplier 26, and adder 28, in the interpolation device 36 evaluates the expressions in the portion of the interpolation equation illustrated at the lower right of FIG. 3.
  • subtractor 24 provides the difference of the function values at the known points, as indicated by the expression labelled 24 in the equation.
  • Multiplier 26 multiplies this difference by the fractional component of the domain coordinate value of the target point (represented by the signals carried on lines 14), as indicated by expression labelled 26 in the equation.
  • adder 28 provides the sum of the product generated by multiplier 26 and to the function value at the known point having the lower domain coordinate value in the domain, as indicated by expression labelled 28 in the equation, thereby providing the interpolated value for the target point represented by x ⁇ - signals.
  • the values for the known points may be stored in content addressable memories (CAMs).
  • CAMs content addressable memories
  • the table memories 30 and 32 store both the domain coordinate values and function values for the known points.
  • the function values for the known points can then be accessed using the domain coordinate value of the desired point.
  • the benefits of using CAM's include the facts that (1) the domain coordinate values for the known points need not lie on integer values and (2) the differences between domain coordinate values need not be uniform. If the differences between the domain coordinate values are uniform, but not "one," the value as produced by adder 28 (FIG. 3) of the interpolation device 36, may be divided by the difference to produce the actual interpolation value. On the other hand, if the difference is not uniform, the table memories may couple the domain coordinate values to the interpolation device 36, which may determine the difference to be used in the division.
  • the locations of the points in the domain at which the function values are known form a two dimensional grid in a two-dimensional domain denoted by axes x and y.
  • the value of the function at the target point is determined by interpolation from function values at the four nearest known points, which form corners of a rectangular grid "window" in which the target point lies.
  • the target point S- is projected onto two of the lines 26 defined by the grid of points at which the function values are known.
  • the resulting projection points are identified as points s i and sp .
  • a value for the function at these projections s i and sp 2 can be calculated by a one dimensional interpolation system, such as described above in connection with FIGS. 1 through 3, using the pairs of known points sn and s ⁇ , s ⁇ and s , respectively.
  • the two projection points spi and sp can be treated as known points in a one- dimensional domain coordinate system defined by the line between points spi and sp 2 , on which point s d lies.
  • the two projections are collinear with the desired point, and thus the value of the function at the desired point S ([ can be calculated by one-dimensional interpolation methods, using the calculated values for the function at the projection points spi and sp 2 .
  • FIG. 5 shows a circuit for performing interpolation in a two-dimensional coordinate domain according to the invention, in connection with x ⁇ _- and y ⁇ - signals which identify the domain coordinate values, along the x and y axes respectively, for the target point.
  • the circuit includes two one-dimensional interpolation blocks 70(ODD) and 70(EVEN), both corresponding to interpolation block 70 (FIG. 1).
  • Each block 70(ODD) and 70(EVEN) stores in its table memories (not shown) the function values for the known points in the coordinate domain along alternating lines 26 as depicted in FIG. 4A.
  • fractional signal x ⁇ - and the integer portion of y ⁇ _- signal are coupled to the one-dimensional interpolation blocks 70, each of which provides the function values for one of the projection points spi and sp .
  • the outputs of the two one-dimensional blocks 70 are coupled to an interpolation device 36, along with the fractional portion of the y ⁇ _q signal, which provides the function value for the target point.
  • the two one-dimensional interpolation blocks 70 include table memories (not shown in FIG. 5) that provide function values for points on alternating lines in the two-dimensional domain. That is, assuming the function values are provided along parallel lines, which are parallel to the x-axis, as shown in FIG. 4A, and which intersect the y-axis at integral points along the y-axis, the one-dimensional interpolation block 70(ODD) includes table memories. corresponding to table memories 30 and 32 (FIG.
  • the other interpolation block 70 includes table memories, also corresponding to table memories 30 and 32, which provide function values along lines which intersect the y-axis at even points along the y-axis.
  • the table memories 30 and 32 in the interpolation block 70(ODD) stores function values at known points along a line stored therein in a set of successive memory locations, with function values along the successive lines being stored in successive sets of memory locations in the respective memories.
  • the table memories 30 and 32 in the interpolation block 70(ODD) are both addressed in response to portions of the integer portion of the x ⁇ -_- input signals and the integer portion of the y ⁇ _ input signals.
  • the address signals are generated by an address generator 38(x), which generates address signals in response to the x ⁇ _- signals and an address generator 38(y), which generates address signals in response to the yjjj signals, with both address generators 38(x) and 38(y) being the same as address generator 38 (FIG. 1).
  • Each of the address generators 38(x) and 38(y) generate even and odd sets of address signals; in particular, the address generator 38(x) generates address signals X ADRS ODD odd address signals and X ADRS EVEN even address signals, both along the x-axis, and address generator 38(y) generates address signals Y ADRS ODD odd address signals and Y ADRS EVEN even address signals, both along the y-axis.
  • the table memories 30 and 32 in the interpolation blocks 70(ODD) and 70(EVEN) are addressed by address signals formed by various concatenations of the X ADRS ODD, X ADRS EVEN, Y ADRS ODD, and Y ADRS EVEN signals produced by the address generators 38(x) and 38(y).
  • the table memory 30 (reference FIG. 1) in the interpolation block 70(ODD) which stores function values, at successive points, which have odd x-axis coordinate values, along successive lines which have odd y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS ODD odd x- axis address signals onto the low-order end of the Y ADRS ODD odd y-axis address signals.
  • the Y ADRS ODD odd y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 30 (reference FIG. 1), while the X ADRS ODD odd x-axis address signals identify a particular point on the line, and thus a particular memory location, in the set identified by the Y ADRS ODD odd y-axis address signals, which stores the function value for the point.
  • the table memory 32 (reference FIG. 1) in the interpolation block 70(ODD), which stores function values, at successive points, which have even x-axis coordinate values, along successive lines which have odd y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS EVEN even x-axis address signals onto the low-order end of the Y ADRS ODD odd y-axis address signals.
  • the Y ADRS ODD odd y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 32, while the X ADRS EVEN even x-axis address signals identify a particular point on the line, and thus a particular location, in the set identified by the Y ADRS ODD odd y- axis address signals, which stores the function value for the point.
  • the table memory 30 (reference FIG.
  • the interpolation block 70 which stores function values, at successive points, which have odd x-axis coordinate values, along successive lines which have even y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS ODD odd x- axis address signals onto the low-order end of the Y ADRS EVEN y-axis address signals.
  • the Y ADRS EVEN even y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 30 (reference FIG. 1), while the X ADRS ODD odd axis address signals identify a particular point on the line, and thus a particular location, in the set identified by the Y ADRS EVEN even y-axis address signals, which stores the function value for the point.
  • the table memory 32 (reference FIG. 1) in the interpolation block 70(EVEN), which stores function values, at successive points, which have even x-axis coordinate values, along successive lines which have even y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS EVEN even x- axis address signals onto the low-order end of the Y ADRS EVEN even y-axis address signals.
  • the Y ADRS EVEN even y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 32 (reference FIG.
  • the four sets of address signals generated by the concatenation of the X ADRS ODD odd x-axis address signals, X ADRS EVEN even x-axis address signals, Y ADRS ODD odd y-axis address signals, and Y ADRS EVEN even y-axis address signals, as described above, identify the four points in the domain proximate the target point at which the function points are known. As in the embodiment, depicted in FIG.
  • the address generators 38(x) and 38(y) generate, respectively, SEL X and SELy select signals that indicate whether the odd- and even-valued domain coordinates are greater and less than the domain coordinate values of the target point, as represented by the XJJJ and y ⁇ _- signals, respectively.
  • the interpolation blocks 70(ODD) and 70(EVEN) generate the interpolated values for the projection points spi and sp 2 .
  • An interpolation device 36 which is identical to that depicted in FIG. 3, receives the interpolated values from the interpolation blocks 70(ODD) and 70(EVEN) and uses them, along with the SELy select signal and the fraction portion of the yiN signals, to generate an interpolated value for the target point.
  • the SELy select signal indicates which of the projection points spi and sp 2 is associated with the interpolated value produced by the interpolation block 70 (ODD) and 70(EVEN).
  • the invention can.be extended to provide interpolated values for higher-dimensional domains in a similar manner.
  • the target point defined by a coordinate x ] $ , y ⁇ n r and zjN, may first be projected, along a line parallel to the z-axis, onto two parallel planes at, for example, integral locations along the z-axis.
  • Each of the planes ay define sets of lines, parallel to the x-axis, which intersects the y-axis at integer locations along the y- axis, which each line containing points, at integer locations along the x-axis, at which the function values are known.
  • An interpolation circuit includes two two- dimensional interpolation blocks, similar to that shown in FIG. 5, with the addition that each of the table memories includes additional sets of memory locations for each of the planes, and the memories are thus also addressed by Z ADRS ODD odd z-axis address signals and Z ADRS EVEN even z-axis address signals provided by an address generator, substantially similar to the address generator 38 (FIG. 2), in response to an integer portion of the z ⁇ _- signal.
  • An interpolation device receives interpolated values from each of the two-dimensional interpolation blocks, which represent interpolated values in each of the plans parallel to the z-axis, and uses them, the fractional portion of the ZJN signal and SELg select signal to generate the interpolated value. Interpolation in higher-dimensioned domains can be accomplished by a similar extension from successive lower-dimensioned domains.
  • the interpolation method may use a cylindrical, radial, or any other coordinate system.
  • the known points need not be arranged in a grid, rather they may be randomly dispersed. In a one dimensional system, the points need not be evenly spaced. In an n-dimensional system, the sets of collinear points need not form parallel lines or planes.

Landscapes

  • Physics & Mathematics (AREA)
  • Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Computational Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Mathematical Physics (AREA)
  • Theoretical Computer Science (AREA)
  • Algebra (AREA)
  • Databases & Information Systems (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Complex Calculations (AREA)

Abstract

An interpolation system generates an interpolated value in response to an input value. The interpolation system includes a function value store (30, 32) comprising a plurality of function value storage tables (30, 32) for storing function values for alternating domain coordinate values in a domain. An address generator (38), in response to an input value, generates address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel. An interpolator (36) receives function values transmitted in parallel by the function value storage tables and the input value and generating in response thereto the interpolated value.

Description

A SYSTEM FOR PERFORMING LINEAR INTERPOLATION
Field Of The Invention The invention relates generally to the field of computer systems, and more particularly to computation systems for interpolating between known data points.
Background of the Invention In many applications in the fields of computation and numerical analysis, the value of a function at a desired domain coordinate must be approximated from known values of the function at other points in the domain. As an example, air pressure (the function) may be known at a set of locations on the earth ("location" comprising the domain), and from these known pressures, one may wish to determine a value for pressure at other locations. This can be accomplished by the method of linear interpolation.
In linear interpolation, the function is assumed to be piecewise linear between adjacent points in the domain, each identified by a domain coordinate value at which the function values are known. Thus, the relation of the interpolated value at a target point in the domain, that is, the domain coordinate value of the point in the domain at which the function value is to be interpolated, to the function values at the known points at adjacent domain coordinate value is linearly proportional to (1) the desired domain coordinate's relative distance from the known points, and (2) the difference between the values of the function at the two adjacent known points. Stated mathematically, in a one dimensional domain, this is
f(xd) = f(xχ) + (X2 I X1J (f(x2 ) " f i)) (Equation 1) where f is the interpolated function, x-j_ and 2 are the domain coordinate values of the points at which the function values are known, and x^ is the domain coordinate value at which the function value is being interpolated.
In the prior art, interpolation calculations have been performed by electronic computing systems. In these systems, the function values for the known points are stored in a single electronic memory. For each interpolation, this memory must be accessed twice, once to obtain a function value for each of the two known points with domain coordinates adjacent to the domain coordinate at which interpolation is to take place.
Summary of the Invention The invention provides a new and improved system for generating an interpolated value.
In brief summary, the invention provides, in one aspect, an interpolation system that generates an interpolated value in response to an input value. The interpolation system includes a function value store comprising a plurality of function value storage tables for storing function values for alternating domain coordinate values in a domain. An address generator, in response to an input value, generates address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel. An interpolator receives function values transmitted in parallel by the function value storage tables and the input value and generating in response thereto the interpolated value. In another aspect, the invention provides a method of generating an interpolated value in response to an input value comprising the steps of providing a plurality of function value storage tables for storing function values for alternating domain coordinate values in a domain; generating address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel; and receiving function values transmitted by the function value storage tables in parallel and the input value and generating in response thereto the interpolated value.
Brief Description of the Drawings The invention is pointed out with particularity in the appended claims, and may be better understood by referring to the following description taken in conjunction with the accompanying drawings, in which: FIG. 1 depicts a functional block diagram of a linear interpolation system according to the invention;
FIG. 2 depicts a block diagram of an address generator useful in the system depicted in FIG. 1; FIG. 3 depicts a block diagram of an interpolation device useful in the system depicted in FIG. 1;
FIGS. 4A and 4B depict a two-dimensional domain useful in understanding multi-dimensional interpolation in accordance with the invention; and FIG. 5 depicts a functional block diagram of a linear interpolation system for performing linear interpolation in a two-dimensional domain.
Detailed Description of Illustrative Embodiments FIG. 1 shows an illustrative embodiment of a linear interpolation system in accordance with the invention. s can be seen in FIG. 1, an interpolation block 70 includes two table memories 30 and 32 that store the function values for the known points. These table memories provide known function values along lines 34 and 35 to an interpolation device 36 in parallel in response to ADRS ODD odd address signals and ADRS EVEN even address signal, respectively, from an address generator 38. The address generator 38 receives a high- order portion of XJN signals along lines 12, defining the high order portion of the domain coordinate value of the target point, that is, the point in the domain at which interpolation is to occur, and generates the ADRS ODD odd address signals and ADRS EVEN even address signals which identify storage locations for function values of known points in the table memories 30 and 32, respectively. In addition, address generator 38 generates an SEL select signal which is coupled to interpolation device 36 on a line 40, and is used thereby as described below.
Interpolation device 36 receives low order JJJ signals on lines 14, which define the low-order portion of the domain coordinate value of the target point, as well as the function values at known points from table memories 30 and 32 on lines 34 and 35, respectively, and the SEL select signal. Interpolation device 36 uses these signals as inputs to compute an interpolated function value f(XJ.N) f°r the domain coordinate value identified by the XJJJ signals.
In one embodiment, as shown in FIG. 1, function values of the known points, stored in table memories 30 and 32, are provided for each integer domain coordinate value. The function values stored in table 30 are those associated with odd integer domain coordinate values, and the function values stored in table 32 are those associated with even integer domain coordinate values. The function values in successive storage locations in each table memory 30 and 32 are stored in ascending order of their respective associated domain coordinate values, and so the address of each function value in the table memories is in direct correspondence to the integer part of the domain coordinate of the function value's respective known point.
As noted above, the function values for the know points are distributed between the two table memories 30 and 32. It will be appreciated that, since function values for odd coordinate values are stored in table memory 30 and function values for even coordinate values are stored in table memory 32 when, during an interpolation operation, the function values for two adjacent domain coordinate values are obtained, one from each of the table memories 30 and 32. Since two table memories 30 and 32 are provided, function values can be obtained from the two table memories simultaneously. As a result, the arrangement depicted in FIG. 1 requires less time to obtain the function values for known points than prior systems using a single table memory.
That is, table memory 30 provides on line 34 the function value for the odd domain coordinate value proximate the target point, as identified by the XJJ- signals on line 12, at which interpolation is to occur and table memory 32 provides, on line 35, the function value for the even domain coordinate value proximate the domain coordinate value identified by the XJN signals. As described below, the SEL select signal indicates whether the domain coordinate value for the function values provided by the table memories 30 and 32 are, respectively, above or below the domain coordinate value defined by the xχ_- signals, to control use by the interpolation device 36 of the signals on lines 34 and 35, as described below. More specifically, with reference to Equation 1, the SEL select signal indicates which of the ADRS ODD odd address signals or ADRS EVEN even address signals correspond to domain coordinate values x± and x2, and which of the values represented by signals transmitted by the table memories 30 and 32 correspond to function values f(xχ) and f(x2).
An illustrative embodiment of an address generator 38 is shown in FIG. 2. The address generator 38 generates the ADRS ODD odd address signals and ADRS EVEN even address signals to identify storage locations in the two table memories 30 and 32, respectively. In addition, the address generator 38 produces the SEL select signal used by the interpolation device 36. In the address generator 38 depicted in FIG. 2, the high- order portion for the XJJ- signal, which identifies the integer part of the domain coordinate value of the point in the domain at which the function value is to be interpolated, is coupled to address generator 38 along lines 12. The least significant bit of the binary representation of the integer part of the xχ_- signal determines whether the high order portion of the Xjn signal has an even or odd value. Therefore, the least significant bit of the high order portion of the XJN signal indicates whether the domain coordinate value of the target point in the domain, at which the function value is to be interpolated, is just above an even or odd integer domain coordinate value, and so it is coupled onto line 40 as the SEL select signal.
The ADRS ODD odd address signals and ADRS EVEN even address signals are functions of the integer portion of the XJN signals on line 12. More specifically, the address signals are both functions of the integer portion of the XJJJ signals, except for the low-order signal which provides the SEL select signal. Since each table memory 30 and 32 stores function values for one- half of the integer domain coordinate values, that is, those domain coordinate values at which function values are known, the values of the ADRS ODD odd address signals and ADRS EVEN even address signals are functions of the greatest integer of one-half of the integer portion of the domain coordinate represented by the xjn signals.
More specifically, with reference to FIG. 1, in storage location in the table memories 30 and 32 with the same addresses, the resulting outputs are such that the known point in the domain with the odd integer domain coordinate value has a higher domain coordinate value than the point in the domain having the even integer domain value. Therefore, the address signals generated by the address generator on lines 50 and 52 should represent the same value when the domain coordinate value of the point in the domain at which the function value is to be interpolated lies just above an even integer domain coordinate value. However, when the domain coordinate of the point in the domain at which the function value is to be interpolated lies just above an odd integer domain coordinate value, table memory 32 should be addressed with ADRS EVEN even address signals identifying a location whose address is one greater than the address of the location identified in table memory 30 by the ADRS ODD odd address signals. Address generator 38 generates ADRS ODD odd address signals and ADRS EVEN even address signals that satisfy these criteria.
As discussed above, the least significant bit of the integer part of the domain coordinate of the desired point indicates whether the known point in the domain with the lower domain coordinate value has an even or odd domain coordinate value. Therefore, this bit also indicates whether the ADRS ODD odd address signals and ADRS EVEN even address signals identify the same storage locations in table memories 30 and 32. As shown in FIG. 2, address generator 38, the least significant bit of the integer part of the xj_- signals, defining the domain coordinate value of the target point, provides a carry input to a binary adder 46, where the B INP summing input terminal to the adder 46 receives binary zero on lines 48, and the A INP summing input terminal receives the more significant bits of the integer part of the xjtj signals. Alternatively, the least significant bit of the integer part of the desired point can simply control the least significant bit carried on lines 48 at the B INP summing input terminal.
The output of the adder 46 provides the ADRS EVEN even address signals generated by the address generator 38, which are used as the address for table memory 32. The more significant bits of the domain coordinate of the desired point, carried on lines 42, are also used as the ADRS ODD odd address signals of the address generator, which is the address for table memory 30. As will be appreciated by those skilled in the art, in this configuration, the value of the ADRS ODD odd address signals equals the value of the ADRS EVEN even address signals when the SEL signal is negated. If the SEL select signal is asserted, the value of the ADRS EVEN even address signals is one greater than the value of the ADRS ODD odd address signal. These results are tabulated in the table at the bottom of FIG. 2. As can be seen from the above, these provide the necessary addresses for the table memories 30 and 32.
A functional block diagram of interpolation device 36 is illustrated in FIG. 3. As shown in FIG. 3, the interpolation device 36 receives the function values from the table memories 30 and 32 along lines 34 and 35. Lines 34 have been labeled "odd" to indicate that they carry function values from table memory 30, which contains the function values for the odd domain coordinate values. Similarly, lines 35 have been labeled "even" to indicate that they carry the function values for the even domain coordinate values from table memory 32. Lines 34 and 35 connect to two multiplexers 20 and 22, both of which are controlled in unison by the SEL select signal so that multiplexer 20 couples the function value of the known point whose domain coordinate value is immediately above that of the target point, as identified by the xχ~s~ domain coordinate value, onto lines 37 and multiplexer 22 couples the function value of the known point whose domain coordinate value is immediately below the targeted point onto lines 39. Further circuitry, comprising a subtractor 24, a multiplier 26 and a second adder 28, generates the function value at the target point, using the function values represented by the signals on lines 37 and 39 and the low order portion of the XJN signals, denoting the fractional portion of the xχ~- signals, on lines 14. As noted above, the known points are at integer domain coordinate values which simplifies the interpolation computation. Specifically, referring to the equation at the bottom of FIG. 3, the difference between the domain coordinates of the known points, that is, the value "(xi+i - xi)f" is always equal to "one," because the domain coordinate values of the known points always lie at sequential integer domain coordinates. Additionally, for similar reasons, the difference between the domain coordinate of the desired point and the domain coordinate of the lower known point, indicated by the expression "( IN *~ xi)" *--n the equation is simply equal to the fractional part of the domain coordinate value of the target point, which, in turn, corresponds to the low order portion of the XJ J signals on lines 14. Thus, the calculation circuitry comprising subtractor 24, multiplier 26, and adder 28, in the interpolation device 36 evaluates the expressions in the portion of the interpolation equation illustrated at the lower right of FIG. 3. Specifically, subtractor 24 provides the difference of the function values at the known points, as indicated by the expression labelled 24 in the equation. Multiplier 26 multiplies this difference by the fractional component of the domain coordinate value of the target point (represented by the signals carried on lines 14), as indicated by expression labelled 26 in the equation. Finally, adder 28 provides the sum of the product generated by multiplier 26 and to the function value at the known point having the lower domain coordinate value in the domain, as indicated by expression labelled 28 in the equation, thereby providing the interpolated value for the target point represented by x ~- signals.
In an alternative embodiment, the values for the known points may be stored in content addressable memories (CAMs). In that case, the table memories 30 and 32 store both the domain coordinate values and function values for the known points. The function values for the known points can then be accessed using the domain coordinate value of the desired point. The benefits of using CAM's include the facts that (1) the domain coordinate values for the known points need not lie on integer values and (2) the differences between domain coordinate values need not be uniform. If the differences between the domain coordinate values are uniform, but not "one," the value as produced by adder 28 (FIG. 3) of the interpolation device 36, may be divided by the difference to produce the actual interpolation value. On the other hand, if the difference is not uniform, the table memories may couple the domain coordinate values to the interpolation device 36, which may determine the difference to be used in the division.
Systems, in accordance with the invention, for performing linear interpolation in multi-dimensional coordinate domains will be described in accordance with FIGS. 4A through 5.
As shown in FIG. 4A, in a two-dimensional interpolation system, the locations of the points in the domain at which the function values are known form a two dimensional grid in a two-dimensional domain denoted by axes x and y. The value of the function at the target point is determined by interpolation from function values at the four nearest known points, which form corners of a rectangular grid "window" in which the target point lies.
As seen in FIG. 4A, the target point S- is projected onto two of the lines 26 defined by the grid of points at which the function values are known. The resulting projection points are identified as points s i and sp . A value for the function at these projections s i and sp2 can be calculated by a one dimensional interpolation system, such as described above in connection with FIGS. 1 through 3, using the pairs of known points sn and sι , s ι and s , respectively.
As shown in FIG. 4B, the two projection points spi and sp can be treated as known points in a one- dimensional domain coordinate system defined by the line between points spi and sp2, on which point sd lies. The two projections are collinear with the desired point, and thus the value of the function at the desired point S([ can be calculated by one-dimensional interpolation methods, using the calculated values for the function at the projection points spi and sp2.
FIG. 5 shows a circuit for performing interpolation in a two-dimensional coordinate domain according to the invention, in connection with xχ_- and yχ~- signals which identify the domain coordinate values, along the x and y axes respectively, for the target point. The circuit includes two one-dimensional interpolation blocks 70(ODD) and 70(EVEN), both corresponding to interpolation block 70 (FIG. 1). Each block 70(ODD) and 70(EVEN) stores in its table memories (not shown) the function values for the known points in the coordinate domain along alternating lines 26 as depicted in FIG. 4A. Using the circuit shown in FIG. 5, fractional signal xχ~- and the integer portion of yχ_- signal are coupled to the one-dimensional interpolation blocks 70, each of which provides the function values for one of the projection points spi and sp . The outputs of the two one-dimensional blocks 70 are coupled to an interpolation device 36, along with the fractional portion of the yχ_q signal, which provides the function value for the target point.
To accomplish this, the two one-dimensional interpolation blocks 70 include table memories (not shown in FIG. 5) that provide function values for points on alternating lines in the two-dimensional domain. That is, assuming the function values are provided along parallel lines, which are parallel to the x-axis, as shown in FIG. 4A, and which intersect the y-axis at integral points along the y-axis, the one-dimensional interpolation block 70(ODD) includes table memories. corresponding to table memories 30 and 32 (FIG. 1), which provide function values along lines which intersect the y-axis at odd points along the y-axis, and the other interpolation block 70 (EVEN) includes table memories, also corresponding to table memories 30 and 32, which provide function values along lines which intersect the y-axis at even points along the y-axis.
The table memories 30 and 32 in the interpolation block 70(ODD) stores function values at known points along a line stored therein in a set of successive memory locations, with function values along the successive lines being stored in successive sets of memory locations in the respective memories. The table memories 30 and 32 in the interpolation block 70(ODD) are both addressed in response to portions of the integer portion of the xχ-_- input signals and the integer portion of the yχ_ input signals. Specifically, the address signals are generated by an address generator 38(x), which generates address signals in response to the xχ_- signals and an address generator 38(y), which generates address signals in response to the yjjj signals, with both address generators 38(x) and 38(y) being the same as address generator 38 (FIG. 1). Each of the address generators 38(x) and 38(y) generate even and odd sets of address signals; in particular, the address generator 38(x) generates address signals X ADRS ODD odd address signals and X ADRS EVEN even address signals, both along the x-axis, and address generator 38(y) generates address signals Y ADRS ODD odd address signals and Y ADRS EVEN even address signals, both along the y-axis.
The table memories 30 and 32 in the interpolation blocks 70(ODD) and 70(EVEN) are addressed by address signals formed by various concatenations of the X ADRS ODD, X ADRS EVEN, Y ADRS ODD, and Y ADRS EVEN signals produced by the address generators 38(x) and 38(y). In particular, the table memory 30 (reference FIG. 1) in the interpolation block 70(ODD), which stores function values, at successive points, which have odd x-axis coordinate values, along successive lines which have odd y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS ODD odd x- axis address signals onto the low-order end of the Y ADRS ODD odd y-axis address signals. The Y ADRS ODD odd y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 30 (reference FIG. 1), while the X ADRS ODD odd x-axis address signals identify a particular point on the line, and thus a particular memory location, in the set identified by the Y ADRS ODD odd y-axis address signals, which stores the function value for the point.
Similarly, the table memory 32 (reference FIG. 1) in the interpolation block 70(ODD), which stores function values, at successive points, which have even x-axis coordinate values, along successive lines which have odd y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS EVEN even x-axis address signals onto the low-order end of the Y ADRS ODD odd y-axis address signals. The Y ADRS ODD odd y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 32, while the X ADRS EVEN even x-axis address signals identify a particular point on the line, and thus a particular location, in the set identified by the Y ADRS ODD odd y- axis address signals, which stores the function value for the point. The table memory 30 (reference FIG. 1) in the interpolation block 70 (EVEN), which stores function values, at successive points, which have odd x-axis coordinate values, along successive lines which have even y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS ODD odd x- axis address signals onto the low-order end of the Y ADRS EVEN y-axis address signals. The Y ADRS EVEN even y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 30 (reference FIG. 1), while the X ADRS ODD odd axis address signals identify a particular point on the line, and thus a particular location, in the set identified by the Y ADRS EVEN even y-axis address signals, which stores the function value for the point.
Finally, the table memory 32 (reference FIG. 1) in the interpolation block 70(EVEN), which stores function values, at successive points, which have even x-axis coordinate values, along successive lines which have even y-axis coordinate values, is addressed by address signals formed by concatenating the X ADRS EVEN even x- axis address signals onto the low-order end of the Y ADRS EVEN even y-axis address signals. The Y ADRS EVEN even y-axis address signals identify a particular line in the domain, and thus a particular set of function values stored in the table memory 32 (reference FIG. 1), while the X ADRS EVEN even x-axis address signals identify a particular point on the line, and thus a particular location, in the set identified by the Y ADRS EVEN even y-axis address signals, which stores the function value for the point.
Thus, the four sets of address signals, generated by the concatenation of the X ADRS ODD odd x-axis address signals, X ADRS EVEN even x-axis address signals, Y ADRS ODD odd y-axis address signals, and Y ADRS EVEN even y-axis address signals, as described above, identify the four points in the domain proximate the target point at which the function points are known. As in the embodiment, depicted in FIG. 1, for performing interpolation in a one-dimensional domain, the address generators 38(x) and 38(y) generate, respectively, SELX and SELy select signals that indicate whether the odd- and even-valued domain coordinates are greater and less than the domain coordinate values of the target point, as represented by the XJJJ and yχ_- signals, respectively.
As noted above, the interpolation blocks 70(ODD) and 70(EVEN) generate the interpolated values for the projection points spi and sp2. An interpolation device 36, which is identical to that depicted in FIG. 3, receives the interpolated values from the interpolation blocks 70(ODD) and 70(EVEN) and uses them, along with the SELy select signal and the fraction portion of the yiN signals, to generate an interpolated value for the target point. It will be appreciated that the SELy select signal indicates which of the projection points spi and sp2 is associated with the interpolated value produced by the interpolation block 70 (ODD) and 70(EVEN).
The invention can.be extended to provide interpolated values for higher-dimensional domains in a similar manner. For example, to perform an interpolation in a three-dimensional domain, defined by orthogonal x-, y- and z-axes, it may be recognized that the target point, defined by a coordinate x ]$, yχnr and zjN, may first be projected, along a line parallel to the z-axis, onto two parallel planes at, for example, integral locations along the z-axis. Each of the planes ay define sets of lines, parallel to the x-axis, which intersects the y-axis at integer locations along the y- axis, which each line containing points, at integer locations along the x-axis, at which the function values are known. An interpolation circuit includes two two- dimensional interpolation blocks, similar to that shown in FIG. 5, with the addition that each of the table memories includes additional sets of memory locations for each of the planes, and the memories are thus also addressed by Z ADRS ODD odd z-axis address signals and Z ADRS EVEN even z-axis address signals provided by an address generator, substantially similar to the address generator 38 (FIG. 2), in response to an integer portion of the zχ_- signal. An interpolation device, similar to that depicted in FIG. 3, receives interpolated values from each of the two-dimensional interpolation blocks, which represent interpolated values in each of the plans parallel to the z-axis, and uses them, the fractional portion of the ZJN signal and SELg select signal to generate the interpolated value. Interpolation in higher-dimensioned domains can be accomplished by a similar extension from successive lower-dimensioned domains.
This invention has been illustrated through the use of a particular embodiment. Other embodiments are within the scope of the appended claims. For example, the interpolation method may use a cylindrical, radial, or any other coordinate system. Also, the known points need not be arranged in a grid, rather they may be randomly dispersed. In a one dimensional system, the points need not be evenly spaced. In an n-dimensional system, the sets of collinear points need not form parallel lines or planes.

Claims

Clai s
1. An interpolation system for generating an interpolated value in response to an input value, the interpolation system comprising: A. a function value store comprising a plurality of function value storage tables for storing function values for alternating domain coordinate values in a domain;
B. an address generator responsive to an input value for generating address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel; and
C. an interpolator for receiving function values transmitted in parallel by the function value storage tables and the input value and generating in response thereto the interpolated value.
2. An interpolation system as defined in claim 1 for generating an interpolated value in a one-dimensional domain, the function value store comprising two function value storage tables each including a plurality of addressable storage locations for storing function values for alternate domain coordinate values in the domain at storage locations whose addresses are related to the respective domain coordinate values.
3. An interpolation system as defined in claim 2 in which the input value is represented by a plurality of input signals having a high-order portion and a low- order portion, the address generator receiving the high- order portion and generating in response thereto address signals for addressing the function value storage tables.
4. An interpolation system as defined in claim 3 in which the function value storage tables comprise an even function value storage table and an odd function value storage table, the address generator generating even address signals for addressing the even function value storage table and odd address signals for addressing the odd function value storage table.
5. An interpolation system as defined in claim 4 in which the function value storage tables store function values for integral domain coordinate values, the address generator generating even address signals and odd address signals identifying addresses which differ by at most one.
6. An interpolation system as defined in claim 5 in which the address generator couples a most-significant bit set of the high-order portion of the input signals as the odd address signals, and the sum of the most significant bit set of the high-order portion of the address signals and a least significant bit of the high- order portion of the address signals as the odd address signals. 7. An interpolation system as defined in claim 5 in which the interpolator includes:
A. a subtractor portion for generating a difference value in response to the function values transmitted by the even function value store and the odd function value store;
B. a multiplier portion for generating a product value in response to the difference value generated by the subtractor portion and the low order option of the input signals; and
C. an adder portion for generating the sum of the product value generated by the multiplier portion and a function value transmitted by one of the even function value store and the odd function value store.
8. An interpolation system as defined in claim 4 in which the address signals generated by the address generator identify domain coordinate values above and below the input value, the address generator further generating a select signal in response to the high-order portion of the input signals identifying which of the even address signals or the odd address signals represent domain coordinate values greater than and less than the input value.
9. An interpolation system as defined in claim 8 in which the interpolator includes:
A. a selector for receiving the function values from the even function value store and the odd function value store and for coupling them in order of respective domain coordinate values in response to the select signal; B. a subtractor portion for generating a difference value in response to the ordered function values from the selector;
C. a multiplier portion for generating a product value in response to the difference value generated by the subtractor portion and the low order portion of the input signals; and
D. an adder portion for generating the sum of the product value generated by the multiplier portion and a function value transmitted by one of the even function value store and the odd function value store.
10. An interpolation system as defined in claim 1 in which said interpolator comprises:
A. a subtractor portion for generating a difference value in response to the function values transmitted by the function value store;
B. a multiplier portion for generating a product value in response to the difference value generated by the subtractor portion and the input value; and C. an adder portion for generating the sum of the product value generated by the multiplier portion and a function value transmitted by the function value store.
11. An interpolation system as defined in claim 1 for generating an interpolated value in a multi-dimensional domain, the function value store comprising, for each dimension comprising the domain, function value storage tables each including a plurality of sets of addressable storage locations for storing function values for alternate domain coordinate values in each dimension comprising the domain at storage locations whose addresses are related to the respective domain coordinate values. 12. An interpolation system as defined in claim 11 in which the input value is represented, for each dimension comprising the domain, by a plurality of input signals each having a high-order portion and a low-order portion, the address generator comprising a plurality of dimensional address generators each receiving the high- order portion of input signals for the associated dimension in the domain, and generating in response thereto address signals for addressing the function value storage tables, each of the function value storage tables being addressed by selected concatenations of address signals generated by the respective dimensional address generators.
13. An interpolation system as defined in claim 12 in which said function value storage tables comprise, for each successive dimension in the domain, successive even dimension function value storage tables and odd dimension function value storage tables, with the even dimension function value storage table and the odd dimension function value storage table for each successive dimension including function values for interleaved coordinate values in the associated dimension in combination with each coordinate value in preceding dimensions in the succession.
14. An interpolation system as defined in claim 13 in which each dimensional address generator couples a most- significant bit set of the high-order portion of input signals for its associated dimension as the odd address signals, and the sum of the most significant bit set of the high-order portion of the address signals and a least significant bit of the high-order portion of the address signals as the odd address signals.
15. An interpolation system as defined in claim 13 in which said interpolator includes a plurality of successive interpolation stages each stage performing interpolation in each of the successive dimensions, each state including at least one interpolator block comprising: A. a subtractor portion for generating a difference value in response to function values transmitted by selected pairs of said even dimension function value storage tables and odd dimension function value storage tables; B. a multiplier portion for generating a product value in response to the difference value generated by the subtractor portion and the low order portion of the input signals for the associated dimension; and
C. an adder portion for generating the sum of the product value generated by the multiplier portion and a function value transmitted by one of said even dimension function value storage tables and odd dimension function value storage tables. 16. An interpolation system as defined in claim 15 in which the address signals generated by each of the dimensional address generators identify domain coordinate values above and below the input value in the associated dimension, the dimensional address generator further generating a select signal in response to the high-order portion of the input signals identifying which of the even address signals or the odd address signals represent domain coordinate values greater than and less than the input value, each said interpolator block further including a selector for receiving the function values from the even function value store and the odd function value store and for coupling them to said subtractor portion and said adder portion in order of respective domain coordinate values in response to the select signal.
17. A method of generating an interpolated value in response to an input value comprising the steps of:
A. providing a plurality of function value storage tables for storing function values for alternating domain coordinate values in a domain;
B. generating address signals identifying locations in the function value storage tables to enable the function value storage tables to transmit function values in parallel; and
C. receiving function values transmitted by the function value storage tables in parallel and the input value and generating in response thereto the interpolated value.
EP19900911465 1989-07-25 1990-07-24 A system for performing linear interpolation Withdrawn EP0436002A4 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US38524289A 1989-07-25 1989-07-25
US385242 1989-07-25

Publications (2)

Publication Number Publication Date
EP0436002A1 EP0436002A1 (en) 1991-07-10
EP0436002A4 true EP0436002A4 (en) 1993-01-27

Family

ID=23520609

Family Applications (1)

Application Number Title Priority Date Filing Date
EP19900911465 Withdrawn EP0436002A4 (en) 1989-07-25 1990-07-24 A system for performing linear interpolation

Country Status (3)

Country Link
EP (1) EP0436002A4 (en)
JP (1) JPH04500877A (en)
WO (1) WO1991001527A1 (en)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5237432A (en) * 1991-12-23 1993-08-17 Xerox Corporation Image scaling apparatus
CA2129092C (en) * 1993-10-04 1999-10-19 Leon C. Williams Image interpolation apparatus
GB9613538D0 (en) * 1996-06-27 1996-08-28 Switched Reluctance Drives Ltd Matrix interpolation
EP0903692A3 (en) * 1997-09-23 2000-01-05 Xerox Corporation System and method for two-dimensional interpolation
EP1139554A3 (en) * 2000-03-29 2003-12-17 Microchip Technology Inc. Microcontroller operated electric motor soft start using a table drive equation with variable timing

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4837722A (en) * 1986-05-14 1989-06-06 Massachusetts Institute Of Technology Digital high speed 3-dimensional interpolation machine
US4841462A (en) * 1984-11-21 1989-06-20 Etat Francais, Administration Des P.T.T. (Centre National D'etudes Des Telecommunications) Random access memory and linear interpolation circuit comprising application thereof

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3247365A (en) * 1961-02-06 1966-04-19 Gen Precision Inc Digital function generator including simultaneous multiplication and division
US3412240A (en) * 1963-02-21 1968-11-19 Gen Precision Systems Inc Linear interpolater
US3678258A (en) * 1970-09-29 1972-07-18 Electronic Associates Digitally controlled electronic function generator utilizing a breakpoint interpolation technique
US3748447A (en) * 1971-11-18 1973-07-24 Sperry Rand Corp Apparatus for performing a linear interpolation algorithm

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4841462A (en) * 1984-11-21 1989-06-20 Etat Francais, Administration Des P.T.T. (Centre National D'etudes Des Telecommunications) Random access memory and linear interpolation circuit comprising application thereof
US4837722A (en) * 1986-05-14 1989-06-06 Massachusetts Institute Of Technology Digital high speed 3-dimensional interpolation machine

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
NASA TECHNICAL BRIEF, NASA SPRINGFIELD, VIRGINIA, US no. 6/A, June 1986, page 658 'FUNCTION GENERATOR FOR IMAGE PROCESSOR' *
See also references of WO9101527A1 *

Also Published As

Publication number Publication date
JPH04500877A (en) 1992-02-13
WO1991001527A1 (en) 1991-02-07
EP0436002A1 (en) 1991-07-10

Similar Documents

Publication Publication Date Title
US5175701A (en) System for performing linear interpolation
US4603348A (en) Method for composing addresses of a memory
US4819152A (en) Method and apparatus for addressing a memory by array transformations
US4827250A (en) Graphics display system having data transform circuit
US5025405A (en) Method of interpolating pixel values
EP0124799B1 (en) Memory access arrangement in a data processing system
US4555771A (en) Data processing system for data base management of matrix type data
US4296468A (en) Address conversion unit for data processing system
US4878182A (en) Multiple pixel generator
KR100474357B1 (en) A method for memory allocation using multi-level partition
EP0436002A4 (en) A system for performing linear interpolation
EP0301253B1 (en) Line generation in a display system
US5383142A (en) Fast circuit and method for detecting predetermined bit patterns
GB2204216A (en) Curve generation in a display system
EP0483454A2 (en) Fast fourier transform using balanced coefficients
Miller et al. Highly efficient exhaustive search algorithm for optimizing canonical Reed-Muller expansions of boolean functions
Tang et al. Optimal workpiece setups for 4-axis numerical control machining based on machinability
Costa et al. A binary Hough transform and its efficient implementation in a systolic array architecture
EP0201174B1 (en) Method and apparatus for addressing a memory
Hayward A lower bound for the optimal crossing-free Hamiltonian cycle problem
JPH05342095A (en) Interleave memory for adjacent interpolaton and image processor using this memory
EP0389890A2 (en) Method and apparatus for generating figures with three degrees of freedom
JP2858616B2 (en) Image interpolation circuit
KR870001402B1 (en) Data processing
JPH0522238B2 (en)

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AT BE CH DE DK ES FR GB IT LI LU NL SE

17P Request for examination filed

Effective date: 19910711

A4 Supplementary search report drawn up and despatched

Effective date: 19921208

AK Designated contracting states

Kind code of ref document: A4

Designated state(s): AT BE CH DE DK ES FR GB IT LI LU NL SE

17Q First examination report despatched

Effective date: 19951023

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 19960305