Thuật toán Grover

Thuật toán tìm kiếm Grover là một thuật toán lượng tử dùng trong việc tìm kiếm trên một cơ sở dữ liệu chưa sắp xếp gồm N phần tử trong độ phức tạp về thời gian là O(N1/2) và sử dụng O(log N) không gian lưu trữ. Thuật toán được trình bày bởi Lov Grover vào năm 1996.

Giống như nhiều thuật toán lượng tử khác, thuật toán lượng tử cho kết quả có xác suất chính xác cao. Xác suất thất bại có thể được giảm đi bằng cách thực hiện nhiều lần thuật toán.

Ứng dụng[sửa | sửa mã nguồn]

Thuật toán Grover có thể được dùng để giải ngược phương trình. Nói cách khác, nếu có 1 phương trình y=f(x) có thể tính toán được trên 1 máy tính lượng tử, ta có thể dùng thuật toán Grover để tính được x với y cho trước. "Giải ngược phương trình" có thể được liên hệ với việc tìm kiếm trong 1 cơ sở dữ liệu vì ta có thể tạo ra 1 phương trình sao cho phương trình đó tạo ra một số y duy nhất nếu x trùng với 1 giá trị ở trong cơ sở dữ liệu.

Thuật toán Grover cũng có thể dùng để tính toán số trung bình và số trung vị trong 1 tập số. Thuật toán cũng có thể được tối ưu hóa nếu như có nhiều hơn 1 kết quả tìm kiếm hoặc số kết quả tìm kiếm đã được biết trước.

Khởi tạo[sửa | sửa mã nguồn]

Giả sử ta có 1 cơ sở dữ liệu gồm N phần tử. Thuật toán cần có 1 không gian N chiều, dùng n=log2N qubits. Ta cần xác định chỉ số của phần tử thỏa mãn những điều kiện tìm kiếm. Cho f là phương trình sao cho f cho giá trị 0 hoặc 1, f(ω)=1 khi và chỉ khi ω thỏa mãn những điều kiện tìm kiếm. Ta sử dụng toán tử Uω:

Mục tiêu của ta là tìm ra chỉ số của

Thuật toán[sửa | sửa mã nguồn]

[Mạch lượng tử thể hiện Thuật Toán Grover

Các bước của thuật toán được thực hiện như sau. Cho là chồng chập của các trạng thái:

.

Toán tử

là toán tử truyền thông tin (diffusion operator).

Thuật toán gồm các bước:

  1. Khởi tạo hệ thống ở trạng thái:
  2. Thực hiện "Vòng lặp Grover" r(N) lần. Hàm r(N), có độ phức tạp O(N½), được miêu tả như sau.
    1. Thực hiện toán tử .
    2. Thực hiện toán tử .
  3. Thực hiện phép đo Ω. Kết quả của phép đo sẽ là λω với xác suất tiến tới 1 khi N≫1. Từ λω, ta có thể tìm thấy ω.

Vòng lặp đầu tiên[sửa | sửa mã nguồn]

Từ định nghĩa, ta có bước khởi tạo

,

Uω có thể được biểu diễn theo cách:

.

Các bước sau cho thấy những gì xảy ra trong vòng lặp đầu tiên: .

.
.
.

Sau khi 2 toán tử ( and ) được sử dụng, giá trị cần tìm đã tăng từ đến .

Tham khảo[sửa | sửa mã nguồn]

  • Reinhold, Blumel (2009). “Foundations of Quantum Mechanics: From Photons to Quantum Computers”. Chú thích journal cần |journal= (trợ giúp)
Chúng tôi bán
Bài viết liên quan
[Review Game] Silent Hill: The Short Messenger
[Review Game] Silent Hill: The Short Messenger
Tựa game Silent Hill: The Short Messenger - được phát hành gần đây độc quyền cho PS5 nhân sự kiện State of Play
20 Git command mà mọi lập trình viên cần biết
20 Git command mà mọi lập trình viên cần biết
20 Git command mà tôi dùng trong mọi lúc
Visual Novel Bishoujo Mangekyou 1 Việt hóa
Visual Novel Bishoujo Mangekyou 1 Việt hóa
Onogami Shigehiko, 1 giáo viên dạy nhạc ở trường nữ sinh, là 1 người yêu thích tất cả các cô gái trẻ (đa phần là học sinh nữ trong trường), xinh đẹp và cho đến nay, anh vẫn đang cố gắng giữ bí mât này.
Những thực phẩm giúp tăng sức đề kháng trước dịch cúm Corona
Những thực phẩm giúp tăng sức đề kháng trước dịch cúm Corona
Giữa tâm bão dịch bệnh corona, mỗi người cần chú ý bảo vệ sức khỏe để phòng tránh vi khuẩn tấn công vào cơ thể