Misplaced Pages

Digital differential analyzer (graphics algorithm)

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from Digital Differential Analyzer (graphics algorithm)) Hardware or software used for interpolation of variables over an interval This article is about a graphics algorithm. For the digital implementation of a differential analyzer, see Digital differential analyzer.

In computer graphics, a digital differential analyzer (DDA) is hardware or software used for interpolation of variables over an interval between start and end point. DDAs are used for rasterization of lines, triangles and polygons. They can be extended to non linear functions, such as perspective correct texture mapping, quadratic curves, and traversing voxels.

In its simplest implementation for linear cases such as lines, the DDA algorithm interpolates values in interval by computing for each xi the equations xi = xiāˆ’1 + 1, yi = yiāˆ’1 + m, where m is the slope of the line. This slope can be expressed in DDA as follows:

m = y e n d y s t a r t x e n d x s t a r t {\displaystyle m={\frac {y_{\rm {end}}-y_{\rm {start}}}{x_{\rm {end}}-x_{\rm {start}}}}}

In fact any two consecutive points lying on this line segment should satisfy the equation.

Performance

The DDA method can be implemented using floating-point or integer arithmetic. The native floating-point implementation requires one addition and one rounding operation per interpolated value (e.g. coordinate x, y, depth, color component etc.) and output result. This process is only efficient when an FPU with fast add and rounding operation will be available.

The fixed-point integer operation requires two additions per output cycle, and in case of fractional part overflow, one additional increment and subtraction. The probability of fractional part overflows is proportional to the ratio m of the interpolated start/end values.

DDAs are well suited for hardware implementation and can be pipelined for maximized throughput.

Algorithm

A linear DDA starts by calculating the smaller of dy or dx for a unit increment of the other. A line is then sampled at unit intervals in one coordinate and corresponding integer values nearest the line path are determined for the other coordinate.

Considering a line with positive slope, if the slope is less than or equal to 1, we sample at unit x intervals (dx=1) and compute successive y values as

y k + 1 = y k + m {\displaystyle y_{k+1}=y_{k}+m}
x k + 1 = x k + 1 {\displaystyle x_{k+1}=x_{k}+1}

Subscript k takes integer values starting from 0, for the 1st point and increases by 1 until endpoint is reached. y value is rounded off to nearest integer to correspond to a screen pixel.

For lines with slope greater than 1, we reverse the role of x and y i.e. we sample at dy=1 and calculate consecutive x values as

x k + 1 = x k + 1 m {\displaystyle x_{k+1}=x_{k}+{\frac {1}{m}}}
y k + 1 = y k + 1 {\displaystyle y_{k+1}=y_{k}+1}

Similar calculations are carried out to determine pixel positions along a line with negative slope. Thus, if the absolute value of the slope is less than 1, we set dx=1 if x s t a r t < x e n d {\displaystyle x_{\rm {start}}<x_{\rm {end}}} i.e. the starting extreme point is at the left.

Program

DDA algorithm program in C++:

#include <graphics.h>
#include <iostream.h>
#include <math.h>
#include <dos.h>
#include <conio.h>
void main()
{
  float x,
  float y,
  float x1, y1,
  float x2, y2, dx, dy, step;
  int i, gd = DETECT, gm;
  initgraph(&gd, &gm, "C:\\TURBOC3\\BGI");
  cout << "Enter the value of x1 and y1: ";
  cin >> x1 >> y1;
  cout << "Enter the value of x2 and y2: ";
  cin >> x2 >> y2;
  dx = (x2 - x1);
  dy = (y2 - y1);
  if (abs(dx) >= abs(dy))
    step = abs(dx);
  else
    step = abs(dy);
  dx = dx / step;
  dy = dy / step;
  x = x1;
  y = y1;
  i = 0;
  while (i <= step) {
    putpixel(round(x), round(y), 5);
    x = x + dx;
    y = y + dy;
    i = i + 1;
    delay(100);
  }
  getch();
  closegraph();
}

See also

References

http://www.museth.org/Ken/Publications_files/Museth_SIG14.pdf


This article includes a list of references, related reading, or external links, but its sources remain unclear because it lacks inline citations. Please help improve this article by introducing more precise citations. (June 2011) (Learn how and when to remove this message)
  • Alan Watt: 3D Computer Graphics, 3rd edition 2000, p. 184 (Rasterizing edges). ISBN 0-201-39855-9
Categories:
Digital differential analyzer (graphics algorithm) Add topic