Computer Graphics
Computer Graphics
      Objectives
      After studying this unit, you should be able to:
      z   Understanding the Fundamentals of computer graphics.
      z   Discuss the Applications of computer graphics in different areas.
      z   Explain the Random and raster scan display.
      z   Understand Display devices
1.1 Introduction
Computer graphics is a subfield of computer science which studies methods for digitally
synthesizing and manipulating visual content. Computer graphics is a creation and
manipulation of pictures with the aids of computers.
Two types of computer graphics techniques can be used:
1     Interactive computer graphics and
2     Passive or non-interactive computer graphics.
                                                                              Amity Directorate of Distance & Online Education
2                                                                                                     Computer Graphics
                                 In interactive computer graphics user having control over image by providing some
                             input device so that he/she can signal requests to the computer. It involves two-way
Notes                        communications between computer and user. User gives signals using input devices
                             and computer modify displayed image accordingly. In this way we maintain
                             conversation or dialogue with computer. For example like video games.
                                 Passive computer graphics: Computer graphics in which operations that transfer
                             automatically without operator intervention i.e. users don’t perform any dialogue with
                             computer system unlike interactive computer graphics.
                                  Basic graphics system:
Notes
                                  CAT scan method is best for detecting brain tumors and other types of disorders.
                             Medical scientist use computer graphics for detecting problems of sensitive organs,
                             tissues and other types of disorder.
                                 (a)                          (b)
                              Figure 1.8: (a) Image and (b) Bloopers
                             Graphics elements such as windows, cursor, menu, icons are so common that it is
                             difficult to imagine computing without them.
Notes
                                 Icons represent different options for painting, drawing, zooming, typing and other
                             operations connected with picture construction. Today, nearly all professional
                             programmers must have an understanding of graphics in order to accept input and
                             present output to users.
                             Keyboard
                             Keyboard is a commonly used input device. When a key is pressed, the position of key
                             pressed is found by internal circuitry to find out corresponding row and column position
                             of the key. This set of information passed to a decoder which gives an equivalent ASCII
                             code of pressed key. Output in ASCII forms goes to CPU. ASCII allows computer to
                             encode keyboards characters. Using ASCII keyboard is able to communicate with
                             computer by sending a specific 7-bit code for each key.
                                In addition to these keys several keyboard provide additional functionality such as
                             save drawing, rotate and remove objects are commonly found on functional keys.
Mouse
Mouse is an input devices used in interactive computer graphics. On upper side of
mouse there are two or three buttons placed using which some actions are controlled.
Mouse is placed on soft rubber base known as mouse pad. From movement of wheels
of mouse CPU gets information about horizontal or vertical movement and accordingly
cursor will move. For selecting an item proper action key is pressed. Nearly in all
computer graphics applications, mouse is an essential input device.
Paddle Control
In paddle control two control knobs are provided, one for movement of x and other for
movement of y. It is an analog input device.
Light Pen
It is a pointing device. It has a light sensitive tip which is excited when light is emitted,
when an illuminated point on screen comes in its field of view. User will point with the
pen to perform an operation such as drawing of a line or rotating an object on a CRT.
     A light pen is an event driven device. Processor has to wait till it across an
illuminated point on the screen to obtain any information.
Image Scanner
    Graphs, drawing, black and white photos or text can be stored for processing using
image scanners. After getting internal representation of a picture we can apply several
transformations to rotate, scale a picture to a particular screen area. We can apply
various image processing methods to modify array representation of the picture.
Touch Screen
It is an input device in which user can enter data by touching some sensitive areas of
the screen. After invoking the program, it display possible choices and user have to
select his/her choices.
                                 Normally touch screen uses a group of infrared light emitting diodes along a
                             horizontal edge and along vertical edge contain light detectors. When fingers are placed
Notes                        on screen, light beam are interrupted and sensed by build in sensors.
   In some raster scan system like TV sets each frame buffer is displayed into two
passes. In first pass beam sweeps across odd number of scan line scan line from top to
                                                                               Amity Directorate of Distance & Online Education
10                                                                                                       Computer Graphics
                             bottom, then vertical retrace followed by second pass in which remaining lines are
                             scanned. Above procedure called interlaced refresh procedure.
Notes
                                 In Interactive raster scan display in addition to a CPU, we need a special purpose
                             processor called video controller or display controller, which is used to control operation
                             of display device. A part of system memory is used as frame buffer. Display controller
                             access the frame buffer to refresh the screen.
                                 In high quality system two frame buffers are used, one used for refreshing and other
                             is used for intensity values.
                                   Objectives
                                   After studying this unit, you should be able to:
                                   z   Understand the Line, Circle and ellipse drawing algorithms.
                                   z   Learn about the concepts of conic section
                                   z   Understand about the pixel addressing and filled area primitive
                             2.1 Introduction
                             Scan conversion is a process of representing a continuous graphical object as a
                             collection of discrete pixels. Each pixel can’t be represented by a single mathematical
                             point but it represents a region which theoretically consists of a large number of points.
Slope(m)=(y2–y1)/(x2–x1)
Given (x1,y1) and (x2,y2) are endpoints of a line. We consider that x1 is smaller
than x2.
     Step 1 :       Compute m=(y2-y1)/(x2-x1) and y-intercept=y1-m*x1
     Step 2 :       Choose a small value dx represent increment in x after each step and
                    correspondingly find dy = m*dx.
     Step 3 :       x = x1 and y = y1 and draw(x, y)
     Step 4 :       Compute next coordinate x = x+dx and y = y+dy
     Step 5 :       If (x>x2 ) go to step 6;
                    Else draw (x, y) and go to step 4
     Step 6 :       Stop
    If |m|>1 then we take small increment in y call it as dy and find corresponding
increment in x i.e. dx=dy/m.
Algorithm 2.2: SLOPE2(x1, y1, x2, y2) with slope |m|>1
Given (x1, y1) and (x2, y2) are endpoints of a line. We consider that x1 is smaller
than x2.
     Step 1 :       Compute m=(y2-y1)/(x2-x1) and y-intercept=y1-m*x1
     Step 2 :       Choose a small value dy increment in y after each step and
                    correspondingly find dx=dy/m.
     Step 3 :       x=x1 and y=y1 draw(x,y)
                             Given (x1,y1) and (x2,y2) are endpoints of a line. We consider that x1 is smaller
                             than x2.
                                  Step 1 :         Compute m=(y2-y1)/(x2-x1) and y-intercept=y1–m*x1
                                  Step 2 :         dx=1 and dy=m
                                  Step 3 :         x=x1 and y=y1 draw(x, y)
                                  Step 4 :         Compute next coordinate x=x+dx and y=y+dy.
                                  Step 5 :         if (x>x2 ) go to step 6
                                                   else draw (x, y) and go to step 4
                                  Step 6 :         stop
                             Algorithm 2.4: DDA2 (x1, y1, x2, y2) with slope |m|>1
                             Given (x1, y1) and (x2,y2) are endpoints of a line. We consider that x1 is smaller than x2.
                                  Step 1 :         Compute m= (y2-y1)/(x2-x1) and y-intercept=y1-m*x1
                                  Step 2 :         dy=1 and dx=1/m
                                  Step 3 :         x=x1 and y=y1 draw(x, y)
                                  Step 4 :         Compute next coordinate x=x+ dx and y=y+dy.
                                  Step 5 :         if (x>x2 ) go to step 6
                                                   else draw (x, y) and go to step 4
                                  Step 6 :         stop
Amity Directorate of Distance & Online Education
Output Primitives                                                                                                       19
    DDA algorithm will consider that our lines are processed from left endpoint to the
right endpoints.
                                                                                                                 Notes
     If starting endpoint is in right we will made following changes:
     Initially we set x=x1 and y=y1
At xk+1, if we choose yk+1=yk , let d1 is the difference between actual value of y and yk
    Now out of these two choice yk+1 and yk , we choose which is close to actual y
value.
     Take difference of d1 and d2
Notes
if yk+1 = yk
pk+1 – pk = 2* dy (2.8)
if yk+1 = yk+1
                                  From (2.5)
                                                      pk = dx(d1-d2)= 2* dy * xk- 2* dx* yk+2* dy +2b*dx-dx
Algorithm 2.5: Bresenham line drawing algorithm with positive slope and less than 1.
    Taking two endpoints as input and considering left endpoint is (x0 ,y0). Calculate
slope m using these two endpoints.
     Step 1 :       Plot (x0, y0)
     Step 2 :       We calculate dx, dy, 2dy and 2* dy-2* dx
                    Calculate initial decision variable p0= 2*dy –dx
     Step 3 :       Repeat step 4, dx times
     Step 4 :       At each iteration calculate pk and
                    If pk<0 , next point to plot is (xk+1,yk)
                             Calculate pk+1 =pk +2*dy
                    Else plot point(xk+1,yk+1) and
                             Calculate pk+1 =pk +2*dy-2* dx
     Step 5 :       Stop
Solution:
1. Slope method
     m= (y2-y1)/(x2-x1)=5/10=1/2 and y-intercept=10-(1/2)*10=5
          Slope is less than 1. Let dx = 0.5 small increment in x and dy = m*dx = (1/2)1/2
          = 0.25
                                  Iteration        1        2         3        4         5       6        7       8       9         10     11
                                  number
                                      X            10      10.5        11      11.5      12      12.5      13     13.5     14       14.5    15
                                      Y            10 10.25          10.5 10.75          11 11.25         11.5 11.75       12 12.25        12.5
                                      X         15.5         16      16.5       17      17.5      18      18.5     19     19.5       20
                                      Y        12.75         13 13.25          13.5 13.75         14 14.25        14.5 14.75         15
                                   Iteration           1         2         3        4        5        6       7       8       9       10    11
                                    number
                                       X           10           11     12          13    14          15    16      17      18         19    20
                                       Y           10      10.5        11      11.5      12      12.5      13     13.5     14       14.5    15
                                     K             1        2         3         4        5        6        7          8       9      10     11
                                     pk                     0        -10        0       -10       0       -10         0   -10         0    -10
                                     xk         10         11        12        13       14       15       16      17       18        19     20
                                     yk         10         11        11        12       12       13       13      14       14        15     15
                             Example 2.2: Given endpoint (10, 10) and (25, 20) Draw a line using Bresenham’s line
                             drawing algorithm.
                             Solution:
                                  Step 1 :         Plot (10,10)
                                  Step 2 :         We calculate dx=15, dy=10, 2dy=20 and 2* dy-2* dx=20-30= -10
                                                   Calculate initial decision variable p0= 2*dy –dx=20-15=5
                                  Step 3 :         Repeat step 4, 15 times
  K       1     2     3      4       5   6     7   8     9       10   11   12   13   14    15     16
  pk            5     -5    15       5   -5   15   5    -5       15   5    -5   15    5     -5    15
  xk     10    11    12     13   14      15   16   17   18       19   20   21   22   23    24     25
  yk     10    11    11     12   13      13   14   15   15       16   17   17   18   19    19     20
Y = yc (2.13)
    As value of x vary from xc-r and xc+r .We take initial value of x as xc-r and increment
value of x by 1 until it reaches to xc+r and correspondingly find value of y by equation
(13).
Algorithm 2.6: Poly_equation_circle1(r, xc, yc)
                             2. After using above algorithm, circle drawn is not uniform. We can reduce uniformity
                                problem by interchanging the coordinate (i.e. we initialize y coordinate and after
Notes                           each y-increment by unit and we find corresponding x-coordinate).
                             xc and yc are the center of circle. Increment in q is given by inc and initial value of q = 0
                             is given.
                                  Step 1 :         q = 0 is given
                                  Step 2 :         Repeat steps 3 and 4 while q < q end
                                  Step 3 :         x= xc+ rcos q and y=yc+rsin q
                                  Step 4 :         Draw a point (x,y) and q = q + inc.
                                  Step 5 :         stop
     p6(-y1,-x1) obtained by reversing x1 and y1 coordinate and reflecting along y-axis and                       Notes
reflecting along x-axis.
     p7(y1,-x1) obtained by reversing x1 and y1 coordinate and reflecting along y-axis.
                             Now
                                              dk+2- dk+1 = (( xk+1+1)2+( yk+1)2-r2+( xk+1+1)2+( yk+1-1)2-r2) -(( xk+1)2+( yk)2-r2+
                                                           ( xk+1)2+ ( yk-1)2-r2)
= [( xk+2)2-( xk+1)2]+2[(yk+1)2-(yk)2]-2[yk+1-yk]
= 6+4xk+2[(yk+1)2-(yk)2]-2[yk+1-yk]
So yk+1 = yk.
dk+2 = dk+1+4xk+6
dk+2 = dk+1+6+4xk+4yk+2+2
     Given r is radius of circle and (xc , yc) are radius of circle.                                                       Notes
     Step 1 :        Calculate initial decision variable d1=3-2r, Take x=0 and y=r
     Step 2 :        Repeat step while x>y
     Step 3 :        If d<0 compute next iteration decision variable d=d+4x+6 and x=x+1
                     else compute next iteration decision variable d=d+4(x-y)+10 and x=x+1,
                     y=y-1
     Step 4 :        As center are (xc,yc) so point will become (xc+x) and (yc+y)
     Step 5 :        Using x-coordinate (xc+x) and y-coordinate (yc+y) derive seven other
                     points using eight-way symmetry.
Example 2.3: Consider radius of a circle is 10. Calculate first quadrant from x=0, x=y
using bresenham’s_circle algorithm? x=0 and y=10 and d=3-2r=3-20= -17
             Table 2.5: Different values of first quadrant with radius 10 and center (0,0)
Properties of Ellipse
1. Ellipse is a circular closed boundary in which horizontal and vertical boundary are
   different.
2. If we take two foci points, then sum of distances from the foci of the ellipse of each
   point on the ellipse is same.
                                  Let two point p1(x1 ,y1) and p2(x2 ,y2) be two foci points and P(x, y) be any point on
                             ellipse. If d1=distance of p1 from P and d2=distance of p2 from P, then
Notes
                                                    d1+d2 = constant
(x − x1 )2 + (y − y1 )2 + (x − x 2 )2 + (y − y 2 )2 = constant (2.21)
                             This algorithm takes any two focus point (x1,y1), (x2,y2) and take (x ,y) is a coordinate on
                             ellipse.
                                  Step 1 :         Compute constant, d=d1+d2
                                  Step 2 :         Repeat step-3 for all possible values of x
                                  Step 3 :         Increment x by 1 and find y so that d1+d2=d
                                Using symmetry we can reduce calculation. But unlike circle, in ellipse we take
                             symmetry between quadrants.
                                 Using symmetry, we can reduce calculation. We put pixel in one quadrant and find
                             three other pixel using symmetry in three other quadrants.
((x-xc)/a)2+((y-yc)/b)2 = 1 (2.23)
                                 First considering that xc and yc are (0, 0), we start with first quadrant having a<b and
                             considering point (0, b) and increase value of x by 1 while moving clockwise and
                             calculate y coordinate.
                                  Taking xc and yc are (0,0) we get
   We start with (0, b) and take unit increment in x, after each iteration until we reach
boundary of region1 and region2.After each iteration we check slope by
In region2 for every next iteration, we decrement value of y and check for two option of x
pk = f(xk,yk-1/2)=b2(xk+1)2+a2(yk-1/2)2-a2b2 (2.26)
Suppose yk+1 is yk
p0 = f(0,b)=b2(1)2+a2(b-1/2)2-a2b2
p0 = b2+a2[b2+1/4-b]-a2b2
p0 = b2+a2b2+a2(1/4)-ba2-a2b2
                             For region-2
                                                       Pk = f(xk+1/2,yk-1)=b2(xk+1/2)2+a2(yk-1)2-a2b2                     (2.31)
                     if xk+1 = xk                                                                                     Notes
                      pk+1 = pk+b2[(xk+1/2)2-(xk+1/2)2]+ a2[(2-2yk)]+ a2
If xk+1 = xk+1
Pk = f(xL,yL)=b2(xL+1/2)2+a2(yL-1)2-a2b2 (2.35)
Using this decision variable we get relationship between Region1 and Region2.
    We have found points assuming (0,0) as center coordinate. If (xc,yc) are center
coordinate point(x,y) that we have found changed to (xc+x,yc+y).
    Once we found a point we can found three other points in three remaining quadrant
by using symmetry.
Figure 2.7: Using four-way symmetry find three points in three other Quardant
Notes                            Considering (xc,yc) are center coordinate and length of major and minor axis a and
                             b. We found a point considering center coordinate (0, 0) and then change it
                             corresponding to (xc,yc) center coordinate.
                                  Step 1 :         Draw point (0, b) and calculate initial decision variable of region-1 using
                                                   p0=b2 + a2/4-ba2
                                  Step 2 :         if pk<0
                                                   Next point on ellipse with center of ellipse (0, 0) is (xk+1, yk) and
                                                   Compute pk+1= pk+2 b2xk+1+b2
                                                   else
                                                   Next point on ellipse with center of ellipse (0, 0) is (xk+1, yk-1) and
                                                   Compute pk+1= pk+2b2xk+1+b2-2 a2[yk+1]
                                  Step 3 :         If (x,y) are coordinate corresponding to center (0,0). Now determine
                                                   value of coordinate for center of ellipse by (xc+x,yc+y) .Using symmetry
                                                   of points in ellipse we can find three other coordinate and draw these
                                                   four points.
                                  Step 4 :         Repeat step 2 and 3 until 2b2xe ³ 2a2y
                                  Step 5 :         We calculate initial decision variable using last coordinate of region1.
                                                   Let (x,y) be last coordinate of region1.
                                                   pk= b2(x+1/2)2+a2(y-1)2-a2b2
                                  Step 6 :         Repeat step 7 and 8 while we are in first quadrant (i.e. until value of x is
                                                   a and y is zero)
                                  Step 7 :         if pk<0
                                                   Next point on ellipse with center of ellipse (0, 0) is (xk+1,yk-1) and
                                                   Compute pk+1=pk+2b2[xk+1]-2 a2[(yk +1)]+ a2
                                                   else
                                                   Next point on ellipse with center of ellipse (0,0) is (xk,yk-1) and
                                                             Compute pk+1=pk-2 a2yk+1+ a2
                                  Step 8 :         If (x,y) are coordinate corresponding to center(0,0). Now determine
                                                   value using center of ellipse by (xc+x,yc+y) .Using symmetry of points in
                                                   ellipse we determine three other coordinate and draw these four points.
                                  Step 9 :         Stop the process
                             Example 2.4: Suppose ellipse inputs are a=8 and b=5. Calculate the ellipse points?
                             Solution:
                                  Given a=8 and b=5
                                  Draw (0,5) and initial decision variable p0=b2+a2/4-ba2=25+16-5*64= -279
For region-2
     Last x-coordinate of region1 is (7, 2)
     Initial decision variable pk= b2(x+1/2)2+a2(y-1)2-a2b2=25(7+1/2)2+64(1)-64*36= -840
                         K                      pk                (xk+1,yk+1)
                         7                     -279                 (8,1)
                         8.                    2857                 (8,0)
    Now these calculations are considering that our center coordinates are (0, 0) if
center coordinate are (xc, yc) which is not (0,0) then each of new coordinates are
obtained by adding xc and yc to respective value obtained during each iteration.
Similarly values in three other coordinates can be obtained using four-way symmetry.
Circle
                                              x2 + y2 = 1
    Both squared terms are present, both are positive, both have the same coefficient.
The right hand side is positive. If the right hand side is zero, it is a point. If the right hand
side is negative, then there is no graph.
Ellipse
                                             3x2 + 4y2 = 1
    Both squared terms are present, both are positive, but they have different
coefficients. The right hand side must be positive. If the right hand side is zero, it is a
point. If the right hand side is negative, then there is no graph.
Hyperbola
                                              x2 - y2 = 1
                                 Both squared terms are present, but one is positive and the other is negative. The
                             coefficients may or may not be the same, it doesn't matter. The right hand side isn't
Notes                        zero. If the right hand side is zero, then it's intersecting lines.
                             Parabola
                                                                          x2 + y = 1
                                  Both variables are present, but one is squared and the other is linear.
                             Line
                                                                          x+y=1
                                  Neither variable is squared.
                             Point
                                                                          x2 + y2 = 0
                                  A circle (or ellipse) with the right hand side being zero.
                             No Graph
                                                                         x2 + y2 = -1
                                  A circle (or ellipse) with the right hand side being negative.
                             Intersecting Lines
                                                                          x2 - y2 = 0
                                  A hyperbola with the right hand side equal to zero.
                             Parallel Lines
                                                                              x2 = 1
                                 One variable is squared and the other variable is missing. The right hand side must
                             be positive. If the right hand side is zero, then it is a line (x2 = 0 so x = 0) and if the right
                             hand side is negative (x2 = -1), then there is no graph.
                             Parabola
                                A parabola is "the set of all points in a plane equidistant from a fixed point (focus)
                             and a fixed line (directrix)".
                                 The distances to any point (x,y) on the parabola from the focus (0,p) and the
                             directrix y=-p, are equal to each other. This can be used to develop the equation of a
                             parabola.
                                 If you take the definition of a parabola and work out the algebra, you can develop
                             the equation of a parabola. You can click on the link if you'd like to see the
                             development, but the short version is that the standard form is x2 = 4py.
                             z    The starting point is the vertex at (h,k)
                             z    There is an axis of symmetry that contains the focus and the vertex and is
                                  perpendicular to the directrix.
                             z    Move p units along the axis of symmetry from the vertex to the focus.
                             z    Move -p units along the axis of symmetry from the vertex to the directrix (which is a
                                  line).
                             z    The focus is within the curve.
                                 The parabola has the property that any signal (light, sound, etc) entering the
                             parabola parallel to the axis of symmetry will be reflected through the focus (this is why
Amity Directorate of Distance & Online Education
Output Primitives                                                                                                          35
satellite dishes and those parabolic antennas that the detectives use to eavesdrop on
conversations work). Also, any signal originating at the focus will be reflected out
parallel to the axis of symmetry (this is why flashlights work).                                                    Notes
Circle
A circle is "the set of all points in a plane equidistant from a fixed point (center)".
    The standard form for a circle, with center at the origin is x2 + y2 = r2, where r is the
radius of the circle.
Ellipse
An ellipse is "the set of all points in a plane such that the sum of the distances from two
fixed points (foci) is constant".
     The sum of the distances to any point on the ellipse (x,y) from the two foci (c,0) and
(-c,0) is a constant. That constant will be 2a.
     If we let d1 and d2 bet the distances from the foci to the point, then d1 + d2 = 2a.
    You can use that definition to derive the equation of an ellipse, but I'll give you the
short form below.
    The ellipse is a stretched circle. Begin with the unit circle (circle with a radius of 1)
centered at the origin. Stretch the vertex from x=1 to x=a and the point y=1 to y=b. What
you have done is multiplied every x by a and multiplied every y by b.
    In translation form, you represent that by x divided by a and y divided by b. So, the
equation of the circle changes from x2 + y2 = 1 to (x/a)2 + (y/b)2 = 1 and that is the
standard equation for an ellipse centered at the origin.
     The center is the starting point at (h,k).
     The major axis contains the foci and the vertices.
   Major axis length = 2a. This is also the constant that the sum of the distances must
add to be.
                             Hyperbola
                             A hyperbola is "the set of all points in a plane such that the difference of the distances
                             from two fixed points (foci) is constant".
                                 The difference of the distances to any point on the hyperbola (x,y) from the two foci
                             (c,0) and (-c,0) is a constant. That constant will be 2a.
                                If we let d1 and d2 bet the distances from the foci to the point, then | d1 - d2 | = 2a.
                             The absolute value is around the difference so that it is always positive.
                                 You can use that definition to derive the equation of a hyperbola, but I'll give you
                             the short form below.
                                  The only difference in the definition of a hyperbola and that of an ellipse is that the
                             hyperbola is the difference of the distances from the foci that is constant and the ellipse
                             is the sum of the distances from the foci that is constant.
Instead of the equation being (x/a)2 + (y/b)2 = 1, the equation is (x/a)2 - (y/b)2 = 1.
                             Standard Forms
                             The table below summarizes the standard forms for the three main conic sections
                             based on the direction of the main axis. For a parabola, the axis is the "axis of
                             symmetry" and divides the parabola in half. For the ellipse, it's called the "major axis"
Interpolated Curves
Interpolation method can be applied to draw curves that pass through a set of the given
data points. The resulting curve can be a straight line, quadratic, cubic, or higher order
curve. We are quite familiar, and have used, the linear interpolation of a straight line,
given by the formula
                           f(x) = f(xi) + [f(xi+1) – f(xi)] [(x-xi) / (xi+1 – xi)]
     Now, we will discuss the higher order curves, which are represented by higher order
polynomials. Lagrange polynomial is a popular polynomial function used for
interpolation of high order polynomials.
                                                                                        Amity Directorate of Distance & Online Education
38                                                                                                                     Computer Graphics
Lagrange Polynomial
Notes                        When a sequence of planar points (x0, y0), (x1, y1), (x2, y2), ….(xn, yn) is given, the nth
                             degree of interpolated polynomial can be calculated by the Lagrange Polynomial
                             equatio n,
                                                   fn (x) = Σ yi Li,n (x)                                                        (4.10)
                                  where,
                                  Li,n (x) = [(x – x0)….(x –xi-1) (x – xi+1)….(x – xn)]/[(xi –x0)….(xi –xi-1) (xi –xi+1)….(xi –xn)]
                             To understand the above expression better, note that
                             z    The term (x –xi) is skipped in the numerator, and
                             z    The denominator starts with the term (xi –x0) and skips the term (xi –xi), which will
                                  make the expression equal to infinity.
                             Example: Using the Lagrange polynomial, find the expression of the curve containing
                             the points, P0(1, 1), P1(2, 2), P2(3, 1)
                             Solution:
                                Here, n = 2 and x0 =1, y0 = 1, x1 = 2, y1 = 2, etc. The polynomial is of a second
                             degree. Expanding the Lagrange equation, we get,
                                  f2 (x) = y0 [(x - x1) (x - x2)] / [(x0 – x1) (x0 – x2)] + y1 [(x – x0) (x - x2)] /
[(x1 – x0) (x1 – x2)] + y2 [(x – x0) (x – x1)] / [(x2 – x0) (x2 – x1)]
                                  =    (1) [(x – 2) (x – 3)] / [(1 – 2) (1 – 3)] + (2) [(x-1) (x – 3)] / [(2 – 1) (2 – 3)] + (1)
                                       [(x – 1) (x - 2)] / [(3 – 1) (3- 2)]
                                  =    ½ (x2 – 5x + 6) – 2 (x2 – 4x + 3) + ½ (x2 – 3x + 2)
                                  or f2 (x) = - x2 + 4 x – 2
                                 This is the explicit non-parametric equation of a circle; the given points lie on the
                             circumference.
Notes
    A cubic polynomial is the lowest degree polynomial that can guarantee a C2 curve.
Higher order polynomials are not used in CAD, because they tend to oscillate about the
control points and require large data storage. Major CAD/CAM systems provide three
types of synthetic curves: Hermite Cubic Spline, Bezier Curves, and B-Spline Curves.
     Cubic Spline curves pass through all the data points and therefore they can be
called as interpolated curves. Bezier and B-Spline curves do not pass through all the
data points, instead, they pass through the vicinity of these data points. Both the cubic
spline and Bezier curve have first-order continuity, whereas, B-Spline curves have a
second-order continuity.
Notes
                               Figure 2.12: Lower-left section of a screen area with coordinate positions referenced by
                                                                 grid intersection lines
                               Figure 2.14: Line path for two connected line segments between screen grid-coordinate
                                                                      positions
Notes
   Figure 2.15: Line path and corresponding pixel display for grid endpoint coordinates
                                    (20, 10) and (30, 18)
Notes
                                 Figure 2.16: Wire-frame representation for a cylinder, showing only the front (visible)
                                             faces of the polygon mesh used to approximate the surfaces.
                                 In general, we can create fill areas with any boundary specification, such as a circle
                             or connected set of spline-curve sections.
                             2.11 Summary
                             Scan conversion is a process of representing a continuous graphical object as a
                             collection of discrete pixels. Each pixel can’t be represented by a single mathematical
                             point but it represents a region which theoretically consists of a large number of points.
                                  Polynomial method has disadvantages of too much floating point calculation and
                             non-uniformity of points. Trigonometric function has disadvantages of having
                             trigonometric calculations and multiplications. We can develop an efficient algorithm
                                   Objectives
                                   After studying this unit, you should be able to:
                                   z   Understand the concept transformation.
                                   z   Discuss the general pivot point rotation and scaling direction.
                                   z   Learn the concept of reflection and shearing
                             3.1 Introduction
                             2D geometric transformations are essential in transforming and visualizing our Model.
                             The affine basic transformation is translation, rotation and scale. The transformation
                             matrices are:
                                                       ⎡ 1 0 Tx ⎤      ⎡E x 0   0⎤       ⎡cos(α ) − sin(α ) 0⎤
                                                       ⎢        ⎥      ⎢          ⎥      ⎢ sin(α ) cos(α ) 0⎥
                                                   T = ⎢0 1 Ty ⎥ E =   ⎢ 0 Ey   0⎥ R =   ⎢                    ⎥
                                                       ⎢0 0 1 ⎥        ⎢0 0     1⎥⎦      ⎢⎣ 0         0     1⎥⎦
                                                       ⎣        ⎦      ⎣
                             We can combine several transformations in order to define more complex ones. For
                             example, rotating around an arbitrary point (xc, yc):
3.2 2D transformation
A point is represented in two dimensional coordinate system by two techniques:
1. Row-wise representation i.e. in 1-row and 2-columns in matrix form, it is written as:
          [x y]1x2                              In 2D
          [x y z]1x3                            In 3D
2. Column-wise representation i.e. in 2-rows and 1-column the matrix form is –
          ⎡x⎤
          ⎢y⎥                                   In 2D
          ⎣ ⎦ 2 ×1
          ⎡x⎤
          ⎢y⎥                                   In 3D
          ⎢ ⎥
          ⎣⎢ z ⎦⎥ 3 ×1
These are called the position vectors. A series of points are stored in a computer as
matrix or array of numbers.
This is the solution i.e. we find the value of transformation matrix [T] provided that [A]-1
exists.
Transformation of Points
Notes                        Let us consider a point P having coordinates [x y] and take a general 2x2 transformation
                             matrix [T]
                                                             ⎡a b ⎤
                             i.e.                      [T] = ⎢    ⎥
                                                             ⎣c d⎦ 2 × 2
                                                                             ⎡a b ⎤
                                                   [x* y*] = [X] [T] = [x y] ⎢    ⎥ = [(ax + cy) (bx + dy)] = [x* y*]
                                                                             ⎣c d⎦
                             This means that the initial coordinates of the point is (x, y) and after transformation the
                             coordinates of the point is (x*, y*).
                                          The value of         x* = ax + cy
                                                               y* = bx + dy
Special Cases
                                       ⎡a b ⎤
                             (i) [T] = ⎢    ⎥
                                       ⎣c d⎦
                                    Let            a=d=1
                                    and            c=b=0
                                          ⎡ 1 0⎤
                                    [T] = ⎢    ⎥
                                          ⎣0 1⎦
                                                          ⎡ 1 0⎤
                                    Thus, [X] [T] = [x y] ⎢    ⎥
                                                          ⎣0 1⎦
                                                    = [x y]
                                                    = [x* y*]
                                    There is no change in the original coordinates. In matrix algebra, multiplication with
                                    identity matrix remains same.
                             (ii) Let b = c = 0 and d = 1
                                          [x* y*] = [X] [T]
                                                            ⎡a 0 ⎤
                                                   = [ x y] ⎢    ⎥
                                                            ⎣0 1⎦
                                                   = [ax y]
                                    This shows the scale change in the coordinate of x because x* = ax but in the
                                    direction of y there is no change i.e. y* = y.
                             (iii) Let b = c = 0
                                          [X*]     = [X] [T]
                                                           ⎡a 0 ⎤
                                                   = [x y] ⎢    ⎥
                                                           ⎣ 0 d⎦
                                    [x* y*]        = [ax dy]
                                    This shows the scale change or scaling in the direction of x and y: If a = d the
                                    scaling is not equal.
                                                          (x2 y2)
                                   (x1 y1)
These points are also known as coordinates of the end points. Our aim is to change the
effect of transformation matrix when applied on these two points.
                             Let the coordinates of point A = [0 2] and B = [3 2] respectively. Now, consider the value
                             of transformation matrix [T]
Notes
                                              ⎡ 2 1⎤
                                        [T] = ⎢    ⎥                                (Assumed value)
                                              ⎣ 1 3⎦
                             The effect can be shown here as —
                                                 ⎡0 2⎤ ⎡ 2 1⎤
                                       [X] [T] = ⎢    ⎥⎢      ⎥
                                                 ⎣ 3 2⎦ ⎣ 1 3 ⎦
                                                                        x* = x1, x2
                                                                        y* = y1 y2
                                                 ⎡2 6⎤
                                       [x* y*] = ⎢    ⎥
                                                 ⎣8 9 ⎦
                                       or                               x1* = 2 y1* = 6
                                                                        x2* = 8 y2* = 9
                                                           y
B*
                                                       A          B
                                                                                  A*
                                                                                                        x
                                                       0                      x
                             3.3 2D Translation
                             In translation an object is displaced a given distance and direction from its original
                             position. If the displacement is given by the vector v = txI + tyJ, the new object point P'(x',
                             y') can be found by applying the transformation Tv to P(x, y). See the figure below
                                                                       P' = Tv(P)
                             where x' = x + tx and y' = y + ty.
                             As an example, consider a triangle defined by three vertices (20, 0), (60, 0), and
                             (40, 100) being translated 100 units to the right along the x-axis (tx = 100) and 10 units
                             up along the y-axis (ty = 10). The new vertices are (120, 10), (160, 10), and (140, 110),
                             see figure below:
If you want to move the rectangle 60 unit’s right and 80 units down, you can just change
the coordinates by adding to the x and y starting point: rect (20 + 60, 20 + 80, 40, 40)
and the rectangle will appear in a different place. (We put the arrow in there for dramatic
effect.)
But there is a more interesting way to do it: move the graph paper instead. If you
move the graph paper 60 units right and 80 units down, you will get exactly the same
visual result. Moving the coordinate system is called translation.
                             The important thing to notice in the preceding diagram is that, as far as the rectangle is
                             concerned, it hasn’t moved at all. Its upper left corner is still at (20, 20). When you use
Notes                        transformations, the things you draw never change position; the coordinate system
                             does.
                             Here is code that draws the rectangle in red by changing its coordinates, and then
                             draws it in blue by moving the grid. The rectangles are translucent so that you can see
                             that they are (visually) at the same place. Only the method used to move them has
                             changed. Copy and paste this code into Processing and give it a try.
                                  void setup()
                                  {
                                      size(200, 200);
                                      background(255);
                                      noStroke();
                             Let’s look at the translation code in more detail. pushMatrix() is a built-in function that
                             saves the current position of the coordinate system. The translate(60, 80) moves the
                             coordinate system 60 units right and 80 units down. The rect(20, 20, 40, 40) draws the
                             rectangle at the same place it was originally. Remember, the things you draw don’t
                             move—the grid moves instead. Finally, popMatrix() restores the coordinate system to
                             the way it was before you did the translate.
                             Yes, you could have done a translate(–60, –80) to move the grid back to its original
                             position. However, when you start doing more sophisticated operations with the
                             coordinate system, it’s easier to use pushMatrix() andpopMatrix() to save and restore
                             the status rather than having to undo all your operations. Later on in this tutorial, you
                             will find out why those functions seem to have such strange names.
                                  void setup()
                                  {
                                   size(400, 100);
                                   background(255);
3.4 2D Scaling
As we know in reflection the matrix used is identity, but in scaling in place of unit value
we place the parameter Sx and Sy which denote the scale change in the coordinates of
x and y respectively. After applying scaling factor or matrix in any object, coordinate is
either increased or decreased depending on the value of scaling factor Sx and Sy. If it is
greater than one, then enlargement of the object will take place and if it less than one,
than compression will occur.
In matrix form -
                         ⎡sx   0⎤
                   [T] = ⎢
                         ⎣0    s y ⎥⎦
or
In homogeneous form
                         ⎡sx   0        0⎤
                         ⎢                ⎥
                   [T] = ⎢ 0   sy       0⎥
                         ⎢0    0        1⎥⎦
                         ⎣
A transformation is any operation on a point in space (x, y) that maps the point's
coordinates into a new set of coordinates(x1,y1).
Scaling is the process of expanding or compressing the dimensions of an object.
Positive scaling constants Sx and Sy are used to describe changes in length with
respect to the x direction and y direction. A scaling constant > 1 creates an expansion
                                  void setup()
                                  {
                                   size(200,200);
                                   background(255);
                                    stroke(128);
                                    rect(20, 20, 40, 40);
                                   stroke(0);
                                   pushMatrix();
                                   scale(2.0);
                                   rect(20, 20, 40, 40);
                                   popMatrix();
                                  }
                             First, you can see that the square appears to have moved. It hasn’t, of course. Its upper
                             left corner is still at (20, 20) on the scaled-up grid, but that point is now twice as far
                             away from the origin as it was in the original coordinate system. You can also see that
                             the lines are thicker. That’s no optical illusion—the lines really are twice as thick,
                             because the coordinate system has been scaled to double its size.
                             Programming Challenge: Scale up the black square, but keep its upper left corner in the
                             same place as the gray square. Hint: use translate() to move the origin, then use
                             scale().
                             There is no law saying that you have to scale the x and y dimensions equally. Try
                             using scale (3.0, 0.5) to make the x dimension three times its normal size and
                             the y dimension only half its normal size.
                             3.5 2D Rotation
                             In this session our aim is to find the rotation of a body or object by some angle θ. To find
                             this result, consider the position vector from the origin to the point in polar form. The
                             rotation is always positive in anticlockwise or counter clockwise direction. Let the
p*
p (r, φ)
                   y*                              θ
                            y                ↑
                                               φ
                                                                               x
                                0
                                             x*
     Now, rotate the point P by an angle φ in anticlockwise direction, the point P is now
shifted to point P* i.e.
The position vector P = [x y] = [r cos φ r sin φ]
and                     P* = [x* y*] = [r cos(θ + φ) r sin(θ + φ)]
                        x* = r cos (θ + φ)
                        x* = r cos θ cos φ – r sin θ sin φ
since                    x = r cosφ y = r sinφ
∴                       x* = (r cos φ) cos θ – (r sin φ) sin θ
                        x* = x cosθ – y sinθ
since                   y* = r sin (θ + φ)
                           = r sin θ cos φ + r cos θ sin φ
                           = (r cos φ) sinθ + (r sin φ) cos θ
                        y* = x sin θ + y cos θ
since                   y* = x sinθ + y cos φ
      In matrix form
                       [X*] = [X] [T] = [X* Y*]
                                   ⎡ cos θ sin θ ⎤
                           = [x y] ⎢              ⎥
                                   ⎣ − sin θ cos θ⎦
      Thus, the transformation matrix for 2D rotation is -
                              ⎡ cos θ sin θ ⎤
                        [T] = ⎢              ⎥
                              ⎣ − sin θ cos θ⎦
                                                              ⎡ 1 0⎤
                                                            = ⎢    ⎥ = [I]
                                                              ⎣0 1⎦
                                  Where [I] is an identity matrix
                                  [T]t = transpose of the transformation matrix [T]
                                                              ⎡cos θ − sin θ⎤
                                                       [T]t = ⎢             ⎥ = [T]
                                                                                   –1
                                                              ⎣ sin θ cos θ ⎦
                                  The inverse of the transformation matrix [T] is same as the transpose of it.
                                 In rotation, the object is rotated ø° about the origin. The convention is that the
                             direction of the rotation is CCW if ø is a positive angle and CW if the ø is a negative
                             angle. The transformation for rotation Rø is
                                                                                 P' = Rø(P)
                             where x' = x cos(ø) - y sin(ø) and y' = x sin(ø) + y cos(ø)
                             For example a triangle (20,0), (60,0), (40,100) rotated 45²ºclockwise about the origin is
                             (14.14, -14.14), (42.43, -42.43), (98.99, -42.43)
                             In addition to moving the grid, you can also rotate it with the rotate() function. This
                             function takes one argument, which is the number of radians that you want to rotate. In
                             Processing, all the functions that have to do with rotation measure angles in radians
                             rather than degrees. When you talk about angles in degrees, you say that a full circle
                             has 360º. When you talk about angles in radians, you say that a full circle has
Since most people think in degrees, Processing has a built-in radians() function which
takes a number of degrees as its argument and converts it for you. It also has
a degrees() function that converts radians to degrees. Given that background, let’s try
rotating a square clockwise 45 degrees.
    void setup()
    {
     size(200, 200);
     background(255);
     smooth();
     fill(192);
     noStroke();
     rect(40, 40, 40, 40);
     pushMatrix();
     rotate(radians(45));
     fill(0);
     rect(40, 40, 40, 40);
     popMatrix();
    }
Hey, what happened? How come the square got moved and cut off? The answer is: the
square did not move. The grid was rotated. Here is what really happened. As you can
see, on the rotated coordinate system, the square still has its upper left corner at
(40, 40).
Notes
And here is the code and its result, without the grid marks.
    void setup()
    {                                                                                               Notes
     size(200, 200);
     background(255);
     smooth();
     fill(192);
     noStroke();
     rect(40, 40, 40, 40);
      pushMatrix();
      // move the origin to the pivot point
      translate(40, 40);
    void setup() {
     size(200, 200);
     background(255);
     smooth();
     noStroke();
    }
    void draw(){
     if (frameCount % 10 == 0) {
     fill(frameCount * 3 % 255, frameCount * 5 % 255,
     frameCount * 7 % 255);
     pushMatrix();
     translate(100, 100);
                             3.6 2D Shear
                             A shear is a transformation that distorts the shape of an object along either or both of
                             the axies. Like scale and translate, a shear can be done along just one or along both of
                             the coordinate axes. A shear along one axis (say, the x-axis) is performed in terms of
                             the point's coordinate in the other axis (the y-axis). Thus a shear of 1 in the x-axis will
                             cause the x-coodinate of the point ot distort by 1*(y-coordinate).
                             To shear in the x direction the equation is:
                                                     x1 = x + ay
                                                     y1 = y
                                       Where b = 0
                             Where x1 and y1 are the new values, x and y are the original values, and a is the scaling
                             factor in the x direction. The matrix is as follows.
                                                                      ⎡ 1 a 0⎤
                                                                      ⎢0 1 0 ⎥
                                                                      ⎢       ⎥
                                                                      ⎢⎣0 0 1⎥⎦
                                                                      ⎡ 1 0 0⎤
                                                                      ⎢b 1 0 ⎥
                                                                      ⎢       ⎥
                                                                      ⎣⎢0 0 1⎥⎦
Example
                        y = -x
                                                              y=x
(-x, y) (x, y)
(x, -y)
Due to reflection the image is of the same size but opposite so we need an identity
matrix with -ve or + ve value depending on the situation.
1. The reflection about x-axis can be shown as —
         i.e. y = 0
               ⎡1 0 ⎤
         [T] = ⎢    ⎥
               ⎣0 −1⎦
2. Reflection about y-axis i.e. x = 0 can be shown as —
               ⎡ −1 0 ⎤
         [T] = ⎢      ⎥
               ⎣ 0 1⎦
3. Reflection about the line y = x is
               ⎡0 1⎤
         [T] = ⎢    ⎥
               ⎣ 1 0⎦
4. Reflection about y = –x is —
               ⎡ 0 −1⎤
         [T] = ⎢      ⎥
               ⎣ −1 0 ⎦
The value of the determinant for each reflection matrix is identically equal to –1.
If the determinant of a transformation matrix is identically equal to –1, then the
transformation produces a pure reflection. If two pure reflections are applied
successively, the result is pure rotation.
                             3.9 Composition
                             R(ø) rotates about the origin; to rotate about P1
                             z    Translate P1 to origin
                             z    Rotate
                             z    Translate origin back to P1
                             Windowing Transformations
                             Displaying an image of a picture involves mapping the coordinates of the points and
                             lines that form the picture into the appropriate coordinates on the device or workstation
                             where the image is to be displayed. This is done through the use of coordinate
                             transformations known as viewing transformations. To perform a viewing transformation
                             we deal with window and viewport.
Instance Transformation
The instance transformation scenario can be summarized as follows: different business
actors use ontologies to describe their internal business logic and their data. Each of
these actors use their own information system and they interact with each other as part
of arbitrary business processes. However as the ontologies of each of the actors is
likely to be different there is a need for a specialized service capable of transforming
data expressed in terms of a given ontology (the source ontology) into the terms of
another ontology (the target ontology), allowing the two actors to communicate
effectively, without changing the way they represent their data. As the instance
transformation occurs at run-time it has to be performed completely automatically using
mappings that have already been created at the schema level during a design-time
phase.
Significant effort has been invested by the Semantic Web community in methodologies
and tools for creating ontology mappings. Various techniques for mapping creation have
been developed; however less interest has been shown in the actual usage of the
created mappings and their application in concrete mediation scenarios. In this paper
we show how mappings can be converted to logical rules and evaluated by a Datalog
reasoned in order to produce the desired mediation result. The mediation scenario
discussed in this work is instance transformation: data expressed as ontology instances
is transformed from the terms of one ontology in to the terms of another ontology based
on mappings created in a design-time phase. We analyze the required reasoning task
and describe how the mappings created at design-time can be grounded at runtime. We
also explore strategies and techniques that we employed in order to improve the
efficiency of the overall process.
Ontology mapping is the most effective solution to achieve interoperability among
heterogeneous ontologies. There already exist many algorithms and tools for creating
mapping, but less research focus on the actual usage of the created mappings for a
specific task. This paper discusses the application of ontology mapping, and proposes
                             the framework MAIT for automatic instance transformation based on mapping, and
                             presents relative transforming algorithms. This framework can work in any ontology-
Notes                        based environment such as semantic Web, and transform the instance data between
                             source ontology and target ontology automatically. The experimental results reveal that
                             the framework and algorithms are feasible and effective.
                              ⎡ 1 0 x t ⎤ ⎡cos θ − sin θ 0⎤ ⎡ 1 0 − x t ⎤
                              ⎢0 1 y ⎥ ⎢ sin θ cos θ 0⎥ ⋅ ⎢0 1 − y ⎥
                              ⎢       t⎥⎢                  ⎥ ⎢        t⎥
                                               ⎡ 1 0 xi ⎤ ⎡s x          0     0⎤ ⎡ 1 0 x t ⎤ ⎡ s x                 0      x t (1 − s x )⎤
                                               ⎢        ⎥ ⎢                     ⎥                   ⎢                                   ⎥
                                               ⎢0 1 y j ⎥ ⋅ ⎢ 0        sy     0⎥ ⋅ ⎢⎢0 1 − y t ⎥⎥ − ⎢ 0           sy      y t (1 − s y )⎥
                                               ⎢0 0 1 ⎥ ⎢ 0             0     1⎥⎦ ⎣⎢0 0 1 ⎥⎦ ⎢⎣ 0                  0            1       ⎥
                                               ⎣        ⎦ ⎣                                                                             ⎦
                                 Suppose we want to transform object descriptions from the xy system to the x'y'
                             system:
Notes
⎢⎣ 0 0 1 ⎥⎦ ⎢⎣0 0 1 ⎥⎦
                                                                     ⎡ A b⎤
                                                                     ⎢0..0 1⎥
                                                                     ⎣      ⎦
                             while an element 1 is added at the bottom of column vectors:
                                                                        ⎡x⎤
                                                                        ⎢ 1⎥
                                                                        ⎣ ⎦
                                                           (homogeneous coordinates).
                                 An affine transformation is invertible if A is invertible. The invertible affine
                             transformations form the affine group, which has the general linear group of degree n as
                             subgroup and is itself a subgroup of the general linear group of degree n+1.
                                 The similarity transformations form the subgroup where A is a scalar times an
                             orthogonal matrix. Iff the determinant of A is 1 or -1 then the transformation preserves
                             area; these also form a subgroup. Combining both conditions we have the isometries,
                             the subgroup of both where A is an orthogonal matrix.
                             Each of these groups has a subgroup of transformations which preserve orientation:
                             those where the determinant of A is positive. In the last case this is in 3D the group of
                             rigid body motions (proper rotations and pure translations).
                             3.16 Summary
                             We have examined the basic types of transformation: translation, scale, rotation and
                             shear. A transformation may be either an object transformation in which the points of
                             the object are transformed, or an axis transformation in which the coordinate axes are
                             transformed and the object points re-expressed relative to the new axes. All of these
                             transformations can be expressed in a 3×3 matrix which is multiplied with the vector for
                             a point to obtain the coordinates of the transformed point. A 3×3 matrix is used to
                             enable different transformations to be combined by multiplying the matrices together.
                             This means that a 2D point to be transformed must be represented as a three-
                             dimensional homogeneous point (x, y, 1). After transformation we have the point (x', y',
                             w'). The real-world 2D coordinates are obtained by dividing the x- and y-components by
                             the w-component.
                                  (c) Differences
                                  (d) only b
Notes
                             9. To change the position of a circle or ellipse we translate
                                  (a) Center coordinates
                                  (b) Center coordinates and redraw the figure in new location
                                  (c) Outline coordinates
                                  (d) All
                             10. The basic geometric transformations are
                                  (a) Translation
                                  (b) Rotation
                                  (c) Scaling
                                  (d) All
                                   Objectives
                                   After studying this unit, you should be able to:
                                   z   Understand the concept of viewing pipeline.
                                   z   Learn the concept of viewing Transformations.
                                   z   Understand the window-to-viewport coordinate T\transformation.
                             4.1 Introduction
                             A typical rendering system will start out with each object being defined in its own local
                             coordinate system. The origin may be some convenient point in the object, for example
                             the center of a sphere. Using a local coordinate system gives an object independence
                             from any other objects in a scene and aids the object modeling stage.
                                 The position and orientation of each object is then defined to construct a scene.
                             Therefore the first stage of the viewing pipeline is to convert each object from its local
                             coordinate system into the world coordinate system (modeling transformation). Once
                             the scene is constructed, the position of the camera is defined in order to generate a
                             picture of the scene. The definition of the camera is an important component with in a
                             rendering package. Several parameters such as its position, orientation, position and
                             size of the film etc. need to be defined in order to define a complete camera model.
2D Viewing-Transformation Pipeline
Notes
                             Procedure:
                             1. Set up viewing-coordinate origin at some world position Po(xo,yo)
                             2. Set up orientation of reference frame
                                  E.g. One could set up view-up vector or one can compute component of u = (ux,
                                  uy) & v = (vx,vy)
                             3. Obtain matrix for converting world coordinates to viewing coordinates
                                  (i) Translate viewing origin to world origin
                                  (ii) Rotate to align two coordinate reference frame
                                                                         MWC YC = R T
TV S V S W TW X
Window-Viewport Mapping
Notes
                             4.6 Clipping
                             Clipping is a procedure used to identify which portion of the graphical object is within or
                             outside the specified region. Region in which we want to show a graphical object is
                             called clip window or we can say that “clipping” is used for avoiding the drawing of
                             things outside the camera’s field of view.
                                  Clipping also refers to removal of part of a graphical object. Clipping can be either
                             external or internal clipping. In external clipping remove parts inside a region and in
                             internal clipping we remove parts of a picture outside the region.
                             We discuss following types of clipping:
                             z    Point clipping
                             z    Line clipping
                             z    Polygon clipping
                             2. Second bit is assigned 1 if point lies below AD line i.e. y coordinate of point < ymax.
                             3. Third bit is assigned 1 if it lies right to CD line i.e. x coordinate of point >xmax.
Notes
                             4. Fourth bit is assigned 1 if it lies Left to AB line i.e. x coordinate of point<xmin.
     We divide such line into two parts by investigating the line endpoint and finding
intersection with the clipping window. These two newly obtained lines are goes under
further investigation from the starting whether they will be considered as completely
inside, completely outside or clipping candidate.
Finding intersection
     Consider four coordinates A(xmin, ymin), B(xmin, ymax), C(xmax, ymax) and D(xmax,ymin) of
clipping window.
    If first bit is 1, Intersect with line y    = ymax
    If second bit is 1, Intersect with line y = ymin
    If third bit is 1, Intersect with line x    = xmax
    If fourth bit is 1, Intersect with line x   = xmin
    Intersection point can be obtained using slope-intercept form. If given two endpoints
are p1(x1,y1) and p2(x2,y2), m=(y2-y1)/(x2-x1)
     For vertical boundary x = xmin or x=xmax
                               y = y1+m(x-x1)
  For horizontal boundary y = ymin or y=ymax
                               Y = y1+m(x-x1)
                            y-y1 = m(x-x1)
                               x = x1+(y-y1)/m
Notes
    Consider p2>0 extended line segment goes from inside of right boundary to outside.
Similarly p3 = -dy = -(y2 - y1) = (y1 - y2) <0 then y1 < y2 and line goes from outside of
bottom boundary to inside and if p4 > 0, line goes from inside of top boundary to
outside.
Summary
1. Find pi and qi for i=1 to 4
2. If there exist same k for which pk=0, find that qk so that
    (a) If qk < 0, line is completely outside the boundary and we reject that line.
    (b) If qk e ³ 0, line is completely inside the clipping window.
3. (a) If pk<0 line proceed from outside to inside to particular clipping boundary.
    (b) If pk>0 line proceed from inside to outside to particular clipping boundary.
                                                                            Amity Directorate of Distance & Online Education
82                                                                                                      Computer Graphics
                             4. Determination of u1: For p<0 (as p<0 is used for outside to inside), determining u1
                                by finding rk=qk/pk for k in which pk<0. Value of u1 is largest from 0 and all other
Notes                           values of r.
                             5. Determination of u2: For p>0 (as p>0 is used for coming from inside to outside),
                                determining u2 by finding rk=qk/pk for k in which pk>0. Value of u2 is minimum
                                amongst 1 and different value of rk.
                             6. If u1>u2 Lines are completely outside the clipping window and rejected. Otherwise
                                endpoint of lines visible in clipping window are u1 and u2.
                             Example 4.1
                                  Rejected line
    Out of all possible nine regions we consider first three regions (Region-1, Region-5
and Region-6). If a point lies in other 6 region we can move those points to these three
regions (using 2D transformation).
    After finding p1 position we find position of p2 relative to p1 depending upon the
position of p2, we create four more regions.
    Case 1: If P1 is in clipping window (Region-5) and p2 is outside the clipping window.
Notes
Figure 4.19: The possible two regions set when P1 is left and above the clip window
                                First important thing of NLN algorithm is to find out the exact region for p2.Consider
                             case-1 in which p1 lies in viewing window and p2 in region-1.
                                  Slope of a line with endpoint (x1,y1) and (x2,y2) between can be found by (y2-y1)/
                             (x2-x1)
                                  Now p2 lies in region-1 if slope p1p2 lies in between slope p1B and p1D.
                             Example 4.2: Given the clipping window coordinate are A(0,0), D(10,0), B(0,10),
                             C(10,10) and line with endpoints are with p1(-5,3) and p2(15,9). Clip the line using
                             Liang-barsky algorithm.
Notes
Notes
                             (d) If vi-1 is in right and vi is on left of clipping edge, find intersection of vi-1vi and clipping
                                 window edge AB call it x and add x, vi in clipped polygon.
Notes
                                  This process is shown in following figure 4.23:
                                 Consider following polygon XYVZ and clipping window ABCD Clip the Polygon
                             against CD and show each step by step
                                  Start from XY edge and clipping edge consider BC following steps are used:
                             1. Extend BC line and XY intersection let M, we add M in output point visible in
                                clipping window.
Example 4.4:
Notes
                             4.7 Summary
                             The real scene taken through a 2D camera is represented using modeling coordinates
                             into a world coordinate system which is user specified. In the World Coordinate system ,
                             an area is selected which is to be displayed called Window. Further World coordinates
                             are converted to viewing coordinates as per the viewing plane and the viewing direction
                             of the user. Further it is transformed into normalized coordinate system which is a
                             standard coordinate system having x extent between 0 and 1. Y-extent is also between
                             0 and 1.Further the normalized coordinate system is converted to physical display
                             device coordinate system on which an area is chosen where the image is displayed
                             called viewport.
                                  The viewport transformation maps Normalized device coordinates into window
                             (screen) coordinates. The viewport is the rectangular region of the window where the
                             image is drawn; normally the viewport is measured in window coordinates relative to the
                             lower-left corner of the window. The viewport transformation determines the actual size
                             in pixels of the displayed object
      Objectives
      After studying this unit, you should be able to:
      z   Understand the concept of Polygon surfaces, polygon meshes and polygon
          table.
      z   Learn about plane equations and quadric surfaces
      z   Understand the concept of Bezier curve and Bezier surface
5.1 Introduction
We can rotate an object about an axis with any spatial orientation in three-dimensional
space. Two-dimensional rotations, on the other hand, are always around an axis that is
perpendicular to the xy plane. Viewing transformations in three dimensions are much
more cornplicated because we have many more parameters to select when specifying
how a three-dimensional scene is to be mapped to a display device. The scene
description must be processed through viewing-coordinate transformations and
projection routines that transform three-dimensional viewing coordinates onto two-
dimensional device coordinates. Visible parts of a scene, for a selected view, must be
identified; and surface-rendering algorithms must he applied if a realistic rendering of
the scene is required.
                                 Polygon and quadric surfaces provide precise descriptions for simple Euclidean
                             objects such as polyhedrons and ellipsoids.
Notes
                                Spline surfaces and construction techniques are useful for designing aircraft wings,
                             gears and other engineering structure with curved surfaces.
                                 Procedural methods such as fractal constructions and particle systems allow us to
                             give accurate representations for clouds, clumps of grass and other natural objects.
                             Physically based modelling methods using systems of interacting forces can be used to
                             describe the non-rigid behaviour of a piece of cloth or a glob of jello.
                                 Octree encodings are used to represent internal features of objects; such as those
                             obtained from medical CT images. Isosurface displays, volume renderings and other
                             visualization techniques are applied to 3 dimensional discrete data sets to obtain visual
                             representations of the data.
Ax + By + Cz + D = 0
Notes                            The coefficients A, B and C define the normal to the plane. [A B C]. We can obtain
                             the coefficients A, B, C and D by solving a set of 3 plane equations using the coordinate
                             values for 3 non collinear points in the plane. Suppose we have 3 vertices on the
                             polygon (x1, y1, z1), (x2, y2, z2) and (x3, y3, z3).
                                  Ax + By + Cz + D = 0
                                  (A/D) x1 + (B/D) y1 + (C/D) z1 = -1
                                  (A/D) x2 + (B/D) y2 + (C/D) z2 = -1
                                  (A/D) x3 + (B/D) y3 + (C/D) z3 = -1
                                  the solution for this set of equations can be obtained using Cramer‘s rule as,
                                                    A = 1 y1 z1
                                                        1 y2 z2
                                                        1 y3 z3
                                                    B = x1 1 z1
                                                        x2 1 z2
                                                        x3 1 z3
                                                    C = x1 y1 1
                                                        x2 y2 1
                                                        x3 y3 1
                                                    D = _ x1 y1 z1
                                                        x2 y2 z2
                                                        x3 y3 z3
                                  We can write the calculations for the plane coefficients in the form
                                  A = y1 (z2 - z3) + y2 (z3 – z1) + y3 (z1 – z2)
                                  B = z1 (x2 - x3) + z2 (x3 – x1) + z3 (x1 – x2)
                                  C = x1 (y2 - y3) + x2 (y3 – y1) + x3 (y1 – y2)
                                  D= - x1 (y2 z3 – y3 z2) – x2 (y3 z1 – y1 z3) – x3 (y1 z2 – y2 z1)
                               Figure 5.3: The vector N, Normal to the surface of a plane described by the equation Ax +
                                                  By + Cz + D = 0, has Cartesian components (A, B, C)
                                 High quality graphics systems typically model objects with polygon meshes and set
                             up a database of geometric and attribute information to facilitate processing of the
Notes                        polygon facets. Fast hardware-implemented polygon renderers are incorporated into
                             such systems with the capability for displaying hundreds of thousands to one million br
                             more shaded polygons per second (usually triangles), including the application of
                             surface texture and special lighting effects.
                             Sphere
                             A spherical surface with radius r centered on the coordinate origin is defined as the set
                             of points (x, y, z) that satisfy the equation
                                                                    x2 + y2 + z2 = r2
                             in parametric form, the equation of a sphere is
                             x = r. Cos Ǿ. Cosθ                 -Π/2 <= Ǿ <= Π/2
                             y = r. Cos Ǿ. Sin θ                -Π <= Ǿ <= Π
                             z = r. sin Ǿ
Notes
Figure 5.8: Parametric coordinate position(r,θ,Ǿ) on the surface of a sphere with radius r
Ellipsoid
An ellipsoidal surface is described as an extension for a spherical surface, where the
radii in 3 mutually perpendicular directions can have different values. The points over
the surface of an ellipsoid centered at the origin is
                                ( x / rx )2 + ( y / ry )   + ( z / rz ) = 1
                                                       2             2
Figure 5.9: An ellipsoid with radii rx, ry, and rz centered on the coordinate origin
     The parametric representation for the ellipsoid in terms of the latitude angle Ǿ and
the longitude angle θ in Figure 5.9 is
                             Torus
                             The torus is a doughnut shaped object. It can be generated by rotating a circle or other
                             conic about a specified axis. The Cartesian representation for points over the surface of
                             a torus can be written as
                                  We can describe the parametric representation of a torus are similar to those for an
                             ellipse, except that angle Ǿ extends over 360º. The parametric representation for the
                             etorus in terms of the latitude angle Ǿ and the longitude angle θ
                             x = rx(r+ cosǾ)cosθ,              -Π<= Ǿ <= Π
                             Super ellipse
                             The Cartesian representation for a super ellipse is obtained from the equation of an
                             ellipse by allowing the exponent on the x and y terms to be variable.
                                  The equation of a super ellipse is:
                                    x       y
                                      2s +    2s = 1
                                   rx      ry
                                  The parameters can be assigned any real value. When s = 1, we get an ordinary
                             ellipse. Corresponding parametric equations for the superellipse can be expressed as
                                  x = rx cossθ,                -Π<= Ǿ <= Π
                                             s
                                  y = ry sin θ,
                             Figure 5.11 illustrates super circle shapes that can be generated using various values
                             for parameter s.
Notes
Figure 5.11: Super ellipses plotted with different values for parameter s and with rx=ry
Super Ellipsoid
The Cartesian representation for a super ellipsoid is obtained from the equation of an
ellipsoid.
                              x         y      s2 z
                                2 s2 +    2 s2   + 2 s1 = 1
                             rx        ry      s1 rz
          Figure 5.12: Super ellipsoids plotted with different values for parameters
                              s1 and s2 and with rx = ry = rz
                                                                             Amity Directorate of Distance & Online Education
102                                                                                                     Computer Graphics
                                               f(x, y, z) =   ∑ f(r ) − T
                                                               k
                                                                     k
                                                       rk =     (x − x k )2 + (y − yk )2 + (z − zk )2
                                                                         2
                             Where,                 f(rk) = bk e − ak r k or f(rk) = bk e − ak rk
Notes
Figure 5.15: A composite blobby object formed with four Gaussian bumps
Interpolation Splines
We specify a spline curve by giving a set of coordinate positions, called control points.
    When polynomial sections are fitted so that the curve passes through each control
points, the resulting curve is said to interpolate the set of control points.
Approximation Splines
When the polynomials are fitted to the general control-point path without necessarily
passing through any control point, the result curve is said to approximate the set of
control points.
    -e.g., Bezier curves, B-spline curves
Notes
                                 The convex polygon boundary that encloses a set of control points is called the
                             convex hull. A convex set S is a set of points such that if x, y are in S so is any point
                             on the line between them.
                             Parametric Continuity
                             For parametric continuity, we view the curve or surface as a function rather than a
                             shape. Parametric continuity cannot be defined given only the shape of the curve. You
                             need a parameterization of it.
Geometric Continuity
Geometric continuity can be defined using only the shape of the curve. It is usually
defined in terms of parameterizations, but the choice of parameterization does not affect
the outcome.
    A junction between two curves is said to be G0-continuous if the (x, y, z)-values of
the two curves agree. Alternatively, this is called zeros-order geometric continuity. It is
exactly the same as C0 continuity.
     A junction between two curves is said to be G1-continuous if the (x, y, z)-values of
the two curves agree, and all their first derivate (dx/ds, dy/ds, dz/ds) are
proportional (the tangent vectors are parallel) at their junction. Alternatively, this is
called first-order geometric continuity.
    Higher order geometric continuity is a bit tricky to define. One way to do it is to use
arc length-based definitions of derivatives. That is, if the nth-order derivatives of the two
curve wrt an arc length parameter s, then the curve is Gn continuous at the junction.
                                  So the vector of initial values (x(1), x(0), x'(1), x'(0)) is a linear function of the vector
                             (a, b, c, d), given by a 4x4 matrix M. By inverting M, we can write (a, b, c, d) as a linear
Notes                        function of the vector (x(1), x(0), x'(1), x'(0)).
                                In fact, we can think of the rows of the matrix M as defining a new polynomial basis.
                             That basis gives the polynomial equation directly in terms of the constraints:
                                                     x(u) = (2u3 - 3u2 + 1) x(0)
                                                             + (-2u3 + 3u2) x(1)
                                                             + (u3 - 2u2 + u) x'(0)
                                                             + ( u3 - u2) x'(1)
                                 The old basis was just the power basis, where the basis polynomials are powers of
                             u. The new basis consists of polynomials which are
                                                   H0 (u) = (2u3 - 3u2 + 1)
                                                   H1 (u) = (-2u3 + 3u2)
                                                   H2 (u) = (u3 - 2u2 + u)
                                                   H3 (u) = (u3 - u2)
                                  This is called a Hermite basis. It’s the natural basis to use when you want to
                             interpolate through known points with known first derivatives. Once you have computed
                             the Hermite polynomials, there is almost no work to do to derive an interpolating curve
                             from the endpoint constraints. It’s simply a sum of the basis polynomials weighted by
                             the constraints x (0), x (1), x'(0) and x'(1).
                                The shape of the Hermite polynomials is intuitive. Look at the graphs in Hearn and
                             Baker to see how their values and derivatives support their role in interpolation.
                                  Natural Cubic Splines
                                 Often you don’t want to specify the derivatives at all intermediate points along a
                             curve, you simply want them to be the same for the curve on both sides of a via point. If
                             you add the condition that derivatives agree, you get equations like
                                                    x1(1) = x2(0) = p1
                                                   x1'(1) = x2'(0)
                                                   x1''(1) = x2''(0)
                                 That is, 4 equations for each intermediate point. At the two endpoints, if you specify
                             the point location and the first derivative, you get exactly 4n-4 equations, which is
                             enough to specify the parameters of n-1 cubic curves to interpolate all the points.
                             Solving this system yields a natural cubic spline to interpolate the points with
                             C2 continuity.
                                 Its disadvantage is the the entire curve shape depends on all of the via point
                             positions. Changing any one of them changes the entire curve.
    P0 and P3 define the start and endpoints of the curve. P1 and P2 determine the initial
direction of the curve. Hence, the curve is determined by 2 endpoints and the slope of
two line segments (P1 - P0 and P2 - P3).
    The parametric formula for the Bezier curve given 4 control points is the following:
    PB = (1-t) 3 P1 + 3t (1-t) 2 P2 + 3t2 (1-t) P3 + t3 P4
    With 0<= t <=1
    In the general case, for n control points, the following applies (u = t):
                                            n
                                                  ⎛n ⎞
                                  P(u) =   ∑ ⎜⎝k ⎟⎠ (1 − u)
                                           k =0
                                                             n−k
                                                                   ukPk u ∈ R
                                While the algorithm is slower than directly using the parametric formula, it is
                             numerically more stable. Implement de Casteljau's algorithm for rendering (cubic)
Notes                        Bezier curves.
                             Uniform B-Splines
                             B-splines are a generalization of Bezier-curves. Given a set of n control points, a B-
                             spline will approximate the curve piece-wise by means of a number of Bezier-curves.
                                  Let's say we have m control points: P0, P1... Pm. If we want to approximate the
                             curve defined by these control points by means of cubic (3rd degree) Bezier curves, we
                             will generate a number of curves Q3, Q4...Qm (i.e. # curve segments = # control points -
                             3). Each curve segment Qi is defined by the control points Pi-3, Pi-2, Pi-1 and Pi. E.g. Q4
                             is a Bezier curve defined by P1, P2, P3, P4, and Q5 is defined by P2, P3, P4, P5 and
                             so on.
                                  The mathematical formula for a curve given 4 control points (with 0 < t < 1) is:
                                  The advantage of using a B-spline rather than one big Bezier curve is that a B-
                             spline is smoother at join points and requires less computation when a single control
                             point is moved. A Bezier curve would have to be recalculated completely, while with the
                             B-spline, only the 4 curves that depend on the control point need to be recalculated
                             Where:
                                                                    n!
                                                   Jn,i (u) =              ui (1 − u)n − i
                                                                i!(n − i)!
                                                                    m!
                                                   Km,j(w) =                w j (1 − w)m − j
                                                                 j!(m − j)!
Notes
Shape Control
Q(u, w) = [U]N[B][M][W]
                                                                                    T
                                                      [W] = ⎡⎣ W n   W n −1 … 1⎤⎦
                                                           ⎧B0,0 … … B0,m ⎫
                                                           ⎪                ⎪
                                                           ⎪                ⎪
                                                        B= ⎨                ⎬
                                                           ⎪                ⎪
                                                           ⎪⎩Bn,0 … … Bn,m ⎪⎭
                                   Objectives
                                   After studying this unit, you should be able to:
                                   z   Describe two dimensional transformations
                                   z   Describe and distinguish between two dimensional geometric and
                                       coordinate transformations
                                   z   Describe composite transformations
                                   z   Describe shear transformations
                             6.1 Introduction
                             When we model and display a 3D scene there are many more considerations we must
                             take into account besides just including coordinate values for the third dimension.
                             Manipulation, viewing and construction of three-dimensional graphic images requires
                             the use of 3D geometry and coordinate transformation. These transformations are
                             formed by composing the basic transformations of translation, scaling and rotation.
                             Each of these transformations can be represented as a matrix transformation. This
                             permits more complex transformations to be built up by use of matrix multiplication or
                             concatenation.
                                 The ability to represent or display a 3D object is fundamental to the understanding
                             of the shape of that object. The ability to rotate, translate and project views of that
                             object, is also fundamental to the understanding of its shape. To do this with a computer
                             we must extend our previous 2D analysis to three dimension.
Notes
    Each type of graphic has it's own advantages and disadvantages. Older versions of
HTML were only able to recognizes bitmapped graphics so most graphics created for
the Internet, using standard HTML, are created or converted to a bitmap format. The
newest version of HTML or XHTML is able to display vector graphics but not all
browsers are able to display these graphics.
    Within each of the two main types there are dozens of different formats.
    Graphics formats are distinguished by their filename extensions.
    The three main bitmapped format graphics used on the Internet are .gif, .jpeg (.jpg)
and .png. There are many others including .bmp, .tiff (.tif), .pcx, .ppm, .tga and a host of
others.
    Some of the structured formats are .ai, .cmx, .eps, .wpg, .cgm and a host of others.
    Bitmapped graphics can be created and modified in a paint program and vector or
structured graphics can be created and modified in a draw program.
    The main tools in a graphics program allow you to select a section of a
picture, erase part of a picture, fill a defined area, select a colour, magnify a section,
draw free hand, draw with various tools such as a straight line; a curved line; a
rectangle; an oval; and a polygon. You can also modify a drawing by changing the size,
colour, placement, and, depending on the program, hundreds of other modification.
Sound
Moving Picture Experts Group (MPEG) or .mpg is multimedia format that is an attempt
to create a standardization among the various formats available. MPEG has made it
possible to place audio content on your website without having it sound tiny and hollow
or taking an extreme amount of time to download. There are many different formats for
sound including; Microsoft's .wav, Sun's .au & .snd, RealNetwork's RealAudio , .ra(*),
and various others.
     You may have heard.mid files play when visiting various websites. Musical
Instruments Digital Interface (MIDI) files are basically sound tracks which use a
collection of sounds contained in the .mid file to play a tune.
      To create a sound file you will need an audio program. You can then record with a
microphone or off of a prerecorded medium. Your computer will need to have a sound
card properly installed and a speaker to hear your recording. You can save the sound
file to play back later.
Animation
With the advent of faster computers comes animation. Though it has been around for
years the modern computer has made it possible to include animation in programs
                             without causing them to slow down (much). As with every multimedia format there are a
                             number of types.
Notes
                                 You may have seen.gif animations on this website. A GIF animation is a series of
                             separate images or frames that display one after the other to give the impression of
                             movement. Other formats are Audio Visual Interleave's .avi, the before mentioned mpg,
                             Microsoft's Media Player .wmv, Apple's Quick Time .qt, .aif(*) & .mov, RealNetwork's
                             RealVideo .rm(*), Macromedia's Flash creates Shockwave.swf, and JavaScript as well
                             as various others.
                                 There are various animation or multimedia players available for a free download off
                             the Internet.
                                 To create animations, sounds or graphics you will need a program that has the
                             capabilities you want. Visit the various multimedia company websites to read up on their
                             product to see if they can do what you want. Most companies offer free trials that you
                             can download from their website.
                                You should also be aware that most media content placed on the Internet is
                             considered published material and therefore copyright unless explicitly stated otherwise.
                                 Same as object-oriented graphics, refers to software and hardware that use
                             geometrical formulas to represent images. The other method for representing graphical
                             images is through bit maps, in which the image is composed of a pattern of dots. This is
                             sometimes called raster graphics. Programs that enable you to create and manipulate
                             vector graphics are called draw programs, whereas programs that manipulated bit-
                             mapped images are called paint programs.
                                 Vector-oriented images are more flexible than bit maps because they can be
                             resized and stretched. In addition, images stored as vectors look better on devices
                             (monitors and printers) with higher resolution, whereas bit-mapped images always
                             appear the same regardless of a device's resolution. Another advantage of vector
                             graphics is that representations of images often require less memory than bit-mapped
                             images do.
                                 Almost all sophisticated graphics systems, including CADD systems and animation
                             software, use vector graphics. In addition, many printers (PostScript printers, for
                             example) use vector graphics. Fonts represented as vectors are called vector fonts,
                             scalable fonts, object-oriented fonts, and outline fonts.
                                 Note that most output devices, including dot-matrix printers, laser printers, and
                             display monitors, are raster devices (plotters are the notable exception). This means
                             that all objects, even vector objects, must be translated into bit maps before being
                             output. The difference between vector graphics and raster graphics, therefore, is that
                             vector graphics are not translated into bit maps until the last possible moment, after all
                             sizes and resolutions have been specified. PostScript printers, for example, have a
                             raster image processor (RIP) that performs the translation within the printer. In their
                             vector form, therefore, graphics representations can potentially be output on any device,
                             with any resolution, and at any size.
                                 In vector graphics, shapes, lines, curves and points are used to represent or create
                             an image in computer graphics. Creating vector graphics in today's environment is
                             similar to learning to use a word processing program. The lines and points of vector
                             graphics allow a lot of flexibility in which one can design.
Significance
In raster graphics, an image is made up of pixels. Pixel is simply a short form of picture
elements. Picture elements are small dots from which a picture is made. The greater
the density of the dots, the better the image quality. So, when such images are
magnified, they give a grainy appearance. When magnified beyond a point, they
become blurred. The quality degrades with positive scaling or an increase in the size of
an image. The images also change when the screen resolution is changed. This is the
case with bitmap images. These images also require more memory to store the images
and the files are larger in size.
Considerations
An advantage of using vector graphics is that a vector based images can be scaled
infinitely without degradation. There is absolutely no loss of clarity even if the image is
made 1,000 times larger or smaller. This is because raster graphic images are based
on pixels but vector graphics are not. Vector graphics are made up of mathematical
equations that adjust themselves to the magnitude of the image.
Function
Both for creating and editing vector graphic images, vector graphic drawing software is
needed. Minor changes in the mathematical formulas are done to make any changes in
the image. Stretching, twisting and color changes can be easily done by the user. The
graphical user interface of this software is very intuitive. The size of the vector image
depends on the screen resolution for which the image will be generated.
Warning
One drawback with the vector graphic is that it may not be supported on some systems.
Also some system may not support the vector graphic that was originally generated
from some other computer. In other words, vector graphics generated from different
computers may be incompatible. To overcome this situation, a vector graphic can also
be converted into a bitmap image easily, although reversing this is not simple.
Obviously, once converted, the vector graphic image will lose its advantages and not be
very scalable like before. It will just be like any other bitmap image.
Misconceptions
In the past, many people have thought of or considered vector graphics or geometric
graphics to be somewhat on the boring side. Due largely in part to advances in
technology, there are some amazing programs available now in which exciting and
unusual graphics can be created.
                             5. Go to the menu bar at top and select "Path," then click on "Trace Bitmap."
                             6. Select the option for "Colors" on the lower left, then increase the number of "Scans"
Notes                           a few times and click on the bar labeled "Update" below the preview image. Raising
                                the number of scans increases the resolution of the image, which also increases the
                                file size and speed of rendering. Experiment with the settings to find what works
                                best for your purpose with your computer's capacity. Remember to click "Update"
                                each time you change a setting.
                             7. Save the image as one of the vector image formats provided. An EPS file is a good
                                choice for most applications.
                                                         ⎡a b c p ⎤
                                                         ⎢ d e f q⎥
                                                   [T] = ⎢        ⎥                                                …(2)
                                                         ⎢g i j r ⎥
                                                         ⎢        ⎥
                                                         ⎣ l m n 1⎦ 4 × 4
                                 The 4 × 4 transformation matrix in equation (2) can be partitioned into four separate
                             sections i.e.
3 X1
3 X3
1X3 1X1
                                 The upper left 3×3 submatrix produces a linear transformation in the form of
                             scaling, shearing, reflection and rotation. The 1×3 lower left submatrix produces
                             translation and the upper right 3×1 submatrix produces a perspective transformation.
                             The final lower right-hand 1×1 submatrix produces overall scaling. This transformation
                             matrix [T] will be applied on homogeneous coordinate position vector and will yield
                             shearing, local scaling, rotation, reflection, translation, perspective and overall scaling.
                             3D Translation
                             The general 4×4 transformation matrix is:
                                                         ⎡a b c p ⎤
                                                         ⎢ d e f q⎥
                                                   [T] = ⎢        ⎥
                                                         ⎢g i j r ⎥
                                                         ⎢        ⎥
                                                         ⎣ l m n 1⎦ 4 × 4
                                 The element of the 4th row of order 1×3 are shown T the translation value i.e. l, m,
                             n are the translations in the x, y and z direction The matrix for translation is –
Amity Directorate of Distance & Online Education
Overview of Graphics System                                                                                                             119
                              ⎡1 0       0 0⎤
                              ⎢0 1       0 0 ⎥⎥
                        [T] = ⎢                                                                                                    Notes
                              ⎢0 0       1 0⎥
                              ⎢               ⎥
                              ⎣1 m       n 1⎦ 4 × 4
                                     ⎡1 0                     0 0⎤
                                     ⎢0 1                     0 0 ⎥⎥
         [x ' y ' z ' h] = [x y z 1] ⎢
                                     ⎢0 0                     1 0⎥
                                     ⎢                             ⎥
                                     ⎣1 m                     n 1⎦
3D Scaling
The diagonal terms of the general 4×4 transformation matrix produce local and overall
scaling. To illustrate this, consider the transformation matrix i.e.
                                          LM a    0 0 0         OP LM s  x   0    0    0 OP
     [x* y* z* 1] = [X] [T] ] = [x y z 1] M                   P0P or MM 00                P
                                              0   e 0         0              sy   0    0
                                           MM 0   0       j
                                                                 P MN 0      0    sz   0P
                                                                                          P
                                            N0    0 0         1Q             0    0    1Q
[x * y * z * 1] = [ax ey jz 1]
or [x * y * z * 1] = [s x x s y y sz z 1] (…3)
                                   ⎡1                 0       0   0⎤
                                   ⎢0                 1       0   0 ⎥⎥
       [x * y * z * 1] = [x y z 1] ⎢
                                   ⎢0                 0       1   0⎥
                                   ⎢                                 ⎥
                                   ⎣0                 0       0   S⎦
   If S<1, a uniform expansion of the position vector occurs and if S>1, a uniform
compression of the position vector occurs.
    ScaleTransform3D changes the model's scale by a specified scale vector with
reference to a center point. Specify a uniform scale, which scales the model by the
same value in the X, Y, and Z axes, to change the model's size proportionally. For
example, setting the transform's ScaleX, ScaleY, and ScaleZproperties to 0.5 halves
                             the size of the model; setting the same properties to 2 doubles its scale in all three
                             axes.
Notes
                             Scale Vector Example
                                  To scale a model "in place," specify the center of the model by setting the
                             ScaleTransform3D's CenterX, CenterY, and CenterZ properties. This ensures that the
                             graphics system scales the model space and then translates it to center on the
                             specified Point3D. Conversely, if you've built the model about the origin and specify a
                             different center point, expect to see the model translated away from the origin.
                             3D Rotation
                             We examine rotation about each of the coordinate axes. For rotation about the x-axis,
                             the x-coordinates of the position vectors do not change. In effect the rotation occurs in
                             planes perpendicular to x-axis. Same is the rotation about the y-axis and z-axis, which
                             occurs in planes perpendicular to the y and z-axis respectively. The transformation of
                             the position vectors in each of these planes is governed by the general 2D-Rotation
                             matrix i.e.
         LM cos ψ          sin ψ      0 0       OP
      T =M                                       P
            − sin ψ        cos ψ      0       0
          MM 0               0        1       0P
                                                 P
           N 0               0        0       1Q
                                                                                         ...(6)
    And rotation by an angle φ about the y-axis the transformation is
          ⎡cos φ     0 − sin φ        0⎤
          ⎢ 0        1    0           0 ⎥⎥
    [T] = ⎢
          ⎢ sin φ    0 cos φ          0⎥
          ⎢                              ⎥
          ⎣ 0        0    0           1⎦
     In equation (7) the signs of the sine terms are reversed from those of equation (5)
and (6) this is in order to maintain the positive right-hand rule convention. The equations
(5), (6) & (7) show that the determinant of each transformation matrix is +1 as required
for pure rotation.
   Since 3D rotation are obtained using matrix multiplication, they are non-
commutative, i.e. the order of multiplication affects the final result. In order to show this,
consider a rotation about x-axis followed by an equal rotation about the y-axis by using
equations (5) & (7) with θ = φ Now we have,
        LM 1 0                0       0 OP LMcos θ    0 − sin θ 0      OP
     T =M                             P0P MM sin0 θ                     P
             0 cos θ        sin θ     0               1       0      0
         MM0 − sin θ        cos θ
                                         PM           0      cos θ   0P
                                                                        P
          N0 0                0       1Q N 0          0       0      1Q
          LM cos θ             0          − sin θ     0    OP
     T =M                                                   PP
               sin θ
                 2
                            cos θ         cos θ sin θ 0
           MMcos θ sin θ    − sin θ        cos 2 θ    0
                                                             P
            N 0               0                  0        1Q
   on the other hand, the reverse operation i.e. a rotation about the y-axis followed by
equal rotation about the x-axis with θ = φ yields,
                                       LMcos θ           0 − sin θ 0 1     OP LM       0       0   0 OP
                                    T =M                                    PM                        P
                                               0         1        0      0 0       cos θ sin θ     0
Notes
                                        MM sin θ         0       cos θ   0 P M0
                                                                            PM     − sin θ cos θ   0P
                                                                                                      P
                                         N0              0        0      1Q N0        0      0     1Q
                                         LMcos θ            sin2 θ     − cos θ sin θ 0       OP
                                    T =M                                                      PP
                                               0            cos θ          sin θ     0
                                          MM sin θ       − cos θ sin θ   cos θ
                                                                             2
                                                                                     0
                                                                                               P
                                           MN 0                  0                 0       1PQ
                                It shows that they are not the same. The fact that 3D – rotations are non-
                             commutative must be kept in mind when more than one rotation is to be made.
                             3D Shearing
                             The off diagonal terms in the upper left 3x3 submatrix of the general 4x4 transformation
                             matrix produce shear in 3D i.e.
                                                           ⎡ 1 b c 0⎤
                                                           ⎢ d 1 f 0⎥
                                  [x* y* z* 1] = [x y z 1] ⎢        ⎥
                                                           ⎢ g i 1 0⎥
                                                           ⎢        ⎥
                                                           ⎣0 0 0 1⎦
                                  or [x* y* z* 1] = [x + yd + gz bx + y + iz cx + fy + z 1]                         .…(8)
                             3D Reflection
                             Some orientations of a 3D object can not be obtained using pure rotations, they require
                             reflections. In 3D reflection occurs through a plane. But in 2D, reflection occurs through
                             an axis. In 3D the value of the determinant for pure reflection matrix is identically equal
                             to –1.
                                 In a reflection through the xy plane, only the z-coordinate values of the objects
                             position vectors change i.e. they are reversed in sign. Thus the transformation matrix for
                             a reflection through the xy plane is-
                                        ⎡1       0 0              0⎤
                                        ⎢0       1 0              0⎥⎥
                                  [T] = ⎢
                                        ⎢0       0 −1             0⎥
                                        ⎢                           ⎥
                                        ⎣0       0 0              1⎦
                                        ⎡ −1         0       0    0⎤
                                        ⎢0           1       0    0⎥⎥
                                  [T] = ⎢
                                        ⎢0           0       1    0⎥
                                        ⎢                           ⎥
                                        ⎣0           0       0    1⎦
                                        ⎡1 0                 0    0⎤
                                        ⎢0 −1                0    0⎥⎥
                                  [T] = ⎢
                                        ⎢0 0                 1    0⎥
                                        ⎢                           ⎥
                                        ⎣0 0                 0    1⎦
Translation
In translation, an object is displaced a given and direction from its original position. If the
displacement is given by the vector v = txl + tyJ, the new object point P'(x', y') can be
found by applying the transformation Tv to P(x, y).
                                           P' = Tv(P)
where x' = x cos(θ) – y sin(θ)
Notes                        Scaling is the process of expanding or compressing the dimension of an object. Positive
                             scaling constants Sx and Sy, are used to describe changes in length with respect to the
                             x direction and y direction, respectively. A scaling constant greater than one indicates
                             an expansion of length, and less than one, compression of length. The scaling
                             transformation is given by SSx Sy is given by P' = SSx Sy (P) where x' = sx.x and y' = sx.y.
                             Notice that after a scaling transformation is performed, the new object is located at a
                             different position relative to the origin. In fact, in a scaling transformation the only point
                             that remains fixed is the origin (Figure 6.3).
                                 If both scaling constants have the same value s, the scaling transformation is said
                             to be homogeneous. Furthermore, if s > 1, it is a magnification and for s < 1, a reduction
Translation
If the xy coordinate system is displaced to a new position, where the direction and
distance of the displacement is given by the vector v = txI + tyJ, the coordinates of a
point in both systems are related by the translation transformation Tv :
where x' = x – tx
and      y' = y – ty
                             the coordinates in the new system are related to coordinates in the old system through
                             the scaling transformation Ssx ,sy :
Notes
                                                                   (x', y') = Ssx ,sy (x, y)
where x' = x and y' = −y'. For reflection about the y axis [figure 6.8(b)]
                                 Notice that the reflected coordinate system is left-handed; thus reflection changes
                             the orientation of the coordinate system.
Then
                             6.7 Summary
Notes                        Transformation is a process carried out by means of transformation to these object or
                             changing the orientation of the object or may be combination of these. In translation, an
                             object is displaced a given and direction from its original position. If the new coordinate
                             system is obtained by reflecting the old system about either x or y axis, the relationship
                             between coordinates is given by the coordinate transformations. Scaling is the process
                             of expanding or compressing the dimension of an object. Multiplying the basic matrix
                             transformations can do complex transformations. Shear transformation distorts an
                             object by scaling one coordinate using the other in such a way as if the object were
                             composed of internal layers that has been caused to slide over each other.
                             ⎡ 1 b c 0⎤
                             ⎢ d 1 f 0⎥
    [x* y* z* 1] = [x y z 1] ⎢        ⎥
                             ⎢ g i 1 0⎥
                             ⎢        ⎥
                             ⎣0 0 0 1⎦
      Objectives
      After studying this unit, you should be able to:
      z   Explain the concept of viewing pipeline.
      z   Describe viewing co-ordinate.
      z   Discuss the projection.
      z   Explain clipping
7.1 Introduction
We can view an object in three dimensions from any spatial position; eg.one can view
either the object from the front of an object, behind the object or from the middle of a
group of objects. One can also view an inside of an object.
    Three dimensional descriptions of objects must be projected onto the flat viewing
surface of the output device. The clipping boundaries enclose a volume of space.
Notes
Notes
    Finally, we choose the up direction for the view by specifying view-up vector V. This
vector is used to establish the positive direction for the yv axis. The vector V is
perpendicular to N. Using N and V; we can compute a third vector U, perpendicular to
both N and V, to define the direction or the xv axis.
                                 Second, we apply rotations to align the xv, yv and zv axes with the world xw, yw and
                             zw axes, respectively.
Figure 7.8: Rotations to align the xv, yv and zv axes with the world xw, yw and zw axis
         ⎡1   0      0             0⎤
         ⎢0 cos θ − sin θ          0⎥⎥
    Rx = ⎢
         ⎢0 sin θ cos θ            0⎥
         ⎢                           ⎥
         ⎣0   0      0             1⎦
Then, we rotate around the world yw axis to align the zw and zv axes.
         ⎡ cos α      0 sin α      0⎤
         ⎢ 0          1   0        0⎥⎥
    Ry = ⎢
         ⎢ − sin α    0 cos α      0⎥
         ⎢                           ⎥
         ⎣ 0          0   0        1⎦
    The final rotation is about the world zw axis to align the yw and yv axes. The
complete transformation from world to viewing coordinate transformation matrix is
obtained as the matrix product.
    Mwe,ve = R z ⋅ R y ⋅ R x ⋅ T
7.5 Projections
Once the description of the objects in a scene is converted to image we can project the
3D objects onto 2D view-plane. Two types of projections are-
1. Parallel Projection
2. Perspective Projection
Parallel Projection
Parallel Projection transforms object positions to the view plane along parallel lines. A
parallel projection preserves relative proportions of objects. Accurate views of the
various sides of an object are obtained with a parallel projection. But not a realistic
representation. Coordinate Positions are transformed to the view plane along parallel
lines.
                                                                   ⎡ x '⎤ ⎡1   0   0   0⎤ ⎡ x ⎤
                                                                   ⎢ y '⎥ ⎢            0⎥⎥ ⎢⎢ y ⎥⎥
                                                                   ⎢ ⎥ = ⎢0    1   0
                                                                   ⎢ z '⎥ ⎢0   0   0   0⎥ ⎢ z ⎥
                                                                   ⎢ ⎥    ⎢              ⎥⎢ ⎥
                                                                     1
                                                                   ⎣ ⎦    ⎣0   0   0   1⎦ ⎣ 1⎦
                             2. Oblique parallel projection: The parallel projection is not perpendicular to the view
                                plane. The projectors are still orthogonal to the projection plane but the projection
                                plane can have any orientation with respect to the object. It is used extensively in
                                architectural and mechanical design.
                                 Some special Orthographic Parallel Projections involve Plan View (Top projection),
                             Side Elevations, and Isometric Projection:
                             Preserve parallel lines but not angles, has three different views
                             1. Isometric view: Projection plane is placed symmetrically with respect to the three
                                principal faces that meet at a corner of object.
                             2. Diametric view: Symmetric with two faces.
                             3. Trimetric view: General case
Notes
Isometric Projection
Notes
                                   ⎡ xp ⎤  ⎡1      0 L1 cos ϕ 0⎤ ⎡ x ⎤
                                   ⎢y ⎥    ⎢       1 L1 sin ϕ 0⎥⎥ ⎢⎢ y ⎥⎥
                                   ⎢ p ⎥ = ⎢0
                                   ⎢ zp ⎥  ⎢0      0     0    0⎥ ⎢ z ⎥
                                   ⎢ ⎥     ⎢                    ⎥⎢ ⎥
                                   ⎣1⎦     ⎣0      0     0    1⎦ ⎣ 1⎦
                             Perspective Projections
                             First discovered by Donatello, Brunelleschi, and DaVinci during Renaissance Objects
                             closer to viewer look larger. Parallel lines appear to converge to single point .In
                             perspective projection object positions are transformed to the view plane along lines
                             that converge to a point called the projection reference point (or center of projection)
                                 When we do 3-D graphics, we think of the screen as a 2-D window onto the 3-D
                             world. The geometry of the situation is that of similar triangles. View from above:
Notes
    Desired result for a point [x, y, z, 1] T projected onto the view plane
                                           x' x y' y
                                             = , =
                                           d z d z
                                   d⋅ x    x        d⋅ y    y
                            x' =        =     ,y' =      =     , z' = d
                                    z     z/d        z     z/d
7.6 Clipping
The purpose of 3D clipping is to identify and save all surface segments within the view
volume for display on the output device. All parts of objects that are outside the view
volume are discarded. Thus the computing time is saved.
    3D clipping is based on 2D clipping. To understand the basic concept we consider
the following algorithm:
Polygon Clipping
Assuming the clip region is a rectangular area,
    The rectangular clip region can be represented by xmin, xmax, ymin and ymax.
     Find the bounding box for the polygon: i.e. the smallest rectangle enclosing the
entire polygon.
   Compare the bounding box with the clip region (by comparing their xmin, xmax, ymin
and ymax).
    If the bounding box for the polygon is completely outside the clip region, the
polygon is outside the clip region and no clipping is needed.
     If the bounding box for the polygon is completely inside the clip region, the polygon
is inside the clip region and no clipping is needed.
     Otherwise, the bounding box for the polygon overlaps with the clip region and the
polygon is likely to be partly inside and partly outside of the clip region. In that case, we
clip the polygon against each of the 4 border lines of the clip region in sequence as
follows:
     Using the first vertex as the current vertex. If the point in the inside of the border
line, mark it as 'inside'. If it is outside, mark it as 'outside'.
    Check the next vertex. Again mark it 'inside' or 'outside' accordingly.
    Compare the current and the next vertices. If one is marked 'inside' and the other
'outside', the edge joining the 2 vertices crosses the border line.
Notes
                                 In this case, we need to calculate where the edge intersects the border (i.e.
                             Intersection between 2 lines).
                                  The intersection point becomes a new vertex and we mark it as 'synthetic'.
                                 Now we set the next vertex as the current vertex and the following vertex as the
                             next vertex, and we repeat the same operations until all the edges of the polygon have
                             been considered.
                                  After the whole polygon has been clipped by a border, we throw away all the
                             vertices marked 'outside' while keeping those marked as 'inside' or 'synthetic' to create
                             a new polygon.
                                 We repeat the clipping process with the new polygon against the next border line of
                             the clip region.
                                  This clipping operation results in a polygon which is totally inside the clip region.
                             7.7 Summary
                             The viewing-coordinate system is used in graphics packages as a reference for
                             specifying the observer viewing position and the position of the projection plane.
                             Projection operations convert the viewing-coordinate description to coordinate positions
                             on the projection plane. Conversion of objection descriptions from world to viewing
                             coordinates is equivalent to a transformation that superimposes the viewing reference
                             frame onto the world frame using the basic geometric. Parallel Projection transforms
                             object positions to the view plane along parallel lines. A parallel projection preserves
                             relative proportions of objects. Parallel lines appear to converge to single point .In
                             perspective projection object positions are transformed to the view plane along lines
                             that converge to a point called the projection reference point. The purpose of 3D
                             clipping is to identify and save all surface segments within the view volume for display
                             on the output device. All parts of objects that are outside the view volume are
                             discarded.
      Objectives
      After studying this unit, you should be able to:
      z   Understand Visible Surface Detection Methods
      z   Understand the various classification of Visible-Surface Detection Algorithms
8.1 Introduction
A major consideration in the generation of realistic graphics displays is identifying those
parts of a scene that are visible from a chosen viewing position. There are many
approaches we can take to solve this problem, and numerous algorithms have been
devised for efficient identification of visible objects for different types of applications.
Some methods require more memory, some involve more processing time, and some
apply only to special types of objects. We will be discussing the various classification of
Visible surface detection algorithms.
Notes                        Visible-surface detection algorithms are broadly classified according to whether they
                             deal with object definitions directly or with their projected images. These two
                             approaches are called object-space methods and image-space methods, respectively.
                             An object-space method compares objects and parts of objects to each other within the
                             scene definition to determine which surfaces, as a whole, we should label as visible. In
                             an image-space algorithm, visibility is decided point by point at each pixel position on
                             the projection plane.
                                 Most visible-surface algorithms use image-space methods, although object space
                             methods can be used effectively to locate visible surfaces in some cases. Line display
                             algorithms, on the other hand, generally use object-space methods to identify visible
                             lines in wireframe displays, but many imagespace visible-surface algorithms can be
                             adapted easily to visible-line detection. Although there are major differences in the basic
                             approach taken by the various visible-surface detection algorithms, most use sorting
                             and coherence methods to improve performance. Sorting is used to facilitate depth
                             comparisons by ordering the individual surfaces in a scene according to their distance
                             from the view plane.
                                 Coherence methods are used to take advantage of regularities in a scene. An
                             individual scan line can be expected to contain intervals (runs) of constant pixel
                             intensities, and scan-line patterns often change little from one line to the next.
                             Animation frames contain changes only in the vicinity of moving objects. And constant
                             relationships often can be established between objects and surfaces in a scene.
                             value is stored, and the surface intensity at that position is determined and in the same
                             xy location in the refresh buffer.
Notes
Figure 8.3
    If we are processing down a vertical edge, the slope is infinite and the recursive
calculations reduce to
                                                            B
                                                z' = z +
                                                            C
    An alternate approach is to use a midpoint method or Bresenham-type algorithm for
determining x values on left edges for each scan line. Also the method can be applied
to curved surfaces by determining depth and intensity values at each surface projection
point.
                                 For polygon surfaces, the depth-buffer method is very easy to implement, and it
                             requires no sorting of the surfaces in a scene. But it does require the availability of a
Notes                        second buffer in addition to the refresh buffer. A system with a resolution of 1024 by
                             1024, for example, would require over a million positions in the depth buffer, with each
                             position containing enough bits to represent the number of depth increments needed.
                             One way to reduce storage requirements is to process one section of the scene at a
                             time, using a smaller depth buffer. After each view section is processed, the buffer is
                             reused for the next section.
                                 If depth is >= 0, the number stored at that position is the depth of a single surface
                             overlapping the corresponding pixel area.
                                The intensity field then stores the RGB components of the surface color at that point
                             and the percent of pixel coverage.
                                 If depth < 0 this indicates multiple-surface contributions to the pixel intensity. The
                             intensity field then stores a pointer to a linked List of surface data
                                  Figure 8.9 illustrates the scan-line method for locating visible portions of surfaces
                             for pixel positions along the line. The active list for line 1 contains information from the
Notes                        edge table for edges AB, BC, EH, and FG. For positions along this scan line between
                             edges AB and BC, only the flag for surface S1 is on. Therefore no depth calculations are
                             necessary, and intensity information for surface S1, is entered from the polygon table
                             into the refresh buffer. Similarly, between edges EH and FG, only the flag for surface S2
                             is on. NO other positions along scan line 1 intersect surfaces, so the intensity values in
                             the other areas are set to the background intensity. The background intensity can be
                             loaded throughout the buffer in an initialization routine.
                                 For scan lines 2 and 3 in Fig. 4-17, the active edge list contains edges AD, EH, BC,
                             and FG. Along scan line 2 from edge AD to edge EH, only the flag for surface S1 is on.
                             But between edges EH and BC, the flags for both surfaces are on. In this interval, depth
                             calculations must be made using the plane coefficients for the two surfaces. For this
                             example, the depth of surface S1 is assumed to be less than that of S2, so intensities for
                             surface S1 are loaded into the refresh buffer until boundary BC is encountered. Then the
                             flag for surface S1 goes off, and intensities for surface S2 are stored until edge FG is
                             passed.
                                  We can take advantage of-coherence along the scan lines as we pass from one
                             scan line to the next. In Fig. 4-17, scan line 3 has the same active list of edges as scan
                             line 2. Since no changes have occurred in line intersections, it is unnecessary again to
                             make depth calculations between edges EH and BC. The two surfaces must be in the
                             same orientation as determined on scan line 2, so the intensities for surface S1 can be
                             entered without further calculations.
    If a depth overlap is detected at any point in the list, we need to make some
additional comparisons to determine whether any of the surfaces should be reordered.
    We make the following tests for each surface that overlaps with S. If any one of
these tests is true, no reordering is necessary for that surface. The tests are listed in
order of increasing difficulty.
1) The bounding rectangles in the xy plane for the two surfaces do not overlap
2) Surface S is completely behind the overlapping surface relative to the viewing
   position.
3) The overlapping surface is completely in front of S relative to the viewing position.
4) The projections of the two surfaces onto the view plane do not overlap.
    The coordinates for all vertices of S into the plane equation for the overlapping
surface and check the sign of the result. If the plane equations are set up so that the
outside of the surface is toward the viewing position, then S is behind S' if all vertices of
S are "inside" S‘.
Notes
                                 If tests 1 through 3 have all failed, we try test 4 by checking for intersections
                             between the bounding edges of the two surfaces using line equations in the xy plane.
Notes
    The tests for determining surface visibility within an area can be stated in terms of
these four classifications.
   No further subdivisions of a specified area are needed if one of the following
conditions is true:
z   All surfaces are outside surfaces with respect to the area.
z   Only one inside, overlapping, or surrounding surface is in the area.
z   A surrounding surface obscures all other surfaces within the area boundaries
Notes
                             8.3 Summary
                             Visible-surface detection algorithms are broadly classified according to whether they
                             deal with object definitions directly or with their projected images. These two
                             approaches are called object-space methods and image-space methods, respectively.
                             An object-space method compares objects and parts of objects to each other within the
                             scene definition to determine which surfaces, as a whole, we should label as visible. In
                             an image-space algorithm, visibility is decided point by point at each pixel position on
                             the projection plane.
                                 Most visible-surface algorithms use image-space methods, although object space
                             methods can be used effectively to locate visible surfaces in some cases. Line display
                             algorithms, on the other hand, generally use object-space methods to identify visible
                             lines in wireframe displays, but many image space visible-surface algorithms can be
                             adapted easily to visible-line detection. Although there are major differences in the basic
                             approach taken by the various visible-surface detection algorithms, most use sorting
                             and coherence methods to improve performance. Sorting is used to facilitate depth
                             comparisons by ordering the individual surfaces in a scene according to their distance
                             from the view plane.
                                 A fast and simple object-space method for identifying the back faces of a
                             polyhedron is based on the "inside-outside" tests. A commonly used image-space
                             approach to detecting visible surfaces is the depth-buffer method, which compares
                             surface depths at each pixel position on the projection plane. The A-buffer method is
                             an extension of the depth-buffer method. An image space method for identifying visible
                             surfaces The area-subdivision method takes advantage of area coherence in a scene
                             by locating those view areas that represent part of a single surface. We apply this
                             method by successively dividing the total viewing area into smaller and smaller
                             rectangles until each small area is the projection of part of a single visible surface or no
                             surface at all.