Xây dựng cổng lượng tử XNOR


10

Đã thử hỏi ở đây trước, vì một câu hỏi tương tự đã được hỏi trên trang web đó. Có vẻ phù hợp hơn cho trang web này tuy nhiên.

Theo hiểu biết hiện tại của tôi rằng một cổng XOR lượng tử là cổng CNOT. Cổng XNOR lượng tử có phải là cổng CCNOT không?


Cảm ơn đã mang câu hỏi của bạn đến đây, nó thực sự là một câu hỏi tuyệt vời cho trang web này.
James Wootton

Câu trả lời:


7

Bất kỳ hàm một bit cổ điển nào trong đó là đầu vào -bit và là đầu ra -bit có thể được viết dưới dạng tính toán có thể đảo ngược, (Lưu ý rằng bất kỳ chức năng nào của đầu ra đều có thể được viết dưới dạng các hàm 1 bit riêng biệt.)f:xyx{0,1}nny{0,1}n

fr:(x,y)(x,yf(x))
mm

Một cổng lượng tử thực hiện điều này về cơ bản chỉ là cổng lượng tử tương ứng với việc đánh giá hàm đảo ngược. Nếu bạn chỉ đơn giản viết ra bảng chân lý của hàm, thì mỗi dòng tương ứng với một hàng của ma trận đơn vị và đầu ra cho bạn biết mục nhập cột nào chứa 1 (tất cả các mục khác chứa 0).

Trong trường hợp XNOR, chúng ta có bảng chân lý chuẩn và bảng chân lý hàm có thể đảo ngược Do đó, ma trận đơn vị là

xf(x)001010100111(x,y)(x,yf(x))000001001000010010011011100100101101110111111110
U=(0100000010000000001000000001000000001000000001000000000100000010).
Điều này có thể dễ dàng bị phân tách theo một vài cổng không được kiểm soát và một hoặc hai lần lật.

Phương pháp mà tôi vừa phác thảo cung cấp cho bạn một cách rất an toàn để thực hiện việc xây dựng hoạt động cho bất kỳ , nhưng nó không tái tạo hoàn hảo sự tương ứng giữa XOR và không được kiểm soát. Để làm được điều đó, chúng ta cần giả sử thêm một chút về các thuộc tính của hàm .f(x)f(x)

Giả sử rằng chúng ta có thể phân tách đầu vào thành sao cho và sao cho tất cả các giá trị của , các giá trị của là khác biệt cho mỗi . Trong trường hợp này, chúng ta có thể định nghĩa đánh giá hàm đảo ngược làĐiều này có nghĩa là chúng tôi đang sử dụng ít hơn 1 bit so với cấu trúc trước đó, nhưng từ đây, kỹ thuật có thể được lặp lại.xa,ba{0,1}n1b{0,1}af(a,b)b

f:(a,b)(a,f(a,b)).

Vì vậy, hãy quay trở lại bảng chân lý cho XNOR. Chúng ta có thể thấy điều đó, ví dụ: khi chúng tôi sửa , hai đầu ra là , do đó khác biệt. Tương tự để sửa . Do đó, chúng ta có thể tiến hành xây dựng hàm đảo ngược và điều này mang lại cho chúng ta một

abf(a,b)001010100111
a=01,0a=1
abaf(a,b)0001010010101111
cNOT(1X)
U=(0100100000100001)
cNOT(1X)

xuất sắc! cảm ơn bạn vì điều này & tất cả những câu trả lời tuyệt vời khác mà tôi đã thấy từ bạn (:
meowzz

4

XNOR lượng tử không phải là CCNOT. CCNOT sẽ lấy 3 bit làm đầu vào, trong khi XOR, XNOR và CNOT chỉ lấy 2 bit hoặc qubit làm đầu vào.

Lý do tại sao chúng tôi nói XOR có thể được coi là một CNOT được giải thích ở đây và lý do tương tự có thể được sử dụng để xây dựng XNOR (2 qubit).


Nếu XOR == CNOT, thì XNOR == SWAP?
meowzz

Có vẻ như một câu hỏi riêng biệt.
1271772
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.