Advanced Data Types and New Applications

Similar documents
Advanced Data Types and New Applications

Chapter 25: Spatial and Temporal Data and Mobility

Advanced Data Types and New Applications

Algorithms for GIS:! Quadtrees

R16 SET - 1 '' ''' '' ''' Code No: R

Multidimensional Indexing The R Tree

Introduction to Indexing R-trees. Hong Kong University of Science and Technology

Background: disk access vs. main memory access (1/2)

File. File System Implementation. File Metadata. File System Implementation. Direct Memory Access Cont. Hardware background: Direct Memory Access

Trees. Reading: Weiss, Chapter 4. Cpt S 223, Fall 2007 Copyright: Washington State University

Data Structures and Algorithms

Chapter 12: Indexing and Hashing

CS6401- Operating System QUESTION BANK UNIT-IV

Balanced Binary Search Trees. Victor Gao

Introduction to Indexing 2. Acknowledgements: Eamonn Keogh and Chotirat Ann Ratanamahatana

Chapter 13: Query Processing

Chapter 11: Indexing and Hashing

CMSC 754 Computational Geometry 1

CS 310 B-trees, Page 1. Motives. Large-scale databases are stored in disks/hard drives.

Chapter 12: Indexing and Hashing. Basic Concepts

CS301 - Data Structures Glossary By

CPSC / Sonny Chan - University of Calgary. Collision Detection II

! A relational algebra expression may have many equivalent. ! Cost is generally measured as total elapsed time for

Chapter 13: Query Processing Basic Steps in Query Processing

Announcement. Computer Architecture (CSC-3501) Lecture 20 (08 April 2008) Chapter 6 Objectives. 6.1 Introduction. 6.

CSIT5300: Advanced Database Systems

Database System Concepts, 6 th Ed. Silberschatz, Korth and Sudarshan See for conditions on re-use

Find the block in which the tuple should be! If there is free space, insert it! Otherwise, must create overflow pages!

would be included in is small: to be exact. Thus with probability1, the same partition n+1 n+1 would be produced regardless of whether p is in the inp

2-3 Tree. Outline B-TREE. catch(...){ printf( "Assignment::SolveProblem() AAAA!"); } ADD SLIDES ON DISJOINT SETS

Spatial Data Management

The Link Layer and LANs. Chapter 6: Link layer and LANs

Lecture 4: CRC & Reliable Transmission. Lecture 4 Overview. Checksum review. CRC toward a better EDC. Reliable Transmission

1. [1 pt] What is the solution to the recurrence T(n) = 2T(n-1) + 1, T(1) = 1

Extra: B+ Trees. Motivations. Differences between BST and B+ 10/27/2017. CS1: Java Programming Colorado State University

Spatial Data Management

CS 465 Program 5: Ray II

COMP3121/3821/9101/ s1 Assignment 1

Chapter 12: Query Processing. Chapter 12: Query Processing

Lecture 4, 04/08/2015. Scribed by Eric Lax, Andreas Santucci, Charles Zheng.

Computer Architecture Memory hierarchies and caches

Laboratory Module X B TREES

Physical Level of Databases: B+-Trees

Chapter 12: Indexing and Hashing

Module 1: Basics and Background Lecture 4: Memory and Disk Accesses. The Lecture Contains: Memory organisation. Memory hierarchy. Disks.

Link Layer and LANs 안상현서울시립대학교컴퓨터 통계학과.

Indexing. Week 14, Spring Edited by M. Naci Akkøk, , Contains slides from 8-9. April 2002 by Hector Garcia-Molina, Vera Goebel

CS/ECE 438: Communication Networks for Computers Spring 2018 Midterm Examination Online

Routing Protocols in MANETs

External Memory Algorithms for Geometric Problems. Piotr Indyk (slides partially by Lars Arge and Jeff Vitter)

Morphological Image Processing

Episode 3. Principles in Network Design

Trees. Eric McCreath

Coding for the Network: Scalable and Multiple description coding Marco Cagnazzo

Masters Exam. Fall 2004 Department of Computer Science University of Arizona

File. File System Implementation. Operations. Permissions and Data Layout. Storing and Accessing File Data. Opening a File

EXTERNAL SORTING. Sorting

CSE 190D Spring 2017 Final Exam Answers

The check bits are in bit numbers 8, 4, 2, and 1.

Silberschatz and Galvin Chapter 15

Lecture 25 of 41. Spatial Sorting: Binary Space Partitioning Quadtrees & Octrees

Lecture 8 The Data Link Layer part I. Antonio Cianfrani DIET Department Networking Group netlab.uniroma1.it

Spatial Queries. Nearest Neighbor Queries

Mass-Storage Structure

SolidFire and Pure Storage Architectural Comparison

kd-trees Idea: Each level of the tree compares against 1 dimension. Let s us have only two children at each node (instead of 2 d )

Chapter 3 A 3D Parity Bit Structure 1

Database System Concepts

Module 9: Binary trees

Organizing Spatial Data

Approximation Algorithms for Geometric Intersection Graphs

Universiteit Leiden Computer Science

Quiz for Chapter 6 Storage and Other I/O Topics 3.10

Lecture 3 February 9, 2010

Chap4: Spatial Storage and Indexing

Chapter 11: Indexing and Hashing

Chapter 11: Indexing and Hashing

CS 455/555 Intro to Networks and Communications. Link Layer

Cache introduction. April 16, Howard Huang 1

CHAPTER 5 PROPAGATION DELAY

Chapter 12: Query Processing

CS F-11 B-Trees 1

26 The closest pair problem

Database Applications (15-415)

Algorithm Performance Factors. Memory Performance of Algorithms. Processor-Memory Performance Gap. Moore s Law. Program Model of Memory I

Motivation for B-Trees

Chapter 16 Networking

9/29/2016. Chapter 4 Trees. Introduction. Terminology. Terminology. Terminology. Terminology

CISC 7310X. C11: Mass Storage. Hui Chen Department of Computer & Information Science CUNY Brooklyn College. 4/19/2018 CUNY Brooklyn College

Storing Data: Disks and Files

Lecture 6 The Data Link Layer. Antonio Cianfrani DIET Department Networking Group netlab.uniroma1.it

CMSC 424 Database design Lecture 12 Storage. Mihai Pop

Range Searching and Windowing

Intro to DB CHAPTER 12 INDEXING & HASHING

Links. CS125 - mylinks 1 1/22/14

COMP asynchronous buses April 5, 2016

Ray Tracing with Spatial Hierarchies. Jeff Mahovsky & Brian Wyvill CSC 305

Polygon Triangulation

Estimating the Free Region of a Sensor Node

Lecture 5. Treaps Find, insert, delete, split, and join in treaps Randomized search trees Randomized search tree time costs

Transcription:

C H A P T E R25 Advanced Data Types and New Applications Practice Exercises 25.1 What are the two types of time, and how are they different? Why does it make sense to have both types of time associated with a tuple? Answer: A temporal database models the changing states of some aspects of the real world. The time intervals related to the data stored in a temporal database may be of two types - valid time and transaction time. The valid time for a fact is the set of intervals during which the fact is true in the real world. The transaction time for a data object is the set of time intervals during which this object is part of the physical database. Only the transaction time is system dependent and is generated by the database system. Suppose we consider our sample bank database to be bitemporal. Only the concept of valid time allows the system to answer queries such as - What was Smith s balance two days ago?. On the other hand, queries such as - What did we record as Smith s balance two days ago? can be answered based on the transaction time. The difference between the two times is important. For example, suppose, three days ago the teller made a mistake in entering Smith s balance and corrected the error only yesterday. This error means that there is a difference between the results of the two queries (if both of them are executed today). 25.2 Suppose you have a relation containing the x, y coordinates and names of restaurants. Suppose also that the only queries that will be asked are of the following form: The query specifies a point, and asks if there is a restaurant exactly at that point. Which type of index would be preferable, R-tree or B-tree? Why? Answer: The given query is not a range query, since it requires only searching for a point. This query can be efficiently answered by a B-tree index on the pair of attributes (x, y). 1

2 Chapter 25 Advanced Data Types and New Applications 25.3 Suppose you have a spatial database that supports region queries (with circular regions) but not nearest-neighbor queries. Describe an algorithm to find the nearest neighbor by making use of multiple region queries. Answer: Suppose that we want to search for the nearest neighbor of a point P in a database of points in the plane. The idea is to issue multiple region queries centered at P. Each region query covers a larger area of points than the previous query. The procedure stops when the result of a region query is non-empty. The distance from P to each point within this region is calculated and the set of points at the smallest distance is reported. 25.4 Suppose you want to store line segments in an R-tree. If a line segment is not parallel to the axes, the bounding box for it can be large, containing a large empty area. Describe the effect on performance of having large bounding boxes on queries that ask for line segments intersecting a given region. Briefly describe a technique to improve performance for such queries and give an example of its benefit. Hint: You can divide segments into smaller pieces. Answer: Large bounding boxes tend to overlap even where the region of overlap does not contain any information. The following figure: R shows a region R within which we have to locate a segment. Note that even though none of the four segments lies in R, due to the large bounding boxes, we have to check each of the four bounding boxes to confirm this. A significant improvement is observed in the follwoing figure:

Practice Exercises 3 R where each segment is split into multiple pieces, each with its own bounding box. In the second case, the box R is not part of the boxes indexed by the R-tree. In general, dividing a segment into smaller pieces causes the bounding boxes to be smaller and less wasteful of area. 25.5 Give a recursive procedure to efficiently compute the spatial join of two relations with R-tree indices. (Hint: Use bounding boxes to check if leaf entries under a pair of internal nodes may intersect.) Answer: Following is a recursive procedure for computing spatial join of two R-trees. SpJoin(node n 1, node n 2 ) begin if(the bounding boxes of n 1 and n 2 do not intersect) return; if(both n 1 and n 2 are leaves) output all pairs of entries (e 1, e 2 ) such that e 1 n 1 and e 2 n 2, and e 1 and e 2 overlap; if(n 1 is not a leaf) NS 1 = set of children of n 1 ; else NS 1 = { n 1 }; if(n 1 is not a leaf) NS 1 = set of children of n 1 ; else NS 1 = { n 1 }; for each ns 1 in NS 1 and ns 2 in NS 2 ; SpJoin(ns 1, ns 2 ); end 25.6 Describe how the ideas behind the RAID organization (Section 10.3) can be used in a broadcast-data environment, where there may occasionally be noise that prevents reception of part of the data being transmitted.

4 Chapter 25 Advanced Data Types and New Applications Answer: The concepts of RAID can be used to improve reliability of the broadcast of data over wireless systems. Each block of data that is to be broadcast is split into units of equal size. A checksum value is calculated for each unit and appended to the unit. Now, parity data for these units is calculated. A checksum for the parity data is appended to it to form a parity unit. Both the data units and the parity unit are then broadcast one after the other as a single transmission. On reception of the broadcast, the receiver uses the checksums to verify whether each unit is received without error. If one unit is found to be in error, it can be reconstructed from the other units. The size of a unit must be chosen carefully. Small units not only require more checksums to be computed, but the chance that a burst of noise corrupts more than one unit is also higher. The problem with using large units is that the probability of noise affecting a unit increases; thus there is a tradeoff to be made. 25.7 Define a model of repeatedly broadcast data in which the broadcast medium is modeled as a virtual disk. Describe how access time and data-transfer rate for this virtual disk differ from the corresponding values for a typical hard disk. Answer: We can distinguish two models of broadcast data. In the case of a pure broadcast medium, where the receiver cannot communicate with the broadcaster, the broadcaster transmits data with periodic cycles of retransmission of the entire data, so that new receivers can catch up with all the broadcast information. Thus, the data is broadcast in a continuous cycle. This period of the cycle can be considered akin to the worst case rotational latency in a disk drive. There is no concept of seek time here. The value for the cycle latency depends on the application, but is likely to be at least of the order of seconds, which is much higher than the latency in a disk drive. In an alternative model, the receiver can send requests back to the broadcaster. In this model, we can also add an equivalent of disk access latency, between the receiver sending a request, and the broadcaster receiving the request and responding to it. The latency is a function of the volume of requests and the bandwidth of the broadcast medium. Further, queries may get satisfied without even sending a request, since the broadcaster happened to send the data either in a cycle or based on some other receivers request. Regardless, latency is likely to be at least of the order of seconds, again much higher than the corresponding values for a hard disk. A typical hard disk can transfer data at the rate of 1 to 5 megabytes per second. In contrast, the bandwidth of a broadcast channel is typically only a few kilobytes per second. Total latency is likely to be of the order of seconds to hundreds or even thousands of seconds, compared to a few milliseconds for a hard disk. 25.8 Consider a database of documents in which all documents are kept in a central database. Copies of some documents are kept on mobile

Practice Exercises 5 computers. Suppose that mobile computer A updates a copy of document 1 while it is disconnected, and, at the same time, mobile computer B updates a copy of document 2 while it is disconnected. Show how the version-vector scheme can ensure proper updating of the central database and mobile computers when a mobile computer reconnects. Answer: Let C be the computer onto which the central database is loaded. Each mobile computer (host) i stores, with its copy of each document d, a version-vector that is a set of version numbers V d,i, j, with one entry for each other host j that stores a copy of the document d, which it could possibly update. Host A updates document 1 while it is disconnected from C. Thus, according to the version vector scheme, the version number V 1,A,A is incremented by one. Now, suppose host A re-connects to C. This pair exchanges versionvectors and finds that the version number V 1,A,A is greater than V 1,C,A by 1, (assuming that the copy of document 1 stored host A was updated most recently only by host A). Following the version-vector scheme, the version of document 1 at C is updated and the change is reflected by an increment in the version number V 1,C,A. Note that these are the only changes made by either host. Similarly, when host B connects to host C, they exchange versionvectors, and host B finds that V 1,B,A is one less than V 1,C,A. Thus, the version number V 1,B,A is incremented by one, and the copy of document 1 at host B is updated. Thus, we see that the version-vector scheme ensures proper updating of the central database for the case just considered. This argument can be very easily generalized for the case where multiple off-line updates are made to copies of document 1 at host A as well as host B and host C. The argument for off-line updates to document 2 is similar.