Luận án Một số kỹ thuật dự báo vị trí và truy vấn các đối tượng chuyển động trong cơ sở dữ liệu không gian - Thời gian

Cho m và M tương ứng là số lượng tối thiểu và tối đa đầu vào có thể vừa đủ với một nút, trong đó m∈ [0, M/2]. R-tree thỏa mãn các thuộc tính sau: - R-tree là cây cân bằng - Nút gốc có ít nhất 2 nút con (ngoại trừ cây chỉ có một nút) - Mỗi một nút chứa số lượng nút con trong khoảng m và M ngoại trừ nút gốc - Nút lá là cấu trúc có dạng (MBR, object_ptr), trong đó MBR là hình chữ nhật nhỏ nhất có chứa dữ liệu của đối tượng được biểu diễn bởi object_ptr - Nút trung gian là cấu trúc có dạng (MBR, chirld_ptr), trong đó MBR là hình chữ nhật nhỏ nhất bao tất cả các hình chữ nhật trong nút con của nó trỏ bởi chirld_ptr - Tất cả các nút lá ở cùng một mức.

pdf106 trang | Chia sẻ: tueminh09 | Ngày: 25/01/2022 | Lượt xem: 584 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Luận án Một số kỹ thuật dự báo vị trí và truy vấn các đối tượng chuyển động trong cơ sở dữ liệu không gian - Thời gian, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Home 17:06 18:12 9 1 Home Café 07:55 08:33 9 2 Café Laboratory 08:40 09:35 9 3 Laboratory Home 18:25 19:38 10 1 Home Laboratory 08:32 09:02 10 2 Laboratory Office 11:03 16:27 10 3 Office Home 17:28 18:15 Tiến hành thực nghiệm trên máy tính PC (cấu hình: CPU 2GHz, 1GB RAM) chạy hệ điều hành Windows 7 cài đặt MONET-DB, sử dụng MonetDB/SQL và MonetDB/GIS. Quỹ đạo của đối tượng với chu kỳ được xác định là “một ngày” biểu diễn trên bảng sau: Bảng 2.3. Quỹ đạo của đối tượng TjID Trajectory T1 Home, Office T2 Home, Café, Laboratory, Office T3 Home, Laboratory, Café, Office T6 Home, Café, Market Các di chuyển thường xuyên giữa hai điểm dừng được biểu diễn trên bảng 2.4 dưới đây cùng với độ hỗ trợ tương ứng. Bảng 2.4. Di chuyển thường xuyên và độ hỗ trợ Move Sup Home  Office 0.5 Home  Café 0.3 Café  Laboratory 0.4 Laboratory  Office 0.5 69 Sử dụng dữ liệu như mô tả trong bảng 2.4 và lựa chọn minsup = 0.5, thu được mẫu hình di chuyển trong bảng 2.5 dưới đây. Bảng 2.5. Mẫu hình di chuyển với độ hỗ trợ nhỏ nhất là 0.5 Move Sup Home  Office 0.5 Office  Home 0.6 Laboratory  Office 0.5 Truy vấn đối tượng X tại một thời điểm cho trước với minsup = 0.5? Ví dụ: bây giờ đang là 8h và đối tượng X đang ở điểm dừng Home. Đối tượng X sẽ ở đâu vào lúc 14h15 ngày hôm nay? Kết quả là đang ở Office. LET given_time= time(14,15) // at 14h15 SELECT o.obj_loc FROM tblMovingObjects WHERE o.id=’X’ AND time(o) = given_time o.obj_loc = “Office”; Kết quả thực nghiệm được sử dụng kết hợp với phương pháp dự đoán theo hàm chuyển động. Khi so sánh với phương pháp dự đoán chỉ theo hàm chuyển động, độ chính xác của phương pháp kết hợp đã được cải thiện như biểu diễn trên biểu đồ hình 2.11 dưới đây. Hình 2.11. So sánh độ chính xác của hai phương pháp dự đoán 70 Biểu đồ này biểu diễn độ chính xác xấp xỉ tương ứng với lượng dữ liệu sử dụng cho khai phá tăng dần theo số ngày. Độ chính xác trung bình của phương pháp dự đoán theo hàm chuyển động (ở đây nghiên cứu sinh sử dụng W-EWMA) là khoảng 82% với tập dữ liệu đã mô tả ở trên. Độ chính xác này được biểu diễn bởi đường đánh dấu hình thoi . Nhìn vào biểu đồ hình 2.11 ở trên có thể thấy khi kết hợp với phương pháp dự đoán theo mẫu hình di chuyển, độ chính xác tăng lên đáng kể (xấp xỉ 88%), được biểu diễn bởi đường đánh dấu hình vuông . Kết luận chương Chương 2 đã trình bày các kết quả nghiên cứu của nghiên cứu sinh bao gồm hai phương pháp đề xuất cho dự đoán vị trí của đối tượng chuyển động, nhằm góp phần giải quyết vấn đề mô hình hóa vị trí trong cơ sở dữ liệu các đối tượng chuyển động. Phương pháp thứ nhất là dự đoán vị trí theo hàm chuyển động sử dụng mô hình W- EWMA, có ưu điểm là xử lý nhanh chóng, cho phép dự đoán được vị trí ở gần thời điểm hiện tại. Phương pháp thứ hai là dự đoán theo hành vi, tiếp cận theo hướng sử dụng khai phá luật kết hợp của các mẫu hình di chuyển của đối tượng. Phương pháp này khắc phục được nhược điểm của phương pháp thứ nhất là cho phép dự đoán được vị trí ở những thời điểm xa hiện tại với độ chính xác tương đối cao. Kết hợp các phương pháp này sẽ đem lại hiệu quả tốt hơn cho cả hệ thống. Các kết quả này cũng được thể hiện trong các công bố (1)-(3). 71 Chương 3 LẬP CHỈ MỤC DỮ LIỆU KHÔNG GIAN-THỜI GIAN Trong chương này, nghiên cứu sinh sẽ trình bày kết quả nghiên cứu là một cấu trúc chỉ mục mới được đề xuất là DO-TPR*-tree, nhằm góp phần giải quyết vấn đề về lập chỉ mục dữ liệu trong cơ sở dữ liệu các đối tượng chuyển động. Như đã đề cập ở chương 2, dữ liệu vị trí của đối tượng chuyển động được mô hình hóa dưới dạng các thuộc tính động. Lập chỉ mục dữ liệu trong cơ sở dữ liệu các đối tượng chuyển động chính là lập chỉ mục các thuộc tính động. Việc lập chỉ mục thuộc tính động này có thể giải quyết bằng cách tách thành hai vấn đề con. Đầu tiên là biểu diễn hình học của giá trị thuộc tính động (tốc độ di chuyển, vị trí ban đầu, thời điểm bắt đầu) trong không gian-thời gian. Thứ hai là lập chỉ mục không gian của biểu diễn hình học nói trên. Vấn đề biểu diễn hình học liên quan đến các câu hỏi: Làm thế nào để ánh xạ một đối tượng (chính xác hơn là giá trị thuộc tính động) vào một vùng (hoặc một đường/điểm) trong không gian? Làm thế nào để ánh xạ một truy vấn vào các khu vực khác trong không gian cốt để mà kết quả truy vấn là các đối tượng có vùng giao với vùng truy vấn? Vùng đối tượng được cập nhật khi và chỉ khi các thuộc tính động được cập nhật một cách rõ ràng chứ không phải là liên tục (ví dụ như khi tốc độ của đối tượng thay đổi). Việc lập chỉ mục không gian liên quan đến câu hỏi là làm thế nào để có thể tìm thấy những vùng giao nhau nêu trên một cách nhanh chóng và hiệu quả. Một số nghiên cứu về cấu trúc cây nhằm giảm chi phí cập nhật đối tượng đã được đề xuất, chẳng hạn như RUM-tree hay FD-tree. RUM-tree [37] xử lý việc cập nhật theo kiểu dựa trên bản ghi nhớ (memo-based) nhằm hạn chế việc truy cập đĩa cứng thường xuyên khi thanh lọc các mục cũ trong quá trình cập nhật. Nhờ đó, chi phí cho thao tác cập nhật trong RUM-tree giảm bằng chi phí của một thao tác thêm mới. Trong khi đó FD-tree [18] là cấu trúc cây chỉ mục sử dụng đặc trưng phần cứng như ổ đĩa flash hay SSD có tốc độ cao hơn nhằm tối ưu hiệu năng cập nhật bằng cách hạn chế các thao tác ghi ngẫu nhiên trong khi vẫn giữ được hiệu quả khi tìm kiếm. 72 Hầu hết các phương pháp lập chỉ mục trong cơ sở dữ liệu các đối tượng chuyển động hiện có đều dựa trên phương pháp lập chỉ mục không gian truyền thống là R- tree và các mở rộng của nó, mà điển hình là TPR-tree. Hình 3.1. Các cấu trúc cây phát triển từ TPR-tree (2005-2012) TPR-tree [36] là cấu trúc cây rất hiệu quả cho việc lưu trữ và tìm kiếm trong cơ sở dữ liệu các đối tượng chuyển động. Nó là cơ sở cho rất nhiều các cấu trúc cây khác 73 phát triển mở rộng về sau như TPR*-tree, LGU TPR-tree [59], VTPR-tree [60], TPRA-tree [61] (hình 3.1). Nhiều nỗ lực trong việc cải tiến cấu trúc chỉ mục TPR- tree để hiệu quả hơn cho truy vấn tương lai như Bdual-tree. Cấu trúc Bdual-tree [48] được giới thiệu nhằm nâng cao hiệu năng cập nhật so với các phương pháp trước. Bdual-tree đem lại hiệu năng tổng thể khá tốt, tuy nhiên khi so sánh với TPR*-tree thì TPR*-tree vẫn đem lại hiệu năng tốt nhất về thời gian xử lý truy vấn [42]. Nhìn hình 3.1 trên cũng có thể thấy TPR*-tree vẫn tiếp tục được cải tiến thêm khá nhiều trong những năm gần đây theo nhiều hướng khác nhau phù hợp với từng hoàn cảnh và ứng dụng cụ thể trong thực tế như Efficient TPR*-tree [57] năm 2011 hay HTPR*-tree [58] năm 2012. Cả Efficient TPR*-tree và HTPR*-tree đều là cấu trúc cây được cải tiến từ TPR*-tree nhằm làm tăng hiệu năng cập nhật các đối tượng chuyển động. Efficient TPR*-tree sử dụng vùng đệm (buffering) để tăng tốc độ cập nhật. Còn HTPR*-tree thì thêm thời gian tạo lập hay cập nhật của các đối tượng vào các nút lá và sử dụng chiến lược cập nhật từ dưới lên với các cấu trúc hỗ trợ là chỉ mục băm, véc tơ nhị phân và bảng truy cập trực tiếp. Phần đầu chương này, nghiên cứu sinh sẽ giới thiệu sơ lược về các cấu trúc cây có liên quan khi xây dựng cây đề xuất bao gồm R-tree, TPR-tree và TPR*-tree. Tiếp theo sẽ giới thiệu kỹ thuật xử lý, thuật toán tìm kiếm của cấu trúc cây đề xuất DO- TPR*-tree dựa trên TPR*-tree nhằm làm tăng hiệu năng truy vấn. Các thực nghiệm được thực hiện ở phần cuối chương này đã chứng tỏ cấu trúc cây DO-TPR*-tree đem lại hiệu năng tốt hơn trong nhiều trường hợp so với cấu trúc cây ban đầu. 3.1. R-tree Cấu trúc cây R-tree R-tree [9] là một cấu trúc cây cân bằng được xây dựng dựa trên B-tree để truy xuất nhanh các vùng không gian. R-tree chia nhỏ không gian ban đầu thành các khối có thể lồng nhau hoặc chồng chéo lên nhau và tạo chỉ mục, sau đó áp dụng lý thuyết cây để quản lý, lưu trữ và truy xuất các vùng không gian này. Hình khối thường được sử dụng là hình chữ nhật bao nhỏ nhất chứa dữ liệu (Minimum Bounding Rectangle 74 - MBR). Chính các MBR được lưu trữ trên cấu trúc cây dưới dạng các nút chứ không phải bản thân dữ liệu, khi đó việc tìm kiếm dữ liệu sẽ được thực hiện trên các nút. Các nút lá trong cây chứa chỉ mục vì vậy chúng có khuôn dạng: (MBR, object_ptr), trong đó object_ptr tham chiếu đến một bộ dữ liệu trong cơ sở dữ liệu và MBR là một hình chữ nhật n-chiều chứa các đối tượng không gian nó thể hiện. Các nút không phải lá gọi là nút trung gian, có khuôn dạng: (MBR, chirld_ptr), trong đó chirld_ptr là địa chỉ nút con của nó trong cây và MBR là hình chữ nhật nhỏ nhất bao tất cả các MBR trong các nút ở mức thấp hơn. Nói cách khác, không gian MBR chứa mọi đối tượng được lập chỉ mục trong các cây con có gốc là đầu vào của MBR. Cho m và M tương ứng là số lượng tối thiểu và tối đa đầu vào có thể vừa đủ với một nút, trong đó m∈ [0, M/2]. R-tree thỏa mãn các thuộc tính sau: - R-tree là cây cân bằng - Nút gốc có ít nhất 2 nút con (ngoại trừ cây chỉ có một nút) - Mỗi một nút chứa số lượng nút con trong khoảng m và M ngoại trừ nút gốc - Nút lá là cấu trúc có dạng (MBR, object_ptr), trong đó MBR là hình chữ nhật nhỏ nhất có chứa dữ liệu của đối tượng được biểu diễn bởi object_ptr - Nút trung gian là cấu trúc có dạng (MBR, chirld_ptr), trong đó MBR là hình chữ nhật nhỏ nhất bao tất cả các hình chữ nhật trong nút con của nó trỏ bởi chirld_ptr - Tất cả các nút lá ở cùng một mức. 75 Hình 3.2. Biểu diễn hai chiều của R-tree Hình 3.3. Biểu diễn cấu trúc cây R-tree Hình 3.2 biểu diễn một ví dụ của R-tree với m=2 và M=4. Các nút trung gian là a, b, c và d, được biểu diễn dưới dạng hai chiều là các hình chữ nhật bao nhỏ nhất bao trọn các nút lá tương ứng là [1,2,5,6], [3,4,7,10], [8,9,14] và [11,12,13] thể hiện như trên hình 3.3 Cấu trúc chỉ mục trong R-tree thực sự linh động, thao tác chèn, xóa, cập nhật có thể kết hợp với phép tìm kiếm và có thể thực hiện đệ quy. R-tree có nhiều biến thể khác như R+-tree hay R*-tree cải tiến thêm về tốc độ truy vấn. R-tree cũng là cơ sở cho rất nhiều cấu trúc chỉ mục khác mà được sử dụng phổ biến như TPR-tree, TPR*- tree 76 3.2. TPR-tree TPR-tree (Time-Parameterized R-tree) [36] là một cây cân bằng, đa chiều dựa trên cấu trúc của R*-tree [2], phát triển từ R-tree [9]. TPR-tree cho phép dự đoán vị trí của đối tượng chuyển động bằng cách lưu trữ cả vị trí hiện tại cùng với vận tốc của từng đối tượng tại một thời điểm cụ thể. Cấu trúc cây TPR-tree Nút lá của TPR-tree là một cấu trúc bao gồm: vị trí của đối tượng chuyển động và con trỏ đến đối tượng chuyển động. Nút trung gian là một cấu trúc bao gồm: con trỏ đến cây con (subtree) và hình chữ nhật bao tất cả các vị trí của đối tượng chuyển động (hình chữ nhật bao các nhánh cây con). Trong TPR-tree, các hình chữ nhật bao trong không gian n-chiều sử dụng các tham số của thời gian, tọa độ của chúng là hàm thời gian. Một hình chữ nhật bao theo tham số thời gian sẽ bao bọc tất cả điểm kèm theo hay các hình chữ nhật tại tất cả thời gian tương lai gần nhất. Vì vậy nó có khả năng bao bọc các điểm chuyển động liên tục. Hình 3.4. Các điểm chuyển động ở các nút lá của TPR-tree 77 Hình 3.5. Các điểm chuyển động trong các nút trung gian của TPR-tree Đối với mỗi chiều n, khoảng bao được xác định bởi hai hàm tuyến tính theo thời gian: [xn├ (tref) + vn├ (t – tref), xn ┤ (tref) + vn ┤ (t – tref)], trong đó: - xn├ = xn├ (tref) = mini{oi.xn├ (tref)} - xn ┤= xn ┤(tref ) = maxi{oi.xn ┤(tref)} - vn├ = mini{oi.vn├} - vn ┤= maxi{oi.vn┤} - tref là thời gian mà hình chữ nhật bao được tạo ra. Các hình chữ nhật bao không bao giờ thu nhỏ lại và trên thực tế nó có thể phát triển rất nhanh theo thời gian. Điều đó làm hiệu suất truy vấn giảm dần theo thời gian vì vậy các hình chữ nhật bao phải được điều chỉnh và cập nhật lại. Đối với mỗi chiều n, điểm cuối của khoảng bao sẽ được cập nhật như sau: xn├ = mini{oi.xn├ (tupd)} – vn├ (tupd – tref) xn┤= maxi{oi.xn ┤ (tupd)} – vn ┤(tupd – tref) tref là thời gian hình chữ nhật bao được tạo ra. tupd là thời gian khi thực hiện cập nhật. 78 Hình 3.6. Cập nhật khoảng giới hạn theo tham số thời gian Trong ví dụ tại hình 3.6, các nét đậm phía trên và phía dưới thể hiện thời điểm được tạo ra và nét đứt là thời gian cập nhật, 4 đường thể hiện đường đi của 4 đối tượng chuyển động o1, o2, o3, o4. Với không gian hai chiều, một đối tượng chuyển động O có thể được biểu diễn bởi hình chữ nhật bao nhỏ nhất (MBR) OR và hình chữ nhật bao vận tốc (VBR) OV={OV1-,OV1+,OV2-,OV2+} trong đó OVi- biểu diễn vận tốc chuyển động của đường bao dưới còn OVi+ biểu diễn vận tốc chuyển động của đường bao trên của OR theo mỗi chiều thứ i tương ứng (1 ≤ i ≤ 2). 79 (a) MBRs & VBRs tại thời điểm 0 (b) MBRs tại thời điểm 1 Hình 3.7. Biểu diễn nút trung gian trong cây TPR-tree Hình 3.7a biểu diễn MBR và VBR của 4 đối tượng chuyển động a, b, c, d. Các mũi tên đen gắn trên mỗi MBR của đối tượng biểu thị hướng chuyển động với vận tốc là số đính kèm của MBR đó, trong đó số âm nghĩa là hướng chuyển động ngược với chiều của trục số. VBR của đối tượng a là aV={1,1,1,1} (hai số đầu cho trục x, hai số sau cho trục y). Tương tự VBR của b, c, d lần lượt là bV={-2,-2,-2,-2}, cV={- 2,0,0,2} và dV={-1,-1,1,1}. Các nút trung gian cũng được biểu diễn bởi MBR và VBR, như trong ví dụ hình 3.7a, các nút trung gian N1 (chứa đối tượng a và b) và N2 (chứa đối tượng c và d) có các VBR lần lượt là N1V={-2,1,-2,1} và N2V={-2,0,-1,2} và hướng được biểu diễn bởi các mũi tên trắng gắn trên mỗi MBR. Để xử lý truy vấn qR tại thời điểm tương lai của người sử dụng, TPR-tree tính toán mở rộng các MBRs và VBRs tại thời điểm truy vấn theo vận tốc tương ứng của mỗi chiều rồi tìm kiếm đệ quy trong các cây con của MBR nào mà chồng lên miền truy vấn qR như ví dụ trên hình 3.7b. Có thể nói TPR-tree là cấu trúc cây rất hiệu quả cho việc lưu trữ và tìm kiếm trong cơ sở dữ liệu các đối tượng chuyển động. Nó là cơ sở cho rất nhiều các cấu trúc cây khác phát triển mở rộng về sau, điển hình là TPR*-tree. 80 3.3. TPR*-tree Cấu trúc dữ liệu và thuật toán xử lý truy vấn của TPR*-tree [42] tương tự như của TPR-tree. Điểm khác giữa hai loại cây này nằm ở thuật toán thêm đối tượng mới vào cây nhờ đó làm tăng tốc độ xử lý truy vấn. Khi chèn đối tượng mới vào cây, TPR-tree đánh giá các thay đổi tổng thể trên độ lớn diện tích của MBR, độ dài đường bao MBR và diện tích các vùng chồng chéo giữa các MBR mà sẽ bị ảnh hưởng bởi việc chèn này. TPR-tree lựa chọn nhánh cây để chèn mà những thay đổi này là nhỏ nhất. Dù cách tiếp cận này là rất hiệu quả cho việc lập chỉ mục các đối tượng tĩnh trong R*-tree, nhưng nó vẫn chưa phải là giải pháp tốt cho các đối tượng chuyển động. Bởi vì TPR-tree chỉ ước tính các thay đổi của MBR tại thời điểm chèn mà không xem xét MBR đã thay đổi theo tham số thời gian. Để giải quyết những thiếu sót này TPR*-tree sử dụng thuật toán chèn có phản hồi các biến đổi theo thời gian của MBR. Khi chèn đối tượng mới vào cây, TPR*-tree sử dụng thuật toán chèn trong đó xem xét bao nhiêu MBR sẽ quét trong không gian chỉ mục từ thời điểm chèn đến thời điểm cụ thể trong tương lai. Ví dụ, cho hai điểm thời gian khác nhau t1 và t2 (t1 < t2). Vùng quét của MBR từ t1 đến t2 được định nghĩa là vùng không gian chỉ mục mà quét bởi MBR mở rộng trong khoảng thời gian (t2 – t1). Hình 3.8 dưới đây minh họa vùng quét trong TPR*-tree. Ở thời điểm khởi tạo ban đầu 0, chúng ta có MBR N ở hình 3.8a, đến thời điểm 1, MBR quét trong không gian chỉ mục như hình 3.8b, trong đó vùng quét được đánh dấu bởi hình đa giác tô màu xám. Trong ví dụ này, vùng quét có kích thước là 23 (đơn vị diện tích). 81 (a) Thời điểm 0 (b) Thời điểm 1 Hình 3.8. Vùng quét từ thời điểm 0 đến thời điểm 1 Thuật toán chèn tìm nút lá trong cây TPR*-tree bằng cách chọn đệ quy từ trên xuống cây con sẽ chứa nút chèn vào. Trong quá trình tìm kiếm, thuật toán sẽ chọn nhánh chèn sao cho vùng quét tổng thể trong nhánh này là nhỏ nhất. Vì vậy, thuật toán cần tính thêm diện tích các vùng quét mỗi khi chèn đối tượng. Tiến trình này đòi hỏi tốn thêm thời gian tính toán so với cây TPR-tree. Tuy nhiên cây TPR*-tree sẽ cho kết quả truy vấn nhanh hơn vì nó giúp thu gọn các MBR và hạn chế các vùng chồng lấp có thể không đem lại kết quả tìm kiếm. Ngoài ra, thuật toán xóa cũng được điều chỉnh nâng cao tương tự thuật toán chèn. Theo thử nghiệm kết quả trong [42], cây TPR*-tree mang lại hiệu suất gấp 5 lần so với cây TPR-tree. 3.4. DO-TPR*-tree Dù đạt được những kết quả đáng kể và được sử dụng trong rất nhiều hệ thống lập chỉ mục dữ liệu không gian-thời gian, cấu trúc cây TPR*-tree vẫn còn tồn tại vài vấn đề cần giải quyết. Một trong số đó là tính thụ động trong việc điều chỉnh MBR trong cây TPR*-tree. Trong TPR*-tree, VBR của mỗi nút lưu trữ vận tốc lớn nhất và nhỏ nhất theo mỗi chiều của hình chữ nhật bao MBR. Và trong thực tế, các MBRs này phát triển rất 82 nhanh theo thời gian, dẫn đến phát sinh vùng không gian trống (mà chắc chắn không chứa kết quả truy vấn) và gây ra sự chồng chéo rất lớn giữa các MBRs của các nút. Điều này sẽ làm giảm đáng kể hiệu suất xử lý truy vấn vì cần đến một số lượng ngày càng tăng của việc truy cập các nút cần thiết khi tìm kiếm do chồng chéo. Đối với vấn đề này, TPR*-tree chỉ thực hiện điều chỉnh MBR trên một nút bất cứ khi nào có thao tác cập nhật mà phản ánh sự thay đổi vận tốc của đối tượng hoặc vị trí hiện tại trên nút đó. Hình 3.9 dưới đây minh họa lợi ích của việc điều chỉnh các MBRs này. Trong hình 3.9a, tại thời điểm khởi tạo 0, một MBR bao các đối tượng O1 và O2 được tạo ra và biểu diễn bởi hình chữ nhật R. Hình 3.9b minh họa vị trí của các đối tượng tại thời điểm 1. Các đối tượng O1 và O2 đã di chuyển lại gần nhau hơn trong khi MBR của chúng lại mở rộng ra xa hơn (hình chữ nhật R1). Nếu điều chỉnh MBR xảy ra ở thời điểm 1 (có thao tác cập nhật hay thêm nút), chúng ta sẽ có MBR nhỏ hơn nhiều như R’ trong hình 3.9b. Với việc thu gọn MBR tại thời điểm 1, chúng ta có thể loại bỏ không gian trống R1 – R’, dẫn đến sẽ loại bỏ được những truy cập nút không cần thiết (vì chắc chắn không có kết quả) khi vùng truy vấn có giao hoặc nằm trong vùng không gian trống R1 – R’ này. (a) Thời điểm 0 (b) Thời điểm 1 Hình 3.9. MBR của R tại thời điểm khởi tạo 0 và mở rộng R1 tại thời điểm 1 Rõ ràng việc điều chỉnh MBR là giải pháp cho hiệu năng tốt hơn khi truy vấn. Tuy nhiên, với TPR*-tree, điều chỉnh các MBRs chỉ xảy ra khi có xuất hiện thao tác 83 cập nhật hay thêm mới đối tượng. Như vậy với một nút N không được cập nhật trong một khoảng thời gian đủ dài, kích cỡ vùng không gian trống sẽ tăng lên rất nhanh. Các truy vấn liên tục thực hiện trên cấu trúc cây TPR*-tree sẽ bị giảm hiệu suất nhanh chóng. Điều này phát sinh từ tính thụ động trong việc điều chỉnh MBR trong cây TPR*-tree. Để giải quyết vấn đề này, nghiên cứu sinh đề xuất một cấu trúc chỉ mục mới dựa trên TPR*-tree, nhằm giảm bớt các vùng không gian trống mỗi khi thực hiện truy vấn liên tục bằng cách điều chỉnh MBR theo mật độ, đặt tên là DO-TPR*-tree (Density Optimal TPR*-tree). Cấu trúc cây, các định nghĩa, kỹ thuật xử lý và thuật toán tìm kiếm DOA_Search sẽ được trình bày cụ thể trong phần tiếp theo. 3.4.1. Cấu trúc cây DO-TPR*-tree Cây DO-TPR*-tree kế thừa toàn bộ cấu trúc của cây TPR*-tree. Nút lá của DO- TPR*-tree là một cấu trúc bao gồm: vị trí của đối tượng chuyển động và con trỏ đến đối tượng chuyển động. Nút trung gian là một cấu trúc bao gồm: con trỏ đến cây con và hình chữ nhật bao các nhánh cây con. DO-TPR*-tree cũng sử dụng cả MBR và VBR để biểu diễn các đối tượng chuyển động. Các thuật toán thêm mới hay xóa đối tượng của cây DO-TPR*-tree là tương tự cây TPR*-tree như mô tả dưới đây. 84 3.4.2. Thuật toán tìm kiếm DOA_Search Kỹ thuật xử lý truy vấn Như mô tả ở phần trên, cây TPR*-tree mang tính thụ động trong việc điều chỉnh MBR. Nghĩa là việc điều chỉnh MBR ở một nút N trong cây chỉ xảy ra khi có thao tác cập nhật hay thêm mới đối tượng chuyển động trong MBR của nút đó. Giả sử DEF Algorithm Insert (e) Input: e is the entry to be inserted Output: Inserted e into Node N 1. re-insertedi= false for all levels 1≤ i ≤ h−1 (h is the tree height) 2. Initialize an empty re-insertion list Lreinsert 3. Invoke Choose Path to find the leaf node N to insert e 4. Invoke Node Insert (N, e) 5. For each entry e' in the Lreinsert 6. Invoke Choose Path to find the leaf node N to insert e' 7. Invoke Node Insert (N, e) 8. End for Algorithm End Algorithm Node Insert (N, e) /* Input: N is the node where entry e is inserted */ 1. if N is a leaf node 2. enter the information of e 3. if N overflows 4. if re-inserted0 = false //no re-insertion at leaf level yet 5. invoke Pick Worst to select a set Sworst of entries 6. remove entries in Sworst from N; add them to Lreinsert 7. re-inserted0 = true 8. else 9. invoke Node Split to split N into itself and N' 10. let P be the parent of N 11. Node Insert(P,∅) or Node Insert(P,N') if N has been split 12. else //N is a non-leaf node 13. similar to lines 2-9 except that (i) the MBR/VBR of the affected child node is adjusted, and (ii) in lines 4, 7 replace re-inserted0 with re-insertedi where i is the level of N End Node Insert 85 và DEFHIlần lượt là các thời điểm cập nhật liên tiếp thứ j và (j+ 1) mà sẽ có điều chỉnh MBR ở nút N. Chúng ta cùng xem xét tình huống xử lý truy vấn P tại nút N của cây TPR*-tree mà P thực hiện trong khoảng thời gian [DEF, DEFHI]. Giả sử có k truy vấn liên tục sau thời điểm cập nhật thứ j ký hiệu Qj,k tại các thời điểm truy vấn DJF,K xảy ra ở nút N và nằm trong khoảng thời gian giữa hai lần cập nhật liên tiếp [DEF , DEFHI]. Ta có: DEF< DJF,I< DJF,L< < DJF,M< DEFHI Vì MBR của nút N mở rộng nhanh chóng trong khoảng thời gian [DEF, DEFHI], truy vấn của người sử dụng tại thời điểm DJF,K (1 ≤ i ≤ k) sẽ xem xét toàn bộ MBR của N và vì vậy sẽ dẫn đến tồn tại những vùng không gian trống ngày càng lớn mà việc thực hiện truy vấn trên đó không đem lại thêm kết quả nào. Rõ ràng là nếu có thể thực hiện điều chỉnh MBR ở nút N tại thời điểm DJF,K khi thực hiện truy vấn Qj,i nào đó, thì tất cả các truy vấn sau đó Qj,x (i < x ≤ k) sẽ không phải xử lý trong vùng không gian trống đó nữa ở khoảng thời gian còn lại [DJF,K, DEFHI]. Phương pháp đề xuất của nghiên cứu sinh là bắt buộc điều chỉnh MBR dựa trên mật độ của nút N trong cây TPR*-tree. Lợi ích của phương pháp này là giảm được một số lượng lớn các truy vấn liên tục vào nút N trong khoảng thời gian [DJF,K, DEFHI] do MBR của nó đã được điều chỉnh nhỏ lại và giảm thiểu không gian trống. Trong phương pháp đề xuất, nghiên cứu sinh đưa ra hai định nghĩa sau mà sẽ được sử dụng trong thuật toán đề xuất. ĐỊNH NGHĨA 3.1 [Node Density – Mật độ của một nút]. Giả sử N là một nút của cây TPR*-Tree. Mật độ của nút N, ký hiệu DN, là tỉ số giữa số lượng Entry nằm trong N trên diện tích của MBR của nút đó. Mật độ của nút N tại thời điểm T, ký hiệu DN(T), là tỉ số của số lượng Entry nằm trong N trên diện tích của MBR của nút đó tại thời điểm T. 86 DN (T) = NE6_PQ(9) RSTQ(9) (3-1) Trong đó, − Num_EN(T) số lượng các Entry nằm trong N tại thời điểm T. Nếu N là nút lá thì Num_EN(T) là số đối tượng chuyển động nằm trong N − ABRN(T) là diện tích của MBR của nút N tại thời điểm T ĐỊNH NGHĨA 3.2 [Node Density Optimal – Mật độ đủ tốt của một nút]. Giả sử N là một nút của cây TPR*-Tree. Mật độ của nút N tại thời điểm truy vấn Tq được gọi là đủ tốt nếu tỉ số của mật độ của nút N tại thời điểm cập nhật cuối cùng trước đó Tu với nó nhỏ hơn một số λ cho trước. UQ(9V) UQ(9W) < λ (3-2) Trong đó, − XN(DJ) là mật độ của nút N tại thời điểm truy vấn Tq − XN(DE) là mật độ của nút N tại thời điểm cập nhật cuối cùng Tu − λ là một số cho trước. Nhìn chung, lựa chọn λ là tùy thuộc vào ngữ cảnh của từng ứng dụng cụ thể và tùy từng thời điểm khác nhau, do mật độ các đối tượng chuyển động thay đổi theo thời gian. Trong ứng dụng quản lý phương tiện chuyển động, λ có thể khởi tạo bằng giá trị h-1 trong đó h là chiều cao của cây. Giá trị này có thể điều chỉnh lại trong quá trình sử dụng ứng dụng. Ví dụ với mật độ giao thông cao vào thời điểm đầu giờ sáng hay giờ tan tầm thì giảm giá trị λ (nhưng vẫn lớn hơn 1), còn những thời điểm khác có thể tăng λ. Điều kiện mật độ đủ tốt (3-2) nhằm đảm bảo vùng không gian trống trong MBR của nút N tại thời điểm truy vấn chưa quá lớn đến mức ảnh hưởng đến các truy vấn tiếp sau thời điểm này. Trong phương pháp đề xuất này, nghiên cứu sinh kiểm tra điều kiện mật độ đủ tốt (3-2) của nút N khi có truy vấn của người sử dụng tại thời điểm truy vấn DJF,K. Nếu 87 không thỏa điều kiện (3-2), việc điều chỉnh MBR sẽ được thực hiện trên nút N. Vì vậy tất cả các truy vấn sau thời điểm này Qj,x (i < x ≤ k) sẽ không phải xử lý trong vùng không gian trống của N ở khoảng thời gian còn lại [DJF,K, DEFHI]. Nhờ đó mà giảm được một số lượng lớn các truy vấn liên tục vào nút N trong khoảng thời gian này và nâng cao hiệu năng truy vấn của cây TPR*-Tree. Thuật toán tìm kiếm DOA_Search Gọi việc điều chỉnh MBR khi kiểm tra điều kiện (3-2) là điều chỉnh mật độ đủ tốt - Density Optimal Adjustment (DOA). Truy vấn tương lai của người sử dụng được biểu diễn dưới dạng (QBR, QT). Trong đó, QBR là ký hiệu phạm vi truy vấn (bao gồm MBR và VBR) trong không gian truy vấn hai chiều và QT là ký hiệu khoảng thời gian truy vấn (bao gồm thời gian bắt đầu và thời gian kết thúc). Truy vấn tương lai dự đoán các đối tượng chuyển động mà sẽ đi vào vùng QBR trong khoảng thời gian QT. Thuật toán tìm kiếm đề xuất DOA_Search được mô tả dưới đây, trong đó trả về tập các định danh của những đối tượng thỏa mãn truy vấn tương lai (QBR, QT). 88 Thuật toán tìm kiếm từ trên xuống các nút lá từ nút gốc. Trong quá trình tìm kiếm, tiến trình tìm kiếm sẽ xác định đường tìm kiếm bằng cách tính toán các hình chữ nhật bao từ mỗi mục e ở các nút trung gian. Tiến trình sẽ lưu nội dung mỗi mục e đã gặp vào vùng nhớ cache tại dòng 11. Việc tính toán mật độ của nút được thực hiện ở dòng Algorithm DOA_Search(QBR, QT, rootNode) Input: (QBR, QT) = future-time query answered. rootNode= address to the root of a sub-tree being searched. Output: SBR= objects’ ids satisfying (QBR, QT). 1. IF rootNode is a leaf node THEN 2. SBR ← ∅; // initialization 3. FOR EACH moving object O IN rootNode 4. IF O IN (QBR, QT) THEN //O is expected computed to be positioned d in QBR within interval QT 5. SBR= SBR ∪ O.id; 6. END IF 7. END FOR 8. ELSE // rootNode is a non-leaf node 9. FOR EACH index entry e IN rootNode 10. IF OVERLAP(e.MBR, QBR, QT) THEN // if there is an overlap between the MBR of e and QBR within QT 11. Cache(e); // cache the content of e into the memory buffer 12. nodeDensity = Cal_NodeDensity(e.childNode); // calculate the Node Density Optimal of the child node pointed to by e 13. λ = h-1; // h is the tree height 14. IF (nodeDensity >= λ) THEN // a DOA execution is needed on childNode 15. Adjust (e.MBR, e.VBR); // adjust the MBR and VBR data of e 16. END IF 17. childSBR ← DOA_Search(QBR, QT, childNode); 18. SBR ← SBR ∪ childSBR; 19. END IF 20. END FOR 21. RETURN SBR 22. END IF Algorithm End 89 12. Điều kiện mật độ đủ tốt của nút được kiểm tra ở dòng 14, nếu điều kiện này không đạt, việc điều chỉnh MBR của nút đó sẽ được thực hiện ở dòng 15. Khi đến nút lá ở dòng 5, thuật toán sẽ đưa ra nhóm các định danh của các đối tượng chuyển động thỏa mãn điều kiện truy vấn và trả về ở dòng 21. Định lý 4.1 (Thuật toán DOA_Search là đúng). Thuật toán DOA_Search trả về đúng và đầy đủ các kết quả truy vấn phạm vi trong tương lai. Chứng minh. Ta thấy, mọi nút trong cây đều được duyệt. Điều này có thể thấy ở dòng 3, mọi nút lá và dòng 9, mọi nút trung gian trong cây (a). Tất cả các nút lá có vị trí nằm trong phạm vi hình chữ nhật truy vấn QBR trong khoảng thời gian truy vấn tương lai QT đều được đưa vào danh sách kết quả truy vấn (dòng 4 và 5) (b). Tất cả các mục entry của nút trung gian mà có hình chữ nhật bao giao với hình chữ nhật truy vấn QBR trong khoảng thời gian truy vấn tương lai QT (dòng 9, 10) đều được duyệt và tìm kiếm đệ quy để tìm ra nút lá bên trong thỏa mãn kết quả truy vấn (dòng 17, 18) (c). Thuật toán dừng khi duyệt hết tất cả các nút trong cây (d). Từ (a) (b) (c) và (d) ta có điều phải chứng minh. 3.4.3. Kết quả thực nghiệm Trong phần này, nghiên cứu sinh trình bày một số kết quả thực nghiệm so sánh phương pháp đề xuất với phương pháp sử dụng cây TPR*-tree. Có thể thấy được phương pháp đề xuất của nghiên cứu sinh đem đến hiệu năng truy vấn tốt hơn trong trường hợp truy vấn tương lai liên tục, mà rất hay được sử dụng trong các hệ thống quản lý phương tiện chuyển động. 90 Dữ liệu thực nghiệm Dữ liệu thực nghiệm được sinh ngẫu nhiên bằng thuật toán kiểu GSTD [43], một thuật toán nổi tiếng được sử dụng ở rất nhiều nghiên cứu trước trong việc đánh giá hiệu năng của các cấu trúc chỉ mục cho đối tượng chuyển động. Với thuật toán này, nghiên cứu sinh tạo ra bốn tập dữ liệu bao gồm [1.000, 10.000, 50.000, 100.000] đối tượng chuyển động có vận tốc chuyển động ngẫu nhiên trong khoảng từ [-50, 50] và vận tốc thay đổi tối đa cho mỗi lần cập nhật là 5. Những đối tượng này giả lập sẽ di chuyển trong không gian truy vấn hai chiều có kích thước từ 0 đến 10,000. Trong không gian truy vấn này, mỗi đối tượng được biểu diễn như là một điểm có vị trí ban đầu và phân bố đều trong không gian. Cấu trúc bản ghi mô tả chi tiết bao gồm định danh, MBR, VBR và thời điểm tham chiếu như sau: struct MovingObject { int oid; // unique identification of object float mbr[4]; // MRB of object float vbr[4]; // VRB of object float ref; // reference time at which the object is inserted or updated } Dữ liệu mẫu thể hiện trong bảng 3.1 dưới đây: Bảng 3.1. Dữ liệu thực nghiệm các đối tượng chuyển động oid X1 X2 Y1 Y2 Vx1 Vx2 Vy1 Vy2 ref time 0 3383.691 3383.713 6253.745 6253.767 -13.148 -13.148 -46.418 -46.418 0 1 1463.102 1463.125 1174.597 1174.619 29.806 29.806 18.544 18.544 0 2 699.142 699.164 1529.711 1529.734 -24.100 -24.100 4.767 4.767 0 3 8125.313 8125.335 747.351 747.373 -24.063 -24.063 38.967 38.967 0 4 1899.701 1899.724 7856.583 7856.605 11.642 11.642 5.390 5.390 0 520 1721.404 1721.427 7964.688 7964.710 9.970 9.970 -5.254 -5.254 1 521 9796.890 9796.912 1979.648 1979.671 27.163 27.163 -26.776 -26.776 1 522 6352.922 6352.944 9722.270 9722.292 49.548 49.548 -25.330 -25.330 1 850 1960.613 1960.635 4836.069 4836.092 -22.374 -22.374 -36.063 -36.063 3 851 6955.288 6955.311 4882.243 4882.265 -1.135 -1.135 -10.259 -10.259 3 91 Thực nghiệm được thực hiện trên máy tính cài hệ điều hành Windows 8 với bộ xử lý Intel Core i3, 1.80GHz, 4GB RAM bộ nhớ trong. Kết quả thực nghiệm Thực nghiệm 3-1. Đánh giá hiệu năng theo độ lớn phạm vi truy vấn Trước tiên nghiên cứu sinh đánh giá hiệu năng của DO-TPR*-tree theo độ lớn phạm vi truy vấn. Trong thực nghiệm này, kích thước vùng truy vấn QBR theo mỗi chiều là [100, 100]. Thời điểm cập nhật cuối cùng trong cây DO-TPR*-tree là 10. Phạm vi truy vấn thay đổi từ thời điểm 10 đến 50 với các giá trị lần lượt là [10-20], [10-30], [10-40] và [10-50]. Các kết quả thực nghiệm được biểu diễn trong hình 3.10 dưới đây, trong đó đồ thị hiển thị trung bình các kết quả tìm được ở hình 3.10a, trung bình số nút phải xử lý ở hình 3.10b, thời gian thực hiện truy vấn ở hình 3.10c. Ở cả 3 đồ thị, phạm vi truy vấn biểu diễn trên trục x. (a) Trung bình kết quả tìm được 0,00 100,00 200,00 300,00 400,00 500,00 600,00 1 0 - 2 0 1 0 - 3 0 1 0 - 4 0 1 0 - 5 0 A V G . D A T A R E T R IE V E S ( N U M ) FUTURE QUERY TIME INTERVAL 1K 10K 50K 100K 92 (b) Trung bình số nút phải xử lý (c) Thời gian thực hiện truy vấn Hình 3.10. Ảnh hưởng của độ lớn phạm vi truy vấn Những kết quả thực nghiệm này cho thấy trung bình số nút phải xử lý và thời gian thực hiện truy vấn ngày càng tăng khi phạm vi truy vấn tương lai ngày càng xa. Thực nghiệm 3-2. So sánh hiệu năng của DO-TPR*-tree với TPR*-tree Trong thực nghiệm này, nghiên cứu sinh so sánh, đánh giá hiệu năng của phương pháp đề xuất, DO-TPR*-tree, với phương pháp gốc là TPR*-tree. Các kết quả thực nghiệm của cả hai phương pháp này được biểu diễn trong hình 3.11, trong đó đồ thị hiển thị trung bình các kết quả tìm được ở hình 3.11a, trung bình số nút phải xử lý ở hình 3.11b, thời gian thực hiện truy vấn ở hình 3.11c. 0,00 50,00 100,00 150,00 200,00 250,00 1 0 - 2 0 1 0 - 3 0 1 0 - 4 0 1 0 - 5 0 A V G . N O D E A C C E S S ( N U M ) FUTURE QUERY TIME INTERVAL 1K 10K 50K 100K 0,00 5,00 10,00 15,00 20,00 25,00 30,00 1 0 - 2 0 1 0 - 3 0 1 0 - 4 0 1 0 - 5 0 Q U E R Y E X E C U T IO N T IM E ( S ) FUTURE QUERY TIME INTERVAL 1K 10K 50K 100K 93 (a) Trung bình kết quả tìm được (b) Trung bình số nút phải xử lý (c) Thời gian thực hiện truy vấn Hình 3.11. So sánh hiệu năng của DO-TPR*-tree với TPR*-tree 0 50 100 150 200 250 300 1 0 - 2 0 1 0 - 3 0 1 0 - 4 0 1 0 - 5 0 A V G . D A T A R E T R IE V E S ( N U M ) FUTURE QUERY TIME INTERVAL TPR*-TRee DO-TPR*-Tree 0 20 40 60 80 100 120 140 1 0 - 2 0 1 0 - 3 0 1 0 - 4 0 1 0 - 5 0 A V G . N O D E A C C E S S ( N U M ) FUTURE QUERY TIME INTERVAL TPR*-TRee DO-TPR*-Tree 0 5 10 15 20 1 0 - 2 0 1 0 - 3 0 1 0 - 4 0 1 0 - 5 0 Q U E R Y E X E C U T IO N T IM E ( S ) FUTURE QUERY TIME INTERVAL TPR*-TRee DO-TPR*-Tree 94 Những kết quả thực nghiệm trên chỉ ra rằng số lượng trung bình kết quả tìm được là tương đương nhưng trung bình số nút phải xử lý ít đi và thời gian thực hiện truy vấn giảm xuống khoảng 30%. Phương pháp mà nghiên cứu sinh đề xuất cho kết quả truy vấn nhanh hơn phương pháp gốc. Ở Việt Nam, với hạ tầng viễn thông đang phát triển, mạng truyền thông 3G thường bị lỗi hay chập chờn ở nhiều điểm ngay cả khi đang ở trong thành phố, tần suất cập nhật vị trí các điểm chuyển động sẽ bị hạn chế. Do đó khi truy vấn, hệ thống đòi hỏi cần nhiều lần điều chỉnh mật độ đủ tốt. Phương pháp của nghiên cứu sinh tỏ ra rất hiệu quả trong điều kiện này. Trong những trường hợp không cần điều chỉnh mật độ đủ tốt, phương pháp của nghiên cứu sinh hoạt động tương tự phương pháp gốc của TPR*-tree. Kết luận chương Chương 3 đã trình bày một số cấu trúc cây cơ bản việc trong lập chỉ mục dữ liệu không gian-thời gian. Trong chương này, nghiên cứu sinh cũng đã trình bày kết quả nghiên cứu là một cấu trúc cây mới được đề xuất dựa trên cây TPR*-tree nhằm giảm bớt các vùng không gian trống mỗi khi thực hiện truy vấn liên tục bằng cách điều chỉnh MBR theo mật độ, đặt tên là DO-TPR*-tree. Thuật toán xử lý truy vấn DOA_Search trong cấu trúc cây này đã được đưa ra và chứng minh tính đúng đắn. Các thực nghiệm cũng chứng tỏ cấu trúc cây DO-TPR*-tree đem lại hiệu năng truy vấn tốt hơn trong nhiều trường hợp so với cấu trúc cây ban đầu là TPR*-tree. Kết quả nghiên cứu này được thể hiện trong công bố (4) của nghiên cứu sinh. 95 KẾT LUẬN Luận án đã đề xuất các phương pháp giải quyết một số vấn đề còn tồn tại trong việc xây dựng cơ sở dữ liệu các đối tượng chuyển động để giải quyết các bài toán trong ứng dụng MODB đang phát triển rất mạnh mẽ hiện nay, đặc biệt là ứng dụng quản lý thông tin đối tượng chuyển động hay quản lý và điều hành giao thông. Các kết quả chính bao gồm: (1) Giải quyết vấn đề về mô hình hóa vị trí của đối tượng chuyển động dưới dạng thuộc tính động. Thuộc tính động ít cần phải cập nhật hơn thông tin vị trí do đó sẽ hạn chế được tần suất cập nhật vào cơ sở dữ liệu (mà thường là rất lớn trong các ứng dụng MODB). Thuộc tính động có thể được xác định nhờ vào hai phương pháp dự đoán vị trí đã đề xuất trong luận án: - Dự đoán vị trí của đối tượng dựa theo hàm chuyển động sử dụng mô hình W- EWMA - Dự đoán dựa trên hành vi của đối tượng sử dụng khai phá luật kết hợp của các mẫu hình di chuyển (2) Giải quyết vấn đề về lập chỉ mục không gian cho biểu diễn hình học của các thuộc tính động nhằm tăng hiệu năng truy vấn trên dữ liệu không gian-thời gian. Luận án đã đề xuất cấu trúc chỉ mục mới là DO-TPR*-tree, dựa trên cấu trúc cây TPR*- tree. Cấu trúc này sử dụng điều chỉnh mật độ đủ tốt và tỏ ra rất hiệu quả khi xây dựng ứng dụng MODB với hạ tầng viễn thông đang phát triển, đôi lúc còn xảy ra tình trạng mất kết nối như ở Việt Nam. Luận án hướng tới một số vấn đề có thể tiếp tục nghiên cứu: - Phát triển phương pháp dự đoán theo hành vi của đối tượng theo các mô hình thống kê, suy luận khác nhằm nâng cao khả năng dự đoán vị trí của đối tượng ở tương lai xa. - Phát triển cấu trúc chỉ mục DO-TPR*-tree trên mạng giao thông đô thị (Fixed Network) nhằm tiếp tục tối ưu truy vấn liên tục vị trí đối tượng chuyển động trong 96 các ứng dụng MODB cho đô thị (quản lý phương tiện/người chuyển động trong thành phố với số lượng rất lớn, tần suất cập nhật và truy vấn liên tục rất cao). 97 DANH MỤC CÁC CÔNG TRÌNH ĐÃ CÔNG BỐ 1. Nguyễn Tiến Phương, Đặng Văn Đức và đồng nghiệp, “Một mô hình dịch vụ trên cơ sở vị trí địa lý để theo dõi, giám sát đối tượng chuyển động”, Kỷ yếu hội thảo “Một số vấn đề chọn lọc của Công nghệ thông tin và truyền thông”, Biên Hòa, 2009, trang 512-523. 2. Nguyễn Tiến Phương, Đặng Văn Đức, “Dự đoán vị trí của đối tượng chuyển động theo mô hình W-EWMA”, Kỷ yếu hội thảo “Một số vấn đề chọn lọc của Công nghệ thông tin và truyền thông”, Cần Thơ, 2011, trang 109-116. 3. Nguyen Tien Phuong, Dang Van Duc, “Predict the location of moving objects using mining Association rules of movement patterns”, Journal of Computer Science and Cybernetics, T.29, S.3 (2013), p252-264. 4. Nguyen Tien Phuong, Dang Van Duc, “DO-TPR*-tree: A density optimal method for TPR*-tree”, Journal of Computer Science and Cybernetics, T31, S1 (2015), p43-54. 98 TÀI LIỆU THAM KHẢO 1. Agrawal R., Imielinski T., Swami A. (2003), “Mining association rules between sets of items in large databases”, ACM Sigmod Int. Conf. on Management of Data, pp. 207-216. 2. Beckmann N., Kriegel H., Schneider R., and Seeger B. (1990), “The R*-tree: An efficient and robust access method for points and rectangles”, Proc. of ACM SIGMOD Record, New York, NY, USA, 19, pp. 322-331. 3. Cai Y. (2004), “Processing range-monitoring queries on heterogeneous mobile objects”, Proc. IEEE Inter. Conf. on Mobile Data Management, pp. 27-38. 4. Cai Y., and Ying Cai (2006), “Real-time processing of range-monitoring queries in heterogeneous mobile databases”, IEEE Transactions on Mobile Computing, 5(7), pp. 931-942. 5. Craig S., Raj M., Stephen B. (2003), “An Approach to Predicting the Location of Moving Objects During On-Road Navigation”, 18th Int. Joint Conf. on Artificial Intelligence. 6. Gedik B. (2006), “MobiEyes: A distributed location monitoring service using moving location queries”, IEEE Transactions on Mobile Computing, 5(10), pp. 1384-1402. 7. Gedik B. (2006), “Processing moving queries over moving objects using motion-adaptive indexes”, IEEE Transactions on Knowledge and Data Engineering, 18(5), pp. 651-668. 8. Güting R. H. (2000), “A Foundation for Representing and Querying Moving Objects”, ACM transactions on database systems, 25(1), pp. 1-42. 9. Guttman A. (1984), “R-trees: a dynamic index structure for spatial searching”, Proc. of ACM SIGMOD ’84, Boston, Massachusetts, USA, ACM, New York, NY, USA, pp. 47–57. 10. Guttman, Antonin (1984), “R-trees: a dynamic index structure for spatial searching”, SIGMOD Record (ACM Special Interest Group on Management of Data), pp. 47-57. 99 11. Hoyoung J. et al. (2008), “A Hybrid Prediction Model for Moving Objects”, Data Engineering, IEEE 24th Int. Conf.. 12. Huang X., and Jensen C. S. (2004), “Towards a streams-based framework for defining location-based queries”, Proc. of the 2nd Workshop on SpatioTemporal Database Management (STDBM), pp. 73–80. 13. Ilarri S. (2006), “Location-dependent queries in mobile contexts: Distributed processing using mobile agents”, IEEE Transactions on Mobile Computing, 5(8), pp. 1029-1043. 14. Kalnis P., Mamoulis N., Bakiras S. (2005), “On discovering moving clusters in spatio-temporal data”, Proc. of the Intl. Symposium on Spatial and Temporal Databases, pp. 364–381. 15. Kim Dong-Oh, Lee Kang-Jun (2007), “An Efficient Indexing Technique for Location Prediction of Moving Objects”, Proc. of the 11th Int. Conf., KES 2007 and XVII Italian Workshop on Neural Networks Conf. on Knowledge- Based Intelligent Information and Engineering Systems. 16. Lazaridis I., Porkaew K., and Mehrotra S. (2002), “Dynamic queries over mobile objects”, Proc. of the 8th Int. Conf. on Extending Database Technology (EDBT), Springer, Berlin/Heidelberg, Germany, pp. 269-286. 17. Lee D. L., Xu J., Zheng B., and Lee W. C. (2002), “Data management in location-dependent information services”, IEEE Pervasive Computing, Vol. 1, pp. 65-72. 18. Li Y., He B., Luo Q., and Yi K. (2009), “Tree indexing on flash disks”, Proc. of ICDE ’09, Shanghai, China, IEEE Computer Society, Washington DC, USA, pp. 1303-1306. 19. Luis O. A., Vania B. et al. (2007), “A Model for Enriching Trajectories with Semantic Geographical Information”, Proc. of the 15th annual ACM Int. Sym. on Advances in geographic information systems, New York, NY, USA. 100 20. Madhavan R., and Schlenoff C. (2003), “Moving Object Prediction and Tracking for Off-road Autonomous Navigation”, Proc. of the SPIE Aerosense 2003 Conf., Orlando, FL. 21. Marcin G., Pawel J. 2009, “Using Apriori-like Algorithms for Spatio- Temporal Pattern Queries”, Proc. of the Int. MultiConf. on Computer Science and Information Technology, pp. 43-48. 22. Martin E., Hans-Peter K., Jörg S., Xiaowei X. (1996), “A density-based algorithm for discovering clusters in large spatial databases with noise”, Proc. of the 2nd Int. Conf. on Knowledge Discovery and Data Mining (KDD-96), AAAI Press. pp. 226–231. 23. Mikołaj M. (2007), “Mining Frequent Trajectories of Moving Objects for Location Prediction”, Proc. of the 5th Int. Conf. on Machine Learning and Data Mining in Pattern Recognition. 24. Mokbel M. F. (2004), “SINA: Scalable incremental processing of continuous queries in spatiotemporal databases”, Proc. ACMSIGMOD Inter. Conf. on Management of Data, pp. 623-634. 25. Mokbel M. F., and Aref W. G. (2008), “SOLE: Scalable on-line execution of continuous queries on spatiotemporal data streams”, VLDB J., 17(5), pp. 971– 995. 26. Mokbel M. F., Xiong X., Hammad M. A., and Aref W. G. (2005), “Continuous query processing of spatiotemporal data streams in PLACE”, GeoInformatica, 9(4), pp. 343-365. 27. MonetDB (2008), “MonetDB Introduction”, www.monetdb.org/documentation/ UserGuide. 28. Nascimento M. A., Silva J. R. O., and Theodoridis, Y. (1999), “Evaluation of access structures for discretely moving points”, Proc. of the 1st Int. Workshop on Spatio-Temporal Database Management (STDBM), Springer, Berlin/Heidelberg, Germany, pp. 171–188. 101 29. Nehme R. V., et al. (2006), “SCUBA: Scalable Cluster-Based Algorithm for evaluating continuous spatio-temporal queries on moving objects”, Advances in Database Technology – EDBT, Springer Berlin/Heidelberg, pp. 1001-1019. 30. Nehme R. V., et al. (2007), “ClusterSheddy: Load shedding using moving clusters over spatiotemporal data streams”, Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics), pp. 637-651. 31. Nishimura S. (2011), “MD-HBase: A scalable multidimensional data infrastructure for location aware services”, IEEE 12th Int. Conf. on Mobile Data Management, pp. 7-16. 32. Ouri W., Prasad S., Bo X., Jutai Z., and Sam C. (1999), “DOMINO: databases fOr MovINg Objects tracking”, SIGMOD Rec, 28(2), pp. 547-549 33. Patel J. M., Chen Y., and Chakka V. P. (2004), “Stripes: an efficient index for predicted trajectories”, SIGMOD, pp. 635-646. 34. Patroumpas K. and Sellis T. K. (2004), “Managing trajectories of moving objects as data streams”, Proc. of the 2nd Workshop on Spatio-Temporal Database Management (STDBM), pp. 41-48. 35. Prabhakar S. (2002), “Query indexing and velocity constrained indexing: Scalable techniques for continuous queries on moving objects”, IEEE Transactions on Computers, 51(10), pp. 1124-1140. 36. Saltenis S., Jensen C. S., Leutenegger S. T., and Lopez M. A. (2000), “Indexing the positions of continuously moving objects”, Proc. of ACM SIGMOD Record, New York, NY, USA, 29, pp. 331-342. 37. Silva Y. N., Xiong X., and Aref W. G. (2009), “The RUM-tree: Supporting frequent updates in R-trees using memos”, VLDB Journal, 18, pp. 719-738. 38. Sistla A. P. (1997), “Modeling and querying moving objects”, Proc. Int. Conf. on Data Engineering, pp. 422-432. 39. Spaccapietra, et al. (2007), A conceptual view on trajectories, Technical report, Ecole Polytechnique Federal de Lau-sanne. 102 40. Su J., Xu H., and Ibarra O. H. (2001), “Moving objects: Logical relationships and queries”, Proc. of the 7th Int. Symposium on Advances in Spatial and Temporal Databases (SSTD), Springer, Berlin/Heidelberg, Germany, pp. 3- 19. 41. Tao Y., Faloutsos C., Papadias D., and Liu B. (2004), “Prediction and indexing of moving objects with unknown motion patterns”, SIGMOD, pp. 611-622. 42. Tao Y., Papadias D., and Sun J. (2003), “The TPR*-tree: An optimized spatio- temporal access method for predictive queries”, Proc. of the 29th Int. Conf. on Very Large Data Bases, USA, pp. 790-801. 43. Theodoridis Y., Silva R., and Nascimento M. (1999), “On the generation of spatiotemporal datasets,” Advances in Spatial Databases, pp. 147-164. 44. Trajcevski G. (2004), “CAT: Correct answers of continuous queries using triggers”, Lecture Notes in Computer Science 2992, pp. 837-840. 45. Wang Y., Lim E.P., Hwang S.Y. (2006), “Efficient mining of group patterns from user movement data”, DKE57, pp. 240-282. 46. Wolfson O., Xu B., Chamberlain S., and Jiang L. (1998), “Moving objects databases: issues and solutions”, Scientific and Statistical Database Management, pp. 111-122. 47. Xiaoguang H., Yan Y., et al. (2007), “Prediction of Moving Objects' K- Nearest Neighbor Based on Fuzzy-Rough Sets Theory”, Fuzzy Systems and Knowledge Discovery. 48. Yiu M., Tao Y., and Mamoulis N. (2008), “The Bdual-tree: Indexing moving objects by space filling curves in the dual space”, The Int. Journal on Very Large Data Bases, 17, pp. 379-400. 49. Zheng B. (2010), “DISQO: A DIStributed Framework for Spatial Queries over Moving Objects”, 39th Int. Conf. on Parallel Processing, pp. 414-423. 50. Chen, Y. (2003), “CAMEL: A moving object database approach for intelligent location aware services”, Lecture Notes in Computer Science 2574, pp. 331- 334. 103 51. Arthur A.S., Gopalan N.P. (2011), “Frequent Pattern Mining of Trajectory Coordinates using Apriori Algorithm”, International Journal of Computer Applications (0975 – 8887), vol. 22, no. 9. 52. Heena R., Shuchita U., Vinod K. (2014), “Frequent Pattern Analysis of Moving Objects Using Apriori Algorithm”, International Journal of Emerging Research in Management &Technology, vol. 3, issue 4. 53. Gokhan Y., Dimitrios K., et al. (2005), “A data mining approach for location prediction in mobile environments” Data & Knowledge Engineering, vol. 54, no. 2, pp. 121-146. 54. S. Rajagopal, R.B. Srinivasan, R.B. Narayan, X.B.C. Petit (2002), “GPS-based predictive resource allocation in cellural networks”, Proceedings of the IEEE International Conference on Networks (IEEE ICON’02), pp. 229-234. 55. A. Bhattacharya, S.K. Das (2002), “LeZi-Update: An information-theoretic approach to track mobile users in PCS networks”, ACM Wireless Networks, vol. 8, issue (2–3), pp. 121-135. 56. Patrick P. C., Martial H. (2006), “Learning and Predicting Moving Object Trajectory: A Piecewise Trajectory Segment Approach”, tech. report CMU- RI-TR-06-42, Robotics Institute, Carnegie Mellon University. 57. Lim S.C. (2011), “A More Efficient TPR*-Tree with Cooling-down Nodes”, Proceedings of the Korea Information Science Society, Vol. 1 No. 1B. 58. Fang Y., Cao J., Wang J., et al. (2012), “HTPR*-Tree: An Efficient Index for Moving Objects to Support Predictive Query and Partial History Query”, LNCS 7142. 59. Lin B., Su J. (2005), “Handling Frequent Updates of Moving Objects”, ACM 14th Conference on Information and Knowledge Management. 60. Liao W., Tang G., Jing N., Zhong Z. (2006), “VTPR-Tree: An Efficient Indexing Method for Moving Objects with Frequent Updates”, LNCS 4231. 104 61. He M.-S., Dong Y.-H., Fu S.-C. (2011), “TPRA-tree: An Improved Spatial- temporal Index for Predictive Queries”, Journal of Ningbo University Natural Science and Engineering Edition, Vol. 24 No. 1. 62. Jamal R. (2013), “Detection of Objects in Motion - A Survey of Video Surveillance”, Journal of Scientific Research - Advances in Internet of Things, Vol.3 No.4. 63. Caifeng L., Ling W., Jidong C., et al. (2007), “Effective Density Queries for Moving Objects in Road Networks”, Proc. of the joint 9th Asia-Pacific web and 8th Int. Conf. on web-age Info. Mgt. Conf. on Adv. in data and web Mgt., Berlin, pp. 200-211

Các file đính kèm theo tài liệu này:

  • pdfluan_an_mot_so_ky_thuat_du_bao_vi_tri_va_truy_van_cac_doi_tu.pdf
Luận văn liên quan