Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Arrow up icon
GO TO TOP
Dancing with Qubits

You're reading from   Dancing with Qubits How quantum computing works and how it can change the world

Arrow left icon
Product type Paperback
Published in Nov 2019
Publisher Packt
ISBN-13 9781838827366
Length 516 pages
Edition 1st Edition
Arrow right icon
Author (1):
Arrow left icon
Robert S. Sutor Robert S. Sutor
Author Profile Icon Robert S. Sutor
Robert S. Sutor
Arrow right icon
View More author details
Toc

Table of Contents (16) Chapters Close

Preface
1 Why Quantum Computing? FREE CHAPTER 2 They’re Not Old, They’re Classics 3 More Numbers than You Can Imagine 4 Planes and Circles and Spheres, Oh My 5 Dimensions 6 What Do You Mean ‘‘Probably’’? 7 One Qubit 8 Two Qubits, Three 9 Wiring Up the Circuits 10 From Circuits to Algorithms 11 Getting Physical 12 Questions about the Future Afterword
Other Books You May Enjoy Appendices

9.9 Simon’s algorithm

There is one more algorithm using an oracle that we now cover before we leave this chapter and that is Simon’s algorithm. It may seem like an odd use of an oracle but the techniques are further used in section 10.5

9.9.1 The problem

Our problem is to find how the values of a function on whole numbers repeat themselves. Recall that by {0, 1}n we mean a string or sequence of n 0s and 1s. For example, if n = 2 then

{0, 1}2 = {00, 01, 10, 11} .
A function
f: {0, 1}n → {0, 1}n
takes such binary strings of length n to other such binary strings. For any two x and y in {0, 1}n, when does f(x) = f(y)?

In general, we don’t know, but we could require that there exists some r in {0, 1}n such that f(x) = f(y) if and only if xy is in {0n, r}.

Here we have ‘‘⊕’’ being the binary xor function, which is addition modulo 2. (We covered modular...

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image