Transformada Quântica de Fourier

Na computação quântica, a transformada de Fourier quântica (abreviadamente: QFT) é uma transformação linear em bits quânticos e é o análogo quântico da transformada discreta inversa de Fourier . A transformada de Fourier quântica é uma parte de muitos algoritmos quânticos, notavelmente o algoritmo de Shor para fatorar e calcular o logaritmo discreto, o algoritmo de estimativa de fase quântica para estimar os valores próprios de um operador unitário e algoritmos para o problema do subgrupo oculto . A transformada quântica de Fourier foi inventada por Don Coppersmith .[1]

A transformada quântica de Fourier pode ser realizada de forma eficiente em um computador quântico, com uma decomposição particular em um produto de matrizes unitárias mais simples. Usando uma decomposição simples, a transformada discreta de Fourier em 2 n {\displaystyle 2^{n}} amplitudes podem ser implementadas como um circuito quântico consistindo apenas em O ( n 2 ) {\displaystyle O(n^{2})} Portões Hadamard e portões de mudança de fase controlada, onde n {\displaystyle n} é o número de qubits.[2] Isso pode ser comparado com a transformada discreta de Fourier clássica, que leva O ( n 2 n ) {\displaystyle O(n2^{n})} portões (onde n {\displaystyle n} é o número de bits), que é exponencialmente maior que O ( n 2 ) {\displaystyle O(n^{2})} . No entanto, a transformada de Fourier quântica atua em um estado quântico, enquanto a transformada de Fourier clássica atua em um vetor, portanto, nem toda tarefa que usa a transformada de Fourier clássica pode tirar vantagem dessa aceleração exponencial. 

Os melhores algoritmos de transformada quântica de Fourier conhecidos (no final de 2000) exigem apenas O ( n log n ) {\displaystyle O(n\log n)} portas para conseguir uma aproximação eficiente.[3]

Definição

A transformada de Fourier quântica é a transformada de Fourier discreta clássica aplicada ao vetor de amplitudes de um estado quântico, onde geralmente consideramos vetores de comprimento N = 2 n {\displaystyle N=2^{n}} .

A transformada de Fourier clássica atua em um vetor ( x 0 , x 1 , , x N 1 ) C N {\displaystyle (x_{0},x_{1},\ldots ,x_{N-1})\in \mathbb {C} ^{N}} e mapeia para o vetor ( y 0 , y 1 , , y N 1 ) C N {\displaystyle (y_{0},y_{1},\ldots ,y_{N-1})\in \mathbb {C} ^{N}} de acordo com a fórmula:

y k = 1 N n = 0 N 1 x n ω N k n , k = 0 , 1 , 2 , , N 1 , {\displaystyle y_{k}={\frac {1}{\sqrt {N}}}\sum _{n=0}^{N-1}x_{n}\omega _{N}^{-kn},\quad k=0,1,2,\ldots ,N-1,}

Onde ω N = e 2 π i N {\displaystyle \omega _{N}=e^{\frac {2\pi i}{N}}} e ω N n {\displaystyle \omega _{N}^{n}} é um N th raiz da unidade .

Da mesma forma, a transformada quântica de Fourier atua em um estado quântico | x = i = 0 N 1 x i | i {\displaystyle |x\rangle =\sum _{i=0}^{N-1}x_{i}|i\rangle } e mapeia para um estado quântico i = 0 N 1 y i | i {\displaystyle \sum _{i=0}^{N-1}y_{i}|i\rangle } de acordo com a fórmula:

y k = 1 N n = 0 N 1 x n ω N n k , k = 0 , 1 , 2 , , N 1 , {\displaystyle y_{k}={\frac {1}{\sqrt {N}}}\sum _{n=0}^{N-1}x_{n}\omega _{N}^{nk},\quad k=0,1,2,\ldots ,N-1,}

(As convenções para o sinal do expoente do fator de fase variam; aqui usamos a convenção de que a transformada de Fourier quântica tem o mesmo efeito que a transformada de Fourier discreta inversa e vice-versa. )

Desde a ω N n {\displaystyle \omega _{N}^{n}} é uma rotação, a transformada quântica inversa de Fourier age de forma semelhante, mas com:

x n = 1 N k = 0 N 1 y k ω N n k , n = 0 , 1 , 2 , , N 1 , {\displaystyle x_{n}={\frac {1}{\sqrt {N}}}\sum _{k=0}^{N-1}y_{k}\omega _{N}^{-nk},\quad n=0,1,2,\ldots ,N-1,}

Em caso de | x {\displaystyle |x\rangle } é um estado básico, a transformada quântica de Fourier também pode ser expressa como o mapa

QFT : | x 1 N k = 0 N 1 ω N x k | k . {\displaystyle {\text{QFT}}:|x\rangle \mapsto {\frac {1}{\sqrt {N}}}\sum _{k=0}^{N-1}\omega _{N}^{xk}|k\rangle .}

Equivalentemente, a transformada de Fourier quântica pode ser vista como uma matriz unitária (ou uma porta quântica, semelhante a uma porta lógica booleana para computadores clássicos) agindo em vetores de estado quântico, onde a matriz unitária F N {\displaystyle F_{N}} É dado por

F N = 1 N [ 1 1 1 1 1 1 ω ω 2 ω 3 ω N 1 1 ω 2 ω 4 ω 6 ω 2 ( N 1 ) 1 ω 3 ω 6 ω 9 ω 3 ( N 1 ) 1 ω N 1 ω 2 ( N 1 ) ω 3 ( N 1 ) ω ( N 1 ) ( N 1 ) ] {\displaystyle F_{N}={\frac {1}{\sqrt {N}}}{\begin{bmatrix}1&1&1&1&\cdots &1\\1&\omega &\omega ^{2}&\omega ^{3}&\cdots &\omega ^{N-1}\\1&\omega ^{2}&\omega ^{4}&\omega ^{6}&\cdots &\omega ^{2(N-1)}\\1&\omega ^{3}&\omega ^{6}&\omega ^{9}&\cdots &\omega ^{3(N-1)}\\\vdots &\vdots &\vdots &\vdots &&\vdots \\1&\omega ^{N-1}&\omega ^{2(N-1)}&\omega ^{3(N-1)}&\cdots &\omega ^{(N-1)(N-1)}\end{bmatrix}}}

Onde ω = ω N {\displaystyle \omega =\omega _{N}} . Obtemos, por exemplo, no caso de N = 4 = 2 2 {\displaystyle N=4=2^{2}} e fase ω = i {\displaystyle \omega =i} a matriz de transformação

F 4 = 1 2 [ 1 1 1 1 1 i 1 i 1 1 1 1 1 i 1 i ] {\displaystyle F_{4}={\frac {1}{2}}{\begin{bmatrix}1&1&1&1\\1&i&-1&-i\\1&-1&1&-1\\1&-i&-1&i\end{bmatrix}}}

Propriedades

Unidade

A maioria das propriedades da transformada de Fourier quântica resulta do fato de ser uma transformação unitária . Isso pode ser verificado executando a multiplicação da matriz e garantindo que a relação F F = F F = I {\displaystyle FF^{\dagger }=F^{\dagger }F=I} detém onde F {\displaystyle F^{\dagger }} é o anexo hermitiano de F {\displaystyle F} . Alternativamente, pode-se verificar se os vetores ortogonais da norma 1 são mapeados para vetores ortogonais da norma 1.

Da propriedade unitária segue-se que o inverso da transformada quântica de Fourier é o adjunto Hermitiano da matriz de Fourier, assim F 1 = F {\displaystyle F^{-1}=F^{\dagger }} . Uma vez que existe um circuito quântico eficiente implementando a transformada quântica de Fourier, o circuito pode ser executado no sentido inverso para realizar a transformada quântica inversa de Fourier. Assim, ambas as transformações podem ser executadas com eficiência em um computador quântico.

Implementação de circuito

As portas quânticas usadas no circuito são a porta de Hadamard e a porta de fase controlada R m {\displaystyle R_{m}} , aqui em termos de

H = 1 2 ( 1 1 1 1 ) and R m = ( 1 0 0 e 2 π i 2 m ) {\displaystyle H={\frac {1}{\sqrt {2}}}{\begin{pmatrix}1&1\\1&-1\end{pmatrix}}\qquad {\text{and}}\qquad R_{m}={\begin{pmatrix}1&0\\0&e^{\frac {2\pi i}{2^{m}}}\end{pmatrix}}}

com e 2 π i 2 m = ω m = ω ( 2 m ) {\displaystyle e^{\frac {2\pi i}{2^{m}}}=\omega _{m}'=\omega _{\left(2^{m}\right)}} o primitivo 2 m {\displaystyle 2^{m}} -ésima raiz da unidade. O circuito é composto por H {\displaystyle H} portões e a versão controlada de R m {\displaystyle R_{m}}

Circuito quântico para Quantum-Fourier-Transform com n qubits (sem reorganizar a ordem dos estados de saída). Ele usa a notação de fração binária apresentada a seguir.

Todas as operações quânticas devem ser lineares, portanto, basta descrever a função em cada um dos estados básicos e deixar que os estados mistos sejam definidos pela linearidade. Isso é diferente de como as transformadas de Fourier são geralmente descritas. Normalmente descrevemos as transformadas de Fourier em termos de como os componentes dos resultados são calculados em uma entrada arbitrária. É assim que você calcularia a integral do caminho ou mostraria que o BQP está em PP . Mas é muito mais simples aqui (e em muitos casos) apenas explicar o que acontece a um estado de base arbitrário específico, e o resultado total pode ser encontrado por linearidade.

A transformada quântica de Fourier pode ser aproximadamente implementada para qualquer N ; entretanto, a implementação para o caso em que N é uma potência de 2 é muito mais simples. Como já foi dito, assumimos N = 2 n {\displaystyle N=2^{n}} . Temos a base ortonormal que consiste nos vetores

| 0 , , | 2 n 1 . {\displaystyle |0\rangle ,\ldots ,|2^{n}-1\rangle .}

Os estados básicos enumeram todos os estados possíveis dos qubits:

| x = | x 1 x 2 x n = | x 1 | x 2 | x n {\displaystyle |x\rangle =|x_{1}x_{2}\ldots x_{n}\rangle =|x_{1}\rangle \otimes |x_{2}\rangle \otimes \cdots \otimes |x_{n}\rangle }

onde, com notação de produto tensorial {\displaystyle \otimes } , | x j {\displaystyle |x_{j}\rangle } indica que qubit j {\displaystyle j} está no estado x j {\displaystyle x_{j}} , com x j {\displaystyle x_{j}} 0 ou 1. Por convenção, o índice de estado básico x {\displaystyle x} ordena os possíveis estados dos qubits lexicograficamente, ou seja, convertendo de binário para decimal desta forma:

x = x 1 2 n 1 + x 2 2 n 2 + + x n 2 0 . {\displaystyle x=x_{1}2^{n-1}+x_{2}2^{n-2}+\cdots +x_{n}2^{0}.\quad }

Também é útil emprestar a notação binária fracionária:

[ 0. x 1 x m ] = k = 1 m x k 2 k . {\displaystyle [0.x_{1}\ldots x_{m}]=\sum _{k=1}^{m}x_{k}2^{-k}.}

Por exemplo, [ 0. x 1 ] = x 1 2 {\displaystyle [0.x_{1}]={\frac {x_{1}}{2}}} e [ 0. x 1 x 2 ] = x 1 2 + x 2 2 2 . {\displaystyle [0.x_{1}x_{2}]={\frac {x_{1}}{2}}+{\frac {x_{2}}{2^{2}}}.}

Com esta notação, a ação da transformada de Fourier quântica pode ser expressa de forma compacta:

QFT ( | x 1 x 2 x n ) = 1 N   ( | 0 + e 2 π i [ 0. x n ] | 1 ) ( | 0 + e 2 π i [ 0. x n 1 x n ] | 1 ) ( | 0 + e 2 π i [ 0. x 1 x 2 x n ] | 1 ) {\displaystyle {\text{QFT}}(|x_{1}x_{2}\ldots x_{n}\rangle )={\frac {1}{\sqrt {N}}}\ \left(|0\rangle +e^{2\pi i\,[0.x_{n}]}|1\rangle \right)\otimes \left(|0\rangle +e^{2\pi i\,[0.x_{n-1}x_{n}]}|1\rangle \right)\otimes \cdots \otimes \left(|0\rangle +e^{2\pi i\,[0.x_{1}x_{2}\ldots x_{n}]}|1\rangle \right)}
QFT ( | x 1 x 2 x n ) = 1 N   ( | 0 + ω 1 [ x n ] | 1 ) ( | 0 + ω 2 [ x n 1 x n ] | 1 ) ( | 0 + ω n [ x 1 . . . x n 1 x n ] | 1 ) . {\displaystyle {\text{QFT}}(|x_{1}x_{2}\ldots x_{n}\rangle )={\frac {1}{\sqrt {N}}}\ \left(|0\rangle +\omega _{1}'^{[x_{n}]}|1\rangle \right)\otimes \left(|0\rangle +\omega _{2}'^{[x_{n-1}x_{n}]}|1\rangle \right)\otimes \cdots \otimes \left(|0\rangle +\omega _{n}'^{[x_{1}...x_{n-1}x_{n}]}|1\rangle \right).}

onde usamos:

[ 0. x 1 x 2 . . . x m ] = [ x 1 x 2 . . . x n ] / 2 m {\displaystyle [0.x_{1}x_{2}...x_{m}]=[x_{1}x_{2}...x_{n}]/2^{m}} e ω m = ω ( 2 m ) = e 2 π i / 2 m . {\displaystyle \omega _{m}'=\omega _{\left({2^{m}}\right)}=e^{2\pi i/2^{m}}.}

Isso pode ser visto reescrevendo a fórmula para a transformada de Fourier na expansão binária:

QFT ( | x ) = 1 N k = 0 2 n 1 ω N x k | k = 1 N k 1 { 0 , 1 } k 2 { 0 , 1 } k n { 0 , 1 } ω N x j = 1 n k j 2 n j | k 1 k 2 k n {\displaystyle {\text{QFT}}(|x\rangle )={\frac {1}{\sqrt {N}}}\sum _{k=0}^{2^{n}-1}\omega _{N}^{xk}|k\rangle ={\frac {1}{\sqrt {N}}}\sum _{k_{1}\in \{0,1\}}\sum _{k_{2}\in \{0,1\}}\ldots \sum _{k_{n}\in \{0,1\}}\omega _{N}^{x\sum _{j=1}^{n}k_{j}2^{n-j}}|k_{1}k_{2}\ldots k_{n}\rangle }

= 1 N k 1 { 0 , 1 } k 2 { 0 , 1 } k n { 0 , 1 } j = 1 n ω N x k j 2 n j | k j = 1 N k 1 { 0 , 1 } k 2 { 0 , 1 } k n { 0 , 1 } ω N x k 1 2 n 1 | k 1 j = 2 n ω N x k j 2 n j | k j {\displaystyle ={\frac {1}{\sqrt {N}}}\sum _{k_{1}\in \{0,1\}}\sum _{k_{2}\in \{0,1\}}\ldots \sum _{k_{n}\in \{0,1\}}\bigotimes _{j=1}^{n}\omega _{N}^{xk_{j}2^{n-j}}|k_{j}\rangle ={\frac {1}{\sqrt {N}}}\sum _{k_{1}\in \{0,1\}}\sum _{k_{2}\in \{0,1\}}\ldots \sum _{k_{n}\in \{0,1\}}\omega _{N}^{xk_{1}2^{n-1}}|k_{1}\rangle \otimes \bigotimes _{j=2}^{n}\omega _{N}^{xk_{j}2^{n-j}}|k_{j}\rangle }

= 1 N ( k 1 { 0 , 1 } ω N x k 1 2 n 1 | k 1 ) k 2 { 0 , 1 } k n { 0 , 1 } ω N x k 2 2 n 2 | k 2 j = 3 n ω N x k j 2 n j | k j {\displaystyle ={\frac {1}{\sqrt {N}}}\left(\sum _{k_{1}\in \{0,1\}}\omega _{N}^{xk_{1}2^{n-1}}|k_{1}\rangle \right)\otimes \sum _{k_{2}\in \{0,1\}}\ldots \sum _{k_{n}\in \{0,1\}}\omega _{N}^{xk_{2}2^{n-2}}|k_{2}\rangle \otimes \bigotimes _{j=3}^{n}\omega _{N}^{xk_{j}2^{n-j}}|k_{j}\rangle }

= 1 N ( k 1 { 0 , 1 } ω N x k 1 2 n 1 | k 1 ) ( k 2 { 0 , 1 } ω N x k 2 2 n 2 | k 2 ) k 3 { 0 , 1 } k n { 0 , 1 } ω N x k 3 2 n 3 | k 3 j = 4 n ω N x k j 2 n j | k j = {\displaystyle ={\frac {1}{\sqrt {N}}}\left(\sum _{k_{1}\in \{0,1\}}\omega _{N}^{xk_{1}2^{n-1}}|k_{1}\rangle \right)\otimes \left(\sum _{k_{2}\in \{0,1\}}\omega _{N}^{xk_{2}2^{n-2}}|k_{2}\rangle \right)\otimes \sum _{k_{3}\in \{0,1\}}\ldots \sum _{k_{n}\in \{0,1\}}\omega _{N}^{xk_{3}2^{n-3}}|k_{3}\rangle \otimes \bigotimes _{j=4}^{n}\omega _{N}^{xk_{j}2^{n-j}}|k_{j}\rangle =\dots }

= 1 N j = 1 n k j { 0 , 1 } ω N x k j 2 n j | k j = 1 N j = 1 n ( | 0 + ω N x 2 n j | 1 ) . {\displaystyle ={\frac {1}{\sqrt {N}}}\bigotimes _{j=1}^{n}\sum _{k_{j}\in \{0,1\}}\omega _{N}^{xk_{j}2^{n-j}}|k_{j}\rangle ={\frac {1}{\sqrt {N}}}\bigotimes _{j=1}^{n}\left(|0\rangle +\omega _{N}^{x2^{n-j}}|1\rangle \right).}

Agora:

ω N x 2 n j = e 2 π i 2 n x 2 n j = e 2 π i ( x 2 j )                     ( 2 ) {\displaystyle \omega _{N}^{x2^{n-j}}=e^{{\frac {2\pi i}{2^{n}}}x2^{n-j}}=e^{{2\pi i}(x2^{-j})}\ \ \ \ \ \ \ \ \ \ (2)} .

Deixei f ( j ) = x 2 j = 2 j r = 1 n x r 2 n r = r = 1 n x r 2 n j r = r = 1 n j x r 2 n j r + r = n j + 1 n x r 2 n j r = a ( j ) + b ( j ) ; {\displaystyle f(j)=x2^{-j}=2^{-j}\sum _{r=1}^{n}x_{r}2^{n-r}=\sum _{r=1}^{n}x_{r}2^{n-j-r}=\sum _{r=1}^{n-j}x_{r}2^{n-j-r}+\sum _{r=n-j+1}^{n}x_{r}2^{n-j-r}=a(j)+b(j);}

então a ( j )   ϵ   N 0 {\displaystyle a(j)\ \epsilon \ \mathbb {N} _{0}} , Porque 2 n j r 0 {\displaystyle 2^{n-j-r}\geq 0} , para   n j r 0 {\displaystyle \ n-j-r\geq 0} , e b ( j ) = 0. x n j + 1 x n j + 2 x n {\displaystyle b(j)=0.x_{n-j+1}x_{n-j+2}\dots x_{n}} , Então, o ( 2 ) {\displaystyle (2)} torna-se:

e 2 π i f ( j ) = e 2 π i ( a ( j ) + b ( j ) ) = e 2 π i a ( j ) e 2 π i b ( j ) = e 2 π i [ 0. x n j + 1 x n j + 2 x n ] , {\displaystyle e^{{2\pi i}f(j)}=e^{{2\pi i}(a(j)+b(j))}=e^{{2\pi i}a(j)}\cdot e^{{2\pi i}b(j)}=e^{{2\pi i}[0.x_{n-j+1}x_{n-j+2}\cdots x_{n}]},}

Desde a e 2 π i a ( j ) = ( e 2 π i ) a ( j ) = 1 {\displaystyle e^{{2\pi i}a(j)}=(e^{2\pi i})^{a(j)}=1} para todos j {\displaystyle j} .

Então podemos escrever:

QFT ( | x 1 x 2 x n ) = 1 N j = 1 n ( | 0 + ω N x 2 n j | 1 ) = 1 N j = 1 n ( | 0 + e 2 π i [ 0. x n j + 1 x n j + 2 x n ] | 1 ) {\displaystyle {\text{QFT}}(|x_{1}x_{2}\dots x_{n}\rangle )={\frac {1}{\sqrt {N}}}\bigotimes _{j=1}^{n}\left(|0\rangle +\omega _{N}^{x2^{n-j}}|1\rangle \right)={\frac {1}{\sqrt {N}}}\bigotimes _{j=1}^{n}\left(|0\rangle +e^{2\pi i[0.x_{n-j+1}x_{n-j+2}\ldots x_{n}]}|1\rangle \right)}

= 1 N ( | 0 + e 2 π i [ 0. x n ] | 1 ) ( | 0 + e 2 π i [ 0. x n 1 x n ] | 1 ) ( | 0 + e 2 π i [ 0. x 1 x 2 x n ] | 1 ) . {\displaystyle ={\frac {1}{\sqrt {N}}}\left(|0\rangle +e^{2\pi i[0.x_{n}]}|1\rangle \right)\otimes \left(|0\rangle +e^{2\pi i[0.x_{n-1}x_{n}]}|1\rangle \right)\otimes \dots \otimes \left(|0\rangle +e^{2\pi i[0.x_{1}x_{2}\ldots x_{n}]}|1\rangle \right).}

Para obter esse estado do circuito descrito acima, uma operação de troca dos qubits deve ser realizada para inverter sua ordem. No máximo n / 2 {\displaystyle n/2} são necessárias trocas, cada uma sendo realizada usando três portas NOT (C-NOT) controladas.[2]

Após a reversão, o n- ésimo qubit de saída estará em um estado de superposição de | 0 {\displaystyle |0\rangle } e e 2 π i [ 0. x 1 . . . x n ] | 1 {\displaystyle e^{2\pi i\,[0.x_{1}...x_{n}]}|1\rangle } , e da mesma forma os outros qubits antes disso (dê uma segunda olhada no esboço do circuito acima).

Em outras palavras, a transformada discreta de Fourier, uma operação em n qubits, pode ser fatorada no produto tensorial de n operações de um único qubit, sugerindo que ela é facilmente representada como um circuito quântico (até uma inversão de ordem da saída). Na verdade, cada uma dessas operações de qubit único pode ser implementada de forma eficiente usando uma porta Hadamard e portas de fase controladas . O primeiro termo requer um portão Hadamard e ( n 1 ) {\displaystyle (n-1)} portas de fase controlada, a próxima requer uma porta Hadamard e ( n 2 ) {\displaystyle (n-2)} porta de fase controlada, e cada termo seguinte requer uma porta de fase controlada a menos. Somando o número de portas, excluindo as necessárias para a reversão da saída, dá n + ( n 1 ) + + 1 = n ( n + 1 ) / 2 = O ( n 2 ) {\displaystyle n+(n-1)+\cdots +1=n(n+1)/2=O(n^{2})} gates, que é polinomial quadrático no número de qubits.

Exemplo

Considere a transformada de Fourier quântica em 3 qubits. É a seguinte transformação:

QFT : | x 1 2 3 k = 0 2 3 1 ω 3 x k | k , {\displaystyle {\text{QFT}}:|x\rangle \mapsto {\frac {1}{\sqrt {2^{3}}}}\sum _{k=0}^{2^{3}-1}\omega _{3}'^{xk}|k\rangle ,}

Onde ω 3 = ω ( 2 3 ) {\displaystyle \omega _{3}'=\omega _{\left(2^{3}\right)}} é uma oitava raiz primitiva de unidade que satisfaz ω 3 8 = ( e 2 π i 2 3 ) 8 = 1 {\displaystyle \omega _{3}'^{8}=\left(e^{\frac {2\pi i}{2^{3}}}\right)^{8}=1} (Desde a N = 2 3 = 8 {\displaystyle N=2^{3}=8} )

Resumindo, configuração ω = ω 3 = ω 8 {\displaystyle \omega =\omega _{3}'=\omega _{8}} , a representação matricial desta transformação em 3 qubits é:

F 2 3 = 1 2 3 [ 1 1 1 1 1 1 1 1 1 ω ω 2 ω 3 ω 4 ω 5 ω 6 ω 7 1 ω 2 ω 4 ω 6 ω 8 ω 10 ω 12 ω 14 1 ω 3 ω 6 ω 9 ω 12 ω 15 ω 18 ω 21 1 ω 4 ω 8 ω 12 ω 16 ω 20 ω 24 ω 28 1 ω 5 ω 10 ω 15 ω 20 ω 25 ω 30 ω 35 1 ω 6 ω 12 ω 18 ω 24 ω 30 ω 36 ω 42 1 ω 7 ω 14 ω 21 ω 28 ω 35 ω 42 ω 49 ] = 1 2 3 [ 1 1 1 1 1 1 1 1 1 ω ω 2 ω 3 ω 4 ω 5 ω 6 ω 7 1 ω 2 ω 4 ω 6 1 ω 2 ω 4 ω 6 1 ω 3 ω 6 ω ω 4 ω 7 ω 2 ω 5 1 ω 4 1 ω 4 1 ω 4 1 ω 4 1 ω 5 ω 2 ω 7 ω 4 ω ω 6 ω 3 1 ω 6 ω 4 ω 2 1 ω 6 ω 4 ω 2 1 ω 7 ω 6 ω 5 ω 4 ω 3 ω 2 ω ] . {\displaystyle F_{2^{3}}={\frac {1}{\sqrt {2^{3}}}}{\begin{bmatrix}1&1&1&1&1&1&1&1\\1&\omega &\omega ^{2}&\omega ^{3}&\omega ^{4}&\omega ^{5}&\omega ^{6}&\omega ^{7}\\1&\omega ^{2}&\omega ^{4}&\omega ^{6}&\omega ^{8}&\omega ^{10}&\omega ^{12}&\omega ^{14}\\1&\omega ^{3}&\omega ^{6}&\omega ^{9}&\omega ^{12}&\omega ^{15}&\omega ^{18}&\omega ^{21}\\1&\omega ^{4}&\omega ^{8}&\omega ^{12}&\omega ^{16}&\omega ^{20}&\omega ^{24}&\omega ^{28}\\1&\omega ^{5}&\omega ^{10}&\omega ^{15}&\omega ^{20}&\omega ^{25}&\omega ^{30}&\omega ^{35}\\1&\omega ^{6}&\omega ^{12}&\omega ^{18}&\omega ^{24}&\omega ^{30}&\omega ^{36}&\omega ^{42}\\1&\omega ^{7}&\omega ^{14}&\omega ^{21}&\omega ^{28}&\omega ^{35}&\omega ^{42}&\omega ^{49}\\\end{bmatrix}}={\frac {1}{\sqrt {2^{3}}}}{\begin{bmatrix}1&1&1&1&1&1&1&1\\1&\omega &\omega ^{2}&\omega ^{3}&\omega ^{4}&\omega ^{5}&\omega ^{6}&\omega ^{7}\\1&\omega ^{2}&\omega ^{4}&\omega ^{6}&1&\omega ^{2}&\omega ^{4}&\omega ^{6}\\1&\omega ^{3}&\omega ^{6}&\omega &\omega ^{4}&\omega ^{7}&\omega ^{2}&\omega ^{5}\\1&\omega ^{4}&1&\omega ^{4}&1&\omega ^{4}&1&\omega ^{4}\\1&\omega ^{5}&\omega ^{2}&\omega ^{7}&\omega ^{4}&\omega &\omega ^{6}&\omega ^{3}\\1&\omega ^{6}&\omega ^{4}&\omega ^{2}&1&\omega ^{6}&\omega ^{4}&\omega ^{2}\\1&\omega ^{7}&\omega ^{6}&\omega ^{5}&\omega ^{4}&\omega ^{3}&\omega ^{2}&\omega \\\end{bmatrix}}.}

Isso poderia ser simplificado ainda mais usando ω 4 = 1 {\displaystyle \omega ^{4}=-1} , ω 2 = i {\displaystyle \omega ^{2}=i} e ω 6 = i {\displaystyle \omega ^{6}=-i}

e então ainda mais dado que ω 5 = ω {\displaystyle \omega ^{5}=-\omega } , ω 3 = i ω {\displaystyle \omega ^{3}=i\omega } e ω 7 = i ω {\displaystyle \omega ^{7}=-i\omega } .

A transformada de Fourier quântica de 3 qubit pode ser reescrita como:

QFT ( | x 1 , x 2 , x 3 ) = 1 2 3   ( | 0 + e 2 π i [ 0. x 3 ] | 1 ) ( | 0 + e 2 π i [ 0. x 2 x 3 ] | 1 ) ( | 0 + e 2 π i [ 0. x 1 x 2 x 3 ] | 1 ) {\displaystyle {\text{QFT}}(|x_{1},x_{2},x_{3}\rangle )={\frac {1}{\sqrt {2^{3}}}}\ \left(|0\rangle +e^{2\pi i\,[0.x_{3}]}|1\rangle \right)\otimes \left(|0\rangle +e^{2\pi i\,[0.x_{2}x_{3}]}|1\rangle \right)\otimes \left(|0\rangle +e^{2\pi i\,[0.x_{1}x_{2}x_{3}]}|1\rangle \right)}
QFT ( | x 1 , x 2 , x 3 ) = 1 2 3   ( | 0 + ω 1 [ x 3 ] | 1 ) ( | 0 + ω 2 [ x 2 x 3 ] | 1 ) ( | 0 + ω 3 [ x 1 x 2 x 3 ] | 1 ) . {\displaystyle {\text{QFT}}(|x_{1},x_{2},x_{3}\rangle )={\frac {1}{\sqrt {2^{3}}}}\ \left(|0\rangle +\omega _{1}'^{[x_{3}]}|1\rangle \right)\otimes \left(|0\rangle +\omega _{2}'^{[x_{2}x_{3}]}|1\rangle \right)\otimes \left(|0\rangle +\omega _{3}'^{[x_{1}x_{2}x_{3}]}|1\rangle \right).}

No caso de utilizarmos o circuito obtemos a fatoração em ordem inversa, nomeadamente

| x 1 , x 2 , x 3 1 2 3   ( | 0 + ω 3 [ x 1 x 2 x 3 ] | 1 ) ( | 0 + ω 2 [ x 2 x 3 ] | 1 ) ( | 0 + ω 1 [ x 3 ] | 1 ) . {\displaystyle |x_{1},x_{2},x_{3}\rangle \longmapsto {\frac {1}{\sqrt {2^{3}}}}\ \left(|0\rangle +\omega _{3}'^{[x_{1}x_{2}x_{3}]}|1\rangle \right)\otimes \left(|0\rangle +\omega _{2}'^{[x_{2}x_{3}]}|1\rangle \right)\otimes \left(|0\rangle +\omega _{1}'^{[x_{3}]}|1\rangle \right).}

Aqui usamos notações como:

[ 0. x 1 x 2 x 3 ] = [ x 1 x 2 x 3 ] / 2 3 {\displaystyle [0.x_{1}x_{2}x_{3}]=[x_{1}x_{2}x_{3}]/2^{3}} e ω m = ω ( 2 m ) = e 2 π i / 2 m . {\displaystyle \omega _{m}'=\omega _{\left(2^{m}\right)}=e^{2\pi i/2^{m}}.}

No esboço a seguir, temos o respectivo circuito para n = 3 {\displaystyle n=3} (com ordem errada de qubits de saída em relação ao QFT adequado):

QFT para 3 Qubits (sem reorganizar a ordem dos qubits de saída)

Conforme calculado acima, o número de portas usadas é n ( n + 1 ) / 2 {\displaystyle n(n+1)/2} que é igual a 6 {\displaystyle 6} , para n = 3 {\displaystyle n=3} .

Referências

  1. Coppersmith, D. (1994). «An approximate Fourier transform useful in quantum factoring.». Technical Report RC19642, IBM 
  2. a b Michael Nielsen and Isaac Chuang (2000). Quantum Computation and Quantum Information. Cambridge University Press. Cambridge: [s.n.] ISBN 0-521-63503-9. OCLC 174527496 
  3. Hales, L.; Hallgren, S. (12–14 de novembro de 2000). «An improved quantum Fourier transform algorithm and applications». Proceedings 41st Annual Symposium on Foundations of Computer Science: 515–525. CiteSeerX 10.1.1.29.4161Acessível livremente. ISBN 0-7695-0850-2. doi:10.1109/SFCS.2000.892139 
  • KR Parthasarathy, Lectures on Quantum Computation and Quantum Error Correcting Codes (Indian Statistical Institute, Delhi Centre, junho de 2001)
  • John Preskill, Lecture Notes for Physics 229: Quantum Information and Computation (CIT, setembro de 1998)

Ligações externas

  • Wolfram Demonstration Project: Quantum Circuit Implementing Grover's Search Algorithm
  • Projeto de demonstração da Wolfram: Circuito Quântico que implementa a transformada Quantum Fourier
  • Transformação quirk de Fourier quântica de vida online