Download presentation
Presentation is loading. Please wait.
1
Techniques and Data Structures for Efficient Multimedia Similarity Search
2
Reading Assignment Guojun Lu, "Multimedia Database Management Systems", Artech House, Publishers, 1999. Chapter 9: Techniques and Data Structures for Efficient Multimedia Similarity Search
3
3 Introduction Feature space is multidimensional. Objective: divide the multidimensional space into subspaces, so that only a few subspaces need to be searched for each query.
4
Query Types Point queries Range queries k nearest-neighbor queries
5
Operations on Data Structures Search Most important as it is done “on-line” Must be efficient Insertion and Deletion Less important as they can be performed “off-line” Need not be efficient
6
Efficient Search Techniques Filtering B and B + -trees Clustering MB + -trees k-d trees Grid files R trees TV trees
7
Filtering Reduce the search space by selecting specific items satisfying certain criteria. Search on the multidimensional feature vector is carried out on the selected set of items only.
8
Filtering with Structured Attributes/Classification Structured attributes associated with multimedia data. e.g. date Subject classification e.g. image-content type=“Natural Scene”
9
Filtering using the triangle inequality d is a distance metric and i,q, and k are feature vectors for three objects. Most feature distance measures are “metrics” d(i,k)=0 iff i=k d(i,k)= d(k,i) Triangle inequality above
10
Application of Triangle Inequality to Multimedia Retrieval MDB Representation Select m feature vectors as a comparison base F, where m << |MDB|, the size of the database i MDB f j F, calculate d(i,f j ) and store in MDB. MDB retrieval for query q Calculate d(q,f j ) f j F. Compute l(i) = max 1 j m |d(i,f j )- d(q,f j )| Find d(i,q) i MDB l(i) T, where T is a specified threshold.
11
Example Find database items whose distance to query q < 3 where the distances between q and the 2 vectors f 1 and f 2 forming the base are 3 and 4, respectively Database Items i d(i,f 1 )d(i,f 2 )|d(i,f 1 )- d(q,f 1 )| |d(i,f 2 )- d(q,f 2 )| l(i) i1i1 25111 i2i2 70 i3i3 104 i4i4 88 i5i5 97 i6i6 16 i7i7 54 i8i8 44
12
Filtering in the Color Histogram- Based Retrieval Space reduction can take place by Reducing the number of bins Selecting only a subset of the database images for calculating the distances from the query image. Space reduction is achieved through the following process: Select potential image candidates. Use full histogram comparison to calculate the distance between the query and the candidates.
13
Selecting Potential Image Candidates Use very few bins in comparing color histograms. Use the average color of images.
14
B-Trees (1) 1. B-Trees are always balanced. 2. B-Trees keep similar-valued records together on a disk page, which takes advantage of locality of reference. 3. B-Trees guarantee that every node in the tree will be full at least to a certain minimum percentage. This improves space efficiency while reducing the typical number of disk fetches necessary during a search or update operation.
15
B-Tree Definition A B-Tree of order m has these properties: The root is either a leaf or has at least two children. Each node, except for the root and the leaves, has between m/2 and m children. All leaves are at the same level in the tree, so the tree is always height balanced. A B-Tree node is usually selected to match the size of a disk block. A B-Tree node could have hundreds of children.
16
B-Tree Search Search in a B-Tree is a generalization of search in a 2-3 Tree. 1. Do binary search on keys in current node. If search key is found, then return record. If current node is a leaf node and key is not found, then report an unsuccessful search. 2. Otherwise, follow the proper branch and repeat the process. 50 203070 10121321233537405559607380
17
B + -Trees The most commonly implemented form of the B-Tree is the B + -Tree. Internal nodes of the B + -Tree neither store records nor pointers to records. They only store key values to guide the search. Leaf nodes store records or pointers to records. A leaf node may store more or less records than an internal node stores keys. Q: What is the advantage of using a B +- tree over a B- tree implementation?
18
B + -Tree Example Search for 21?
19
B + -Tree Insertion Insert the following keys into an initially empty B+ tree of order 4 where each leaf node can hold a maximum of 5 records: 12, 23, 10, 48, 33, 50, 15, 18, 20, 45, 47, 31, 52, 21, 30 What is the cost of direct access to a B+ tree of order n with N database items?
20
B + -Tree Deletion (Delete 18)
21
B + -Tree Deletion (Delete 12)
22
B + -Tree Deletion (Delete 33)
23
Clustering Similar information items are grouped together to form a cluster based on a certain similarity measurement. Each cluster is represented by the centroid of the feature vectors of that cluster. How is search carried out?
24
2D Example x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x xx x x x x x x x x x x x
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.