community
directory
books
authors
images
encyclopedia

Email:
Password:
Register

Knowledgerush Search

 

Google
  Web knowledgerush


Search for images of Computational geometry


Message boards   Post comment

Computational geometry

General

In computer science, computational geometry is the study of algorithms to solve problems stated in terms of geometry. Some purely geometrical problems arise out of the study of computational geometric algorithms, and the study of such problems is also considered to be part of computational geometry.

The main driving force for the development of computational geometry as a discipline was progress in computer graphics, computer-aided design and manufacturing (CAD/CAM), but many problems in computational geometry are classical in nature.

Other important "customers" of computational geometry inlude Robotics (motion planning and visibility problems), Geographic Information Systems (GIS) (geometrical location and search, route planning), Integrated circuit design (IC geometry design and verification), computer-aided engineering (CAE) (programming of numerically controlled (NC) machines).

There are two main flavors of computational geometry:

  • Combinatorial Computational Geometry, also called Algorithmic Geometry, which deals with geometric objects as discrete entities.

  • Numerical Geometry, also called Machine Geometry, Computer-aided geometric design (CAGD), or Geometric Modeling which deals primarily with representation of real-world objects in form suitable for computer computations in CAD /CAM systems.

Often, the latter kind of computational geometry is considered to be branch of computer graphics and/or CAD, and the former one is called simply computational geometry.

Combinatorial Computational Geometry

The primary research is to develop efficient algorithms and data structures for solving problems in stated in terms of most basic geometrical objects: points, line segments, polygons, polyhedra, etc.

Some of these problems look so simple that some 40 years ago they were not perceived as problems at all. Consider, for example, the

  • Closest pair problem: Given N points in the plane, find two with the smallest distance from each other.

If one computes the distances between all pairs of points, there are N(N-1)/2 of them; one then picks the smallest one. This brute force algorithm has time complexity O(N2), i.e., its execution time is proportional to the square of the number of the points. One of milestones in computational geometry was an algorithm for the closest-pair problem of time complexity O(N log N).

For modern GIS, computer graphics, and integrated circuit design systems routinely handling tens and hundreds of million points the difference between N2 and N log N is the difference between seconds and days of computation. Hence the emphasis on computational complexity in computational geometry.

Some core algorithms:

Some computational geometry problems:

  • The museum problem. If a museum (represented by a polygon in the plane) wants to post guards (which see in all directions) to avoid getting robbed by a crook that could in principle drop from the ceiling, it is sufficient to post a guard at each vertex. This follows from the fact that all polygons can be triangulated. However, knowing that all triangulations can be colored using only three colors (see graph coloring), we get a proof and algorithm that we never need to put more than one guard for each three vertices.

  • The museum problem in three dimensions. If a museum is represented in three dimensions as a polyhedron, then putting a guard at each vertex will not ensure that all of the museum is under observation. Although all of the surface of the polyhedron would be surveilled, but there are points in the interior of the polyhedron which might not be under surveillance. (A picture of this would be good.)

  • Given a list of pairs of integers (for instance, representing the edges of a graph, we can ask whether it is possible to embed this graph in the plane (that is, draw it on a flat surface) without any edges crossing. This mildly overlaps with graph theory and graph drawing, but there is a complicated algorithm to answer this question efficiently.

  • Given a list of points, line segments, triangles, spheres or other convex objects, determine whether there is a separating plane, and if so, compute it.

  • Given two sets of points A and B, find the orthogonal matrix U which will minimize the distance between UA and B. In english, we're interested in seeing if A and B are simple rotations of one another.

Numerical geometry

This branch is also known as geometric modelling, computer-aided geometric design (CAGD), and may be often found under the keyword curves and surfaces.

Core problems are curve and surface modelling and representation.

The most important instruments here are parametric curves and parametric surfaces, such as Bezier curves, spline curves and surfaces.

First (and still most important) application areas are shipbuilding, aircraft, and automotive industries. However because of modern ubiquity and power of computers even perfume bottles and shampoo dispensers are designed using techniques unheard of by shipbuilders of 1960s.

Related topics

Referenced By

List of algorithms | List of basic discrete mathematics topics | List of geometry topics | List of mathematical proofs | List of mathematical topics | List of mathematical topics (A-C) | List of mathematics topics | List of proofs | Solid modeling | Solid modelling

 

Compose Your Message

Your Email Address or Pen Name (optional):
Subject:
Your Message:
 

 

 

 

 

 

This article is licensed under the GNU Free Documentation License. It uses material from the Wikipedia article "Computational geometry".

 

Contact UsPrivacy Statement & Terms of Use

 
Copyright © 1999-2003 Knowledgerush.com. All rights reserved.