840 likes | 995 Views
Kinetic Data Structures and their Application in Collision Detection. Sean Curtis COMP 768 Oct. 16, 2007. Kinetic Data Structures. Motivation. Convex hull Points move with time Recalculate hull at each point O(n lg n) work at each time step
E N D
Kinetic Data Structuresand their Application in Collision Detection Sean Curtis COMP 768 Oct. 16, 2007
Kinetic Data Structures Motivation • Convex hull • Points move with time • Recalculate hull at each point • O(n lg n) work at each time step • Instead, define convex hull based on the points used • Only update hull when necessary Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation What happens to the CH when they start moving? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation • Simple solution • Take small time steps and recalculate the CH for each configuration of points. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation • Simple solution • Take small time steps and recalculate the CH for each configuration of points. • Takes O(n log n) work at each time step. • An alternative – observe the nodes that form the CH. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation Kinetic Data Structures -- COMP 768
Kinetic Data Structures Motivation • Create a data structure that associated the convex hull directly with the vertices that form it. • Use the trajectories of the nodes to determine when they enter or leave the CH list. • This is a Kinetic Data Structure. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Moving objects • Continuous motion. • Could maintain some property about the set by sampling over time and modifying the data structure supporting the property. • Danger of over- or under-sampling. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Configuration Function • A collection of continuous or discrete attributes for “mobile” data. • Ex. 1 For a convex hull, it is the ordered list of points on the hull. • Ex. 2 For the closest pair, it is,simply, the pair of nodes. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Kinetization • The process of transforming an algorithm on static data into a data structure appropriate for continuously changing data. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Flight plan • Information about a moving objects current motion. • The information need not be complete – no complete a priori knowledge necessary. • Flight plans can update based on interactions within the environment or with a user. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Global Event Queue • Means through which the object’s motion is connected to the data structure. • Narrow interface. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Certificates • A set of conditions which prove the configuration function. • The configuration function can only be invalidated when certificates change. • The change of the state of certificates are the events in the queue – certificate failure. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Quality • Ultimately, a KDS is “good” if the cost of processing a certificate failure is low. • How do we quantify this? Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Responsive • A low worst-case cost for processing a certificate failure. • This could include updating the proof, the configuration function, de-scheduling events and scheduling new events. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Efficient • The ratio between total events to external events is “small”. • “External” events affect the configuration function. • “Internal” events are events required to fix KDS internal structures. • External events represent a lower-bound on the amount of work. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Compact • The maximum number of events in the queue at any one time is roughly linear in the number of moving objects. Kinetic Data Structures -- COMP 768
Kinetic Data Structures Concepts • Localized • The maximum number of events in the queue dependent on a single object is “small”. • Being “local” implies being “compact”. Kinetic Data Structures -- COMP 768
Kinetic Data Structures 0 1 2 3 4 5 6 7 8 Simple ExamplePoints on a line What is the right-most point? x Kinetic Data Structures -- COMP 768
Kinetic Data Structures 0 1 2 3 4 5 6 7 8 Simple ExamplePoints on a line What is the right-most point? x Kinetic Data Structures -- COMP 768