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 amplitudes podem ser implementadas como um circuito quântico consistindo apenas em Portões Hadamard e portões de mudança de fase controlada, onde é o número de qubits.[2] Isso pode ser comparado com a transformada discreta de Fourier clássica, que leva portões (onde é o número de bits), que é exponencialmente maior que . 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 portas para conseguir uma aproximação eficiente.[3]
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 .
A transformada de Fourier clássica atua em um vetor e mapeia para o vetor de acordo com a fórmula:
Onde e é um N th raiz da unidade .
Da mesma forma, a transformada quântica de Fourier atua em um estado quântico e mapeia para um estado quântico de acordo com a fórmula:
(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 é uma rotação, a transformada quântica inversa de Fourier age de forma semelhante, mas com:
Em caso de é um estado básico, a transformada quântica de Fourier também pode ser expressa como o mapa
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 É dado por
Onde . Obtemos, por exemplo, no caso de e fase a matriz de transformação
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 detém onde é o anexo hermitiano de . 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 . 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.
As portas quânticas usadas no circuito são a porta de Hadamard e a porta de fase controlada , aqui em termos de
com o primitivo -ésima raiz da unidade. O circuito é composto por portões e a versão controlada de
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 . Temos a base ortonormal que consiste nos vetores
Os estados básicos enumeram todos os estados possíveis dos qubits:
onde, com notação de produto tensorial , indica que qubit está no estado , com 0 ou 1. Por convenção, o índice de estado básico ordena os possíveis estados dos qubits lexicograficamente, ou seja, convertendo de binário para decimal desta forma:
Também é útil emprestar a notação binária fracionária:
Por exemplo, e
Com esta notação, a ação da transformada de Fourier quântica pode ser expressa de forma compacta:
onde usamos:
- e
Isso pode ser visto reescrevendo a fórmula para a transformada de Fourier na expansão binária:
Agora:
- .
Deixei
então , Porque , para , e , Então, o torna-se:
Desde a para todos .
Então podemos escrever:
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 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 e , 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 portas de fase controlada, a próxima requer uma porta Hadamard e 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á gates, que é polinomial quadrático no número de qubits.
Considere a transformada de Fourier quântica em 3 qubits. É a seguinte transformação:
Onde é uma oitava raiz primitiva de unidade que satisfaz (Desde a )
Resumindo, configuração , a representação matricial desta transformação em 3 qubits é:
Isso poderia ser simplificado ainda mais usando , e
e então ainda mais dado que , e .
A transformada de Fourier quântica de 3 qubit pode ser reescrita como:
No caso de utilizarmos o circuito obtemos a fatoração em ordem inversa, nomeadamente
Aqui usamos notações como:
- e
No esboço a seguir, temos o respectivo circuito para (com ordem errada de qubits de saída em relação ao QFT adequado):
Conforme calculado acima, o número de portas usadas é que é igual a , para .
- 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)