Computer Graphics (CS 4300) 2010S: Lecture 2
Today
- HW1 due next class meeting!
- coordinate frames
- segments, rays, and intersections 2D
Coordinate Frames
- components of an
-dimensional vector
define a point
in an
-dimensional coordinate frame as a linear combination of the
-dimensional basis vectors
defining the frame - linear combination is computed as
data:image/s3,"s3://crabby-images/3c666/3c66687e34e8622376d48340d607a113a47b17f9" alt=""
- same as product of a matrix and a vector:
data:image/s3,"s3://crabby-images/ce97d/ce97dfc40b6440ab8f6f07523bacfac58e1b4f20" alt=""
- (general
multiplication and its uses in graphics will be covered later in the course) - technically, any set of
-dimensional vectors can form a basis for an
-dimensional frame as long as they are linearly independent - orthonormal bases are of particular interest: all
and for all
data:image/s3,"s3://crabby-images/02797/02797f43b3e34007b1cedc65c2540f232345948a" alt=""
- an orthonormal basis defines a Cartesian frame
- “standard” basis is
, so data:image/s3,"s3://crabby-images/4f8c7/4f8c78d6c92b24bcecb42545d3256607a41ccb4d" alt=""
- note this is right-handed; if we had defined
instead, it would have been left handed - there are always exactly two options for the “handedness” (chirality) of a 3D orthonormal basis
- right-handed coordinate frames are typical in graphics, but not totally universal
- it is often useful to define other local coordinate frames with arbitrary pose relative to the standard global frame
- pose of an object is its position plus its orientation
- we will cover this more formally later, but basically, the pose of a local frame is defined by the location of its origin
and an orthonormal basis data:image/s3,"s3://crabby-images/bc831/bc831cdb22a7f74c5d9d366c53a7efd26fd90d99" alt=""
- all of these are vectors in the global frame
- the matrix
defines the orientation of the local frame - to transform a vector
from the local to the global frame, compute data:image/s3,"s3://crabby-images/d412d/d412dc003e3765d1a6ec0ac97e34deb827c6fbfe" alt=""
- note this does not change the magnitude of the vector, only its direction
- this is because the columns of
are orthonormal
- since a vector is technically only a magnitude and a direction, with no specific “place in space”, no need for
in this operation - to transform a point or location
from the local to the global frame, compute data:image/s3,"s3://crabby-images/4215e/4215e4023d8b99e74fe32fd304d016cacc6515db" alt=""
- going the other way: to transform a vector
from the global to the local frame, compute data:image/s3,"s3://crabby-images/93721/93721c80c9cedbc37cf9acde0ec667c9efae4fe0" alt=""
- this uses the fact that the inverse of an orthogonal matrix is its transpose (show easy derivation from above eqn for
) - note this is the same as computing
, as in the text
- transforming a point or location
from the global to the local frame: solve above
eqn for data:image/s3,"s3://crabby-images/f0a56/f0a5655d2c26bcd56c947e7e6b41ea3a0d72b286" alt=""
data:image/s3,"s3://crabby-images/6535c/6535c6fd55bb348c2315a7231df0b37bff684113" alt=""
- note this is not the same as
data:image/s3,"s3://crabby-images/24643/246435afe94e9d283970d7676c14211251699ca1" alt=""
- there are algorithms to “square” up a set of vectors to ensure they are orthonormal
- also sometimes required to construct a basis given only two or one vector
- if given two non-parallel vectors, use cross product to produce third, and square up if necessary
- if given only one vector, first find some other non-parallel vector, then proceed as above
Rays and Segments
- points have already been discussed: an
-dimensional vector can be used to represent a point in
dimensions by giving a displacement relative to the origin in some coordinate frame - a ray is a continuum of points starting at some location and continuing in a straight line to infinity
- can be represented as a start point
plus a unit vector
giving the direction of the ray - def works in any dimension
- a line segment, or just a segment, is the continuum of points along a straight line between two given locations
- usually represented as the two endpoints, typically identified as start
and end data:image/s3,"s3://crabby-images/f0fad/f0fad0faeaa7c18d4bec24f3c2cee5211cb95751" alt=""
- can also represent as start and a displacement
from there to end- easy to convert:
data:image/s3,"s3://crabby-images/e4cf6/e4cf62472ea411acb0772413cecd0fd5e9b1e208" alt=""
- either def works in any dimension
- can define the “left” and “right” sides in 2D: stand at
and face along data:image/s3,"s3://crabby-images/fc1fd/fc1fd02aa6ac6ddf675df84ecc8f5c1e5ea405dc" alt=""
- on what side of the segment does a given point
fall?- compute
component of
, extending each to 3D with
: data:image/s3,"s3://crabby-images/fa828/fa828b757b5a7852a0eefb44fe8218afaaf2b28b" alt=""
- (note that
and
components of cross product of any two vectors each with
will be 0 anyway) - if positive,
is on left of segment - if zero,
is coincident with line through segment - if negative,
is on right of segment - this can be used e.g. to pick triangles in the plane
- unit normal
can also be used to answer this question (we will see this when studying line equations and the signed distance from a point to a line) - can parametrize points
along the segment as
where data:image/s3,"s3://crabby-images/36695/36695f0f20be94af16aaea3af2af651044e002b3" alt=""
- intersection of two 2D segments:
data:image/s3,"s3://crabby-images/2e1e0/2e1e0709c4e63a0f934540d3fbdc998c4a1d93c9" alt=""
- two linear equations in two unknowns
data:image/s3,"s3://crabby-images/25fb2/25fb23d5b9104fcdcb664dd44b749348d6f89b07" alt=""
data:image/s3,"s3://crabby-images/cdd9c/cdd9c04ce36574e23c1358c28269398302113428" alt=""
- rearranging into standard form,
data:image/s3,"s3://crabby-images/eb2a8/eb2a8dfa3bfe458a34b294ada14cb61459f52f41" alt=""
data:image/s3,"s3://crabby-images/b3e6c/b3e6c6fcf80bb4fbb7a24717afdaecfebdfc256f" alt=""
data:image/s3,"s3://crabby-images/0c8df/0c8df1cef7d871ac3715f7eb324a1df5fa83dffe" alt=""
- can solve for
and
(carefully):- e.g. use Cramer’s rule, watch out for “no solution”
- same result can be derived using law of sines and cross product
data:image/s3,"s3://crabby-images/69db5/69db5688dcc57293923a2e3a6585c737c3c95bb9" alt=""
- let
data:image/s3,"s3://crabby-images/214e1/214e187079edad2a25c9973ec77393d587955d4c" alt=""
- law of sines:
data:image/s3,"s3://crabby-images/7714b/7714b9805cb8702f12f1374fe4c3bc5a4976f2e4" alt=""
- treat
,
, and
as 3D vectors with data:image/s3,"s3://crabby-images/3c39b/3c39bd2c98762ef110957c3e4d7b79f6179630c0" alt=""
- thus, the magnitude any cross product will be just the z component
- let
data:image/s3,"s3://crabby-images/2c11b/2c11b2971130cd391b2f13d2efe3e35ffca178f2" alt=""
- let
data:image/s3,"s3://crabby-images/35417/35417041fc9db22aa1b3ff15fc8fa27b573dc705" alt=""
- let
data:image/s3,"s3://crabby-images/a49d0/a49d0e4e1b872444ae5f821259668f5536907a9b" alt=""
data:image/s3,"s3://crabby-images/bacfb/bacfbb5810ca97db7a9a36f051ced4aecda71c19" alt=""
data:image/s3,"s3://crabby-images/bbf86/bbf86f6a095090125c1321925cb61e33b8a1cd96" alt=""
data:image/s3,"s3://crabby-images/27b8d/27b8d678d6f1962570da0befd84355b71e427c34" alt=""
- similarly,
data:image/s3,"s3://crabby-images/1bb6e/1bb6ec1f7e52b62560f50c6a064d72fbc883bf45" alt=""
data:image/s3,"s3://crabby-images/9cb72/9cb72078bcde9ab521adb48bbe4cb86a97aa129a" alt=""
data:image/s3,"s3://crabby-images/25726/2572676751cd86a0cec5c55ac459c83d272bc6bd" alt=""
- if
segments are collinear - segments intersect iff
data:image/s3,"s3://crabby-images/7f761/7f76116d4c12284759b4128983a6740eb81f8a91" alt=""
- same math works for segment/ray and ray/ray intersection, except the condition for the ray(s) is that
data:image/s3,"s3://crabby-images/78259/782590c39a2d0ba49d61c598cb5efcd8db86ea7a" alt=""
Next Time
- HW1 due!
- lines in 2D
- “triangle asteroids” example
- output devices
- reading on website