Talk:Deutsch–Jozsa algorithm

Latest comment: 2 years ago by Jehochman in topic Ancilla bit

corrected mistake

edit

I found a small mistake in the description of the algorithm, and I corrected it. To me, the wording of the article is still a bit sloppy; but I'm not going to try to fix it at the moment. At least now the algorithm works. :) Karadoc** 05:27, 3 July 2006 (UTC)Reply

another mistake?

edit

The text says: "The best case occurs where the function is balanced and the first two output values that happen to be selected are different." Isn't the best case when the function is constant and the two differing values are observed? — Preceding unsigned comment added by Wmagro (talkcontribs) 19:48, 17 January 2020 (UTC)Reply

If the function is constant, you can't observe different values. 128.250.0.202 (talk) 06:00, 25 August 2022 (UTC)Reply

What the...?

edit

In section History, it is claimed that the original Deutsch algorithm was meant to solve the n=1 case only, and, furthermore, it was randomized, having only a 1/2 probability of successfully recognizing the input function as either constant or not. Well, i don't need a quantum computer for that... Simply toss a coin. If it comes up heads, claim 'constant'; 'non-constant' if tails. Or the other way around. You get the idea: Something must be amiss here. —Preceding unsigned comment added by 89.152.248.155 (talk) 04:02, 10 March 2008 (UTC)Reply

As I recall, the algorithm would return yes, no or fail (failed with prob 1/2). The gain over a coin flip was that the algorithm guaranteed confidence in the result. That is, a yes answer from the algorithm means it really was constant. Skippydo (talk) 07:45, 23 March 2008 (UTC)Reply
In the original algorithm, which result can we be confident in? Is it when we find that the function is *constant* we're sure it's correct and can stop trying or is it when we find that the function is *balanced* that we're sure it's correct and can stop trying? We should include this in the text. The author of this question is right, it currently sounds like the original algorithm didn't tell us much! :o) --DavidBoden (talk) 13:59, 20 January 2009 (UTC)Reply
Consider changing to this? The original algorithm was successful in detecting a constant function with a probability of one half and did not falsely indicate that a function was constant when it was balanced. Applying the function n times and having it indicate balanced every time increases confidence that the function is in fact balanced in the order of  . —Preceding unsigned comment added by DavidBoden (talkcontribs) 15:42, 15 August 2009 (UTC)Reply
From what I understand from Scott Aaronson's blog, Skippydo's interpretation seems correct. Possibly the algorithm outputs 2 bits, one which indicates whether the algorithm has failed or succeeded, and the second bit tells you whether it is constant or not in the case that it has succeeded. --Robin (talk) 19:49, 17 August 2009 (UTC)Reply

problem with the formula for the probability of measuring ket 0

edit

The formula that is given for measuring ket 0 does not make sense. Take the case that f(x) is balanced. The current formula is:   say f(x) = 1 then the formula evaluates to:   this is not equal to 1 as is claimed in the article, so there is an error in the formula
the correct formula should be:  

Good catch, the square was the typo. Fixed! Skippydo (talk) 23:41, 8 April 2008 (UTC)Reply



I think that the correct formula for the probability should be:
 
not
 
The following article mentions the Deutsch-Jozsa Algorithm and it says that the amplitude of ket(0) is:
 
And the probability is the square of the amplitude.
http://arxiv.org/abs/quant-ph/9708016v1 —Preceding unsigned comment added by Ursubaloo (talkcontribs) 16:47, 9 April 2008 (UTC)Reply

Fixed! Skippydo (talk) 23:19, 9 April 2008 (UTC)Reply

A more complete explanation of the 2 bit algorithm

edit

How about expanding the whole basic 2 bit algorithm out? It never hurts to explain the same thing more than once; bearing in mind that this is the simplest possible useful quantum computing algorithm, we want to make the article as accessible as possible to people new to the subject. I'm still working on this one:

The starting point is:  

Applying   gives  

Function Type Output state Which equals
  Constant    
  Balanced    
  Balanced    
  Constant    

==== This paragraph is okay, but IMHO it should be after the main algorithm. Otherwise it interrupts the flow of the article. MikeR613 (talk) 19:10, 9 September 2012 (UTC)Reply

Constant Functions

edit

For the constant functions, the expression for x, the first qubit, remains  .

This follows logically when we imagine the implementation of the constant f(x) functions. For f(x) = 0, nothing whatsoever needs to be wired into the circuit to implement the function. The value of the y qubit does not change. It is therefore not surprising that the state of qubit x does not change. The same is true of f(x) = 1; the function does not need to make any reference to qubit x.

Balanced Functions

edit

For the balanced functions, the expression for x is changed to   due to interactions between the x and y qubits. *More explanation required here*

Hadamard transform of qubit x

edit

The key to the algorithm is the final Hadamard transformation on qubit x, which maps the constant functions to   and the balanced functions to  

The behaviour is described as part of the description of Hadamard Transform Quantum Gates. DavidBoden (talk)

I agree with your reasoning for including this. You have my blessing to incorporate this. Bender2k14 (talk) 12:50, 14 October 2010 (UTC)Reply
Looks good. I advise against introducing the vector representation, it isn't currently used in the article and I doubt it's needed. Skippydo (talk) 23:48, 20 October 2010 (UTC)Reply

Motivation needs a rewrite

edit

The content of the motivation section appears irrelevant to the algorithm itself. The MWI discussion was particularly frustrating, and distracts from the rest of the article. Can we leave metaphysics out and stick with the mechanics of Deutsch-Jozsa? Much cleanup and explanation might make the section less cognitively jarring. 198.102.153.2 (talk) 23:52, 25 March 2011 (UTC)Reply

Agreed. This is just an excellent and interesting algorithm. There is absolutely *no* need to bring up *any* interpretation of QM, especially in such an obfuscating and unilluminating way. 129.97.136.28 (talk) 13:36, 9 August 2011 (UTC)Reply
I removed two paragraphs from that section. The remainder may still need a bit of work but I don't have an opinion of how to improve it. Skippydo (talk) 22:32, 9 August 2011 (UTC)Reply
I rewrote the motivation. Is that better? --Robin (talk) 03:01, 23 March 2013 (UTC)Reply

Proposed move: Deutsch–Jozsa algorithm -> Deutsch–Jozsa problem

edit

I think the article should be named after the problem instead of the algorithm. The problem was invented to show a separation and didn't exist before. (Unlike, say, Shor's algorithm for factorization or Grover's algorithm for the search problem.) That also makes the article an appropriate place to discuss classical algorithms and oracle separations that can be proved using this problem. --Robin (talk) 03:05, 23 March 2013 (UTC)Reply

Better Explaination for the function on the problem statement?

edit

Am i the only one that i cannot understand the symbolism of the function mentioned on the problem statement section? Please any help apreciated.. Sperxios (talk) 00:15, 23 August 2013 (UTC)Reply

In layman's terms, the function   takes  -digit binary value as inputs and produces either a   or a   as output for each such value. AldaronT/C 01:04, 23 August 2013 (UTC)Reply
Thank you Aldaron! I added your description in main page, since i believe that not everybody is aware of this notation. — Preceding unsigned comment added by Sperxios (talkcontribs) 10:39, 25 August 2013 (UTC)Reply

Can we have references for the classical solution section?

edit

Especially for the claim regarding conventional randomized algorithms. Where is this being got from? M cuffa (talk) 13:15, 8 February 2014 (UTC)Reply

Agreed. Where does the "classical solution" section come from? Dr. Universe (talk) 14:56, 30 December 2019 (UTC)Reply

Missing main algorithm description and a section about implementation

edit

The actual algorithm for the general n to 1 case is not described, and there are no implementation suggestions or details regarding implementation attempts made in the past. — Preceding Aviv comment added by 87.211.107.83 (talk) 11:28, 30 September 2014 (UTC)Reply

Example circuits

edit

Circuits that provide a constant output of either   or  , assuming that the output qubit is initialised to  , can be viewed as having the output qubit disconnected from the input qubits. It is therefore expected that the input qubits measure as  .

Output qubit is constant   Output qubit is constant  
   

In the circuit diagrams, the functions are shown within a dashed line border. It is important to note that an   gate that flips   to   has no effect in the Hadamard basis.   passes through an   gate unchanged.

A sub-class of balanced functions uses only a single input qubit to decide whether the output qubit is   or  .

Output qubit is the value of one input qubit Output qubit is the negation of one input qubit
   

In the Hadamard basis, the   gate affects the value of what would be considered the input qubit in the computational basis. In these examples, the input qubits will measure as   due to the connection between the input qubits and the output qubit.

DavidBoden (talk) 20:05, 12 March 2019 (UTC)Reply

Ancilla bit

edit

The circuit diagram shows the use of an ancilla bit and computing y + f(x). This complexity is not necessary. The algorithm can be implemented with n hadamard gates before and after a phase oracle and then measure all the outputs. I think we should show this alternative description. The two are equivalent, but it can be easier to understand the second. Jehochman Talk 18:11, 15 October 2022 (UTC)Reply