Реализация квантовых вычислений в программе Excel | Статья в журнале «Молодой ученый»

Отправьте статью сегодня! Журнал выйдет 28 декабря, печатный экземпляр отправим 1 января.

Опубликовать статью в журнале

Автор:

Рубрика: Информационные технологии

Опубликовано в Молодой учёный №22 (102) ноябрь-2 2015 г.

Дата публикации: 15.11.2015

Статья просмотрена: 1320 раз

Библиографическое описание:

Актимиров, А. В. Реализация квантовых вычислений в программе Excel / А. В. Актимиров. — Текст : непосредственный // Молодой ученый. — 2015. — № 22 (102). — С. 16-22. — URL: https://moluch.ru/archive/102/23292/ (дата обращения: 16.12.2024).

 

В статье кратко изложены основы теории квантовых вычислений. Рассматриваются свойства кубитов, правила преобразования над ними, различные типы квантовых гейтов. Описан пример реализации квантового алгоритма Гровера в программе EXCEL. Показано преимущество квантового алгоритма Гровера над классическими алгоритмами.

Ключевые слова: квантовый компьютер, квантовый гейт, кубит, алгоритм Гровера.

 

Квантовая информатика на протяжении более двух десятков лет является одной из самых развивающих наук, поэтому создания квантового компьютера считается одним из наиболее актуальных идей в веке высоких технологий. Объясняется такой интерес двумя причинами: во-первых, квантовые вычисления предоставляют новые возможности для кодирования, обработки и передачи информации (увеличение быстродействия вычислений и возможность решать ряд вычислительных задач, недоступных классическому компьютер); во-вторых — это миниатюризация элементов интегральных схем классических компьютеров. Успехи современной компьютерной индустрии основаны на увеличении количества и уменьшении размера элементов микросхем [1, с.5]. Согласно закону Мура число транзисторов на один квадратный дюйм в микросхемах классических компьютеров увеличивается со временем по экспоненциальному закону, а именно удваивается каждые 18–24 месяца [2, с.7]. Одновременно с этим, число атомов, необходимых для предоставления одного бита информации, экспоненциально уменьшается со временем. Поэтому рано или поздно транзисторы будут столь малы, что каждый из них будет состоять из нескольких десятков атомов. В таком случае пренебрежение квантово-механическими эффектами в таких структурах станет недопустимым, а классическая логика, на которой построены современные компьютеры, перестанут функционировать. На этом этапе квантовая информатика должна открыть другой способ увеличения быстродействия компьютеров, основанный на использовании квантовых эффектов. По словам Р. Фейнмана такие квантовые компьютеры окажутся экспоненциально более быстрыми при моделировании квантово-механических систем, чем их классические аналоги. Совсем недавно было разработано несколько алгоритмов, осуществление которых на квантовом компьютере превращает проблемы экспоненциальной сложности в проблемы полиномиальной сложности [3, с.12]. Среди таких алгоритмов, в первую очередь, следует отметить алгоритм П. Шора, позволяющий факторизовать большие числа за полиномиальное время, и алгоритм Л. Гровера для поиска в неупорядоченной базе данных, показывающий квадратичный прирост быстродействия [5, с.18].

У квантового компьютера есть несколько принципиальных отличий от классического, но с практической точки зрения основными являются две: экспоненциальный рост объема памяти с ростом количества ячеек и способность за один такт работы обрабатывать всю имеющуюся в его распоряжении память. Иными словами, добавляя всего одну ячейку памяти, мы увеличиваем быстродействие квантового компьютера в два раза. Наибольшая надежда возлагается на квантовый параллелизм — возможность квантового регистра находиться одновременно во всех своих состояниях [4, с.35]. В основе квантового параллелизма лежит использование при вычислениях суперпозиций базисных состояний, что позволяет одновременно производить большое количество вычислений с различными исходными данными. Элементарным шагом при квантовых вычислениях является отдельная унитарная операция над N-кубитовой суперпозицией в квантовых компьютерах, тогда как для классического компьютера такая операция потребовала бы элементарных шагов. Например, 64-разрядный квантовый регистр может хранить дозначений одновременно, а квантовый компьютер может все эти значения одновременно обрабатывать.

Основным понятием в информатике является бит. При измерении информация может принимать два значения 0 и 1. В классической ситуации под битом можно подразумевать переключатель с двумя четко различными состояниями. Квантовым аналогом бита выступает кубит (Q-бит, Quantum бит, квантовый бит), который представляет из себя квантово-механическую систему, обладающую двумя базисным состояниями: . В дираковской системе обозначений векторных величин используется разбиение английского слова bracket (скобка) на два слога: bra («бра») вектор — строки и ket («кет») вектор –столбцы. Запись кет — вектора выглядит как , а бра — вектор записывается как В обозначении внутреннего (скалярного) произведения два вектора оказываются заключенными в своеобразные скобки, например, . В общем случае, состояние такой системы задается волновой функцией вида:

|+ |(1.1)

где α и  — комплексные коэффициенты. При измерении состояния системы с волновой функцией, вероятность обнаружить ее в состоянии | равна , а вероятность обнаружить ее в состоянии | равна . Сумма этих вероятностей равна единице:

= 1 (1.2)

Выражение (1.1), записано в традиционной форме, характерной для квантовой механики «состояний».

В матричной форме бра-векторы принято обозначать следующим образом:

(1 0), (0 1), (1.3)

В матричной форме кет-векторы принято обозначать следующим образом:

|, |, (1.4)

Рассмотрим пример.

Имеется кубит в квантовом состоянии | + | В этом случае, вероятность получить при измерении 0 составляет = 49/81 = 60 %, вероятность получить при измерении 1 составляет = 36/81 = 40 %. В данном случае, при измерении мы получим 0 с 60 % вероятностью. Как известно, в результате измерения кубит переходит в базисное состояние |.

Пусть регистр состоит из двух кубитов. Измерение каждого из них может дать 0 или 1. Поэтому у системы есть 4 базисных состояния: |, |, | |

Тогда квантовое состояние системы из двух кубитов имеет вид:

| = a|||d |(1.5)

При измерении системы (1.5) вероятность обнаружить ее в состоянии | равна , | равна | равна , | равна . Отметим, что + + + = 1 как полная вероятность [5,с.63].

В матричном виде базисные состояния системы могут быть получены путем тензорного умножения однокубитных кэт-векторов:

|; (1.6)

Сним1

где знак тензорного умножения.

С квантовыми системами можно производить только линейные унитарные преобразования, что эквивалентно поворотам вектора длиной 1 в трехмерном пространстве.

Рассмотрим основные элементарные преобразования. Их можно выполнить при помощи так называемых квантовых вентилей (квантовых гейтов) — умножением матричной формы кет-вектора на матричную форму вентиля [6, с.42].

Таблица 1

Квантовые вентили

Название, обозначение и краткое описание квантового вентиля

Действие на базисные состояния

Матричная форма вентиля

Однокубитовые:

Тождественное преобразование (I)

|

|

Отрицание (X или NOT)

|

|

Фазовый сдвиг (Z)

|

|

Фазовый сдвиг с отрицанием (Y)

|

|

Преобразование Уолша-Адамара (H)

|

|

 

Двухкубитовые:

Управляемое отрицание

(ControlledNOT или СNOT)

|

|

|

|

Трехкубитовые:

ВентильТоффоли (ССNOT)

|

|

|

|

|

|

|

|

 

Важнейшим двухкубитовым оператором является CNOT, или управляемый NOT.

В базисе |, |, | |матрица оператора CNOT имеет вид:

(1.7)

Распишем действие этой матрицы на базисные векторы:

, , (1.8)

, ,

Если первый кубит находится в состоянии , а второй кубит находится в одном из базисных состояний или , то под действием оператора CNOT состояние такой двухкубитовой системы не изменится. Если же первый кубит находится в состоянии , а второй — в одном из базисных состояний, то оператор CNOT переводит второй кубит в другое базисное состояние. Состояние же первого кубита не изменится:

(1.9)

.

Оператор CNOT изображается в виде квантовой схемы:

C:\Users\интелект98\Desktop\Снимок.JPG

Рис. 1. Квантовая схема, изображающая оператор CNOT

 

Условно по двум проводам, слева направо, к схеме подводятся два кубита x и y. По двум правым проводам, от схемы отводятся два кубита — результат действия схемы [7, с.50]: неизменённый управляющий х, управляемый же у преобразуется в х у, где  — знак сложения по модулю 2:

(2.0)

Ниже в программе EXCEL представлены примеры действия оператора СNOT на некоторые векторы. Так, в примере 1 на входе имеем | = 0.4 ||| 0.2 |:

C:\Users\интелект 98\Desktop\Без имени-011.jpg

В результате получим вектор | = 0.4 ||| 0.8 |

Квантовый алгоритм Гровера

Пусть имеется база данных, состоящей из записей. Одна из записей удовлетворяет некоторому заданному условию. Задача состоит в том, чтобы найти эту запись. Предполагается, что база данных представляет собой неупорядоченную, неструктурированную совокупность записей.

В классическом случае поиск требуемой записи осуществляется методом полного перебора, по которому требуется проверить в среднем записей. В общем случае необходимо проверить О запись, где О (…) обозначает термин «не более чем».

Например, рассмотрим неупорядоченную базу данных, содержащую 1024 записей. Мы хотим найти ровно одну запись. Для того чтобы решить эту задачу на обычном компьютере, в худшем случае, нам придется перебрать все 1024записей, а в среднем 512 — это очевидно. На квантовом компьютере необходимо и достаточно произвести 25 итераций, чтобы найти данную запись. Для 16 384 записей в классическом среднем случае придется перебрать 8 192 записи. На квантовом компьютере необходимо и достаточно произвести 100 итераций.

В общем случае алгоритм Гровера (рис.2) позволяет выполнить поиск требуемой записи за шагов.

Задачу поиска в неупорядоченной базе данных можно сформулировать следующим образом.

Задана неупорядоченная совокупность элементов , где .Аргумент х принимает значения . Элемент удовлетворяет заданному условию, то есть существует функция,

Требуется найти «маркированный» элемент .

C:\Users\интелект98\Desktop\сма.JPG

Рис. 2.Квантовый двухкубитный алгоритм Гровера.

 

Рассмотрим пример. Пусть база данных содержит 4 записи. В худшем случае, нам придется перебрать все 4записи, а в среднем 2. На квантовом компьютере достаточно произвести 1 итерацию, чтобы найти данную запись.

Алгоритм включает в себя следующие шаги.

  1.                Приготовление начального состояния квантового регистра, состоящего из кубитов. Каждый кубит устанавливается в состояние |. Состояние регистра запишем вектор в виде:

(2.2)

C:\Users\интелект98\Desktop\Снимок.JPG

  1.                Приготовление равновероятной (с равными амплитудами) суперпозиции состояний кубитов с помощью преобразования Уолша — Адамара:

 

(2.3)

C:\Users\интелект 98\Desktop\Без имени-222.jpg

  1.                Поворот амплитуды «маркированного» состояния . Для этого необходимо выполнить преобразование:

C:\Users\интелект 98\Desktop\Без имени-231.jpg

  1.                Преобразование Адамара:

C:\Users\интелект 98\Desktop\Без имени-142.jpg

  1.                Вычисление инверсии относительно среднего:

C:\Users\интелект 98\Desktop\Без имени-421.jpg

  1.                Преобразование Адамара (возвращает в начальное состояние ):

C:\Users\интелект 98\Desktop\Без имени-541.jpg

 

Таким образом, выполнив одну итерацию мы нашли функцию, которая принимает значение 1 только на одном из 4-х вариантов входных значений. Следовательно, процедура поиска заметно ускорилась теоретически на по сравнению с расчетами на классическом компьютере.

Очевидно, что классические компьютеры и алгоритмы в ближайшее время достигнут максимальной производительности. Поэтому необходимо разрабатывать новые алгоритмы и программы для квантовых компьютеров уже сегодня.

 

Литература:

 

  1. Валиев К. А. Квантовые компьютеры: надежды и реальность // К. А. Валиев, А. А. Кокин — Ижевск; РХД, 2001. — 352 с.
  2. Quantum algorithms revisited / R. Clever, A. Ekert, C. Mosca // Proc.Roy. Soc. Lond. A. — 1998. — Vol. 454. Pp. 339–354.
  3. Galindo A. Information and computation: classical and quantum aspect / A.. Galindo, M. A. Martin — Delgado // Reviews of Modern Physics. — 2002. — Vol. 74, no. 2. — Pp. 347–423.
  4. Международный научный журнал: «Квантовые компьютеры и квантовые вычисления», № 1,2000.
  5. Чивилихин С. А. Учебное пособие «Квантовая информатика». 2009.
  6. Cадовничий В. А. Квантовые компьютеры и квантовые вычисления. № 2
  7. Хренников А. Ю. Введение в квантовую теорию информации. 2008.
Основные термины (генерируются автоматически): CNOT, квантовый компьютер, кубит, EXCEL, NOT, алгоритм, запись, базисное состояние, квантовый алгоритм, общий случай.


Ключевые слова

кубит, квантовый компьютер, квантовый гейт, алгоритм Гровера., алгоритм Гровера

Похожие статьи

Программная реализация алгоритма Левенштейна для устранения опечаток в записях баз данных

В статье описан пример реализации алгоритма Левенштейна на языке PL/SQL для устранения опечаток в записях баз данных.

Имитационное моделирование квантового алгоритма решения систем линейных уравнений в прикладной программе MATLAB

Целью статьи является ознакомление с квантовым алгоритмом решения систем линейных алгебраических уравнений (СЛАУ) и программой для его моделирования на ЭВМ с помощью программы MATLAB. В работе представлен код программы модели и результат её работы.

Алгоритмы расщепления для задачи о пропозициональной выполнимости

В статье исследуется задача о пропозициональной выполнимости и известные алгоритмы ее решения. Приведено обоснование её значимости как широко применимой задачи, для которой впервые было сформулировано и доказано свойство NP-полноты. Автором разработа...

Модификация алгоритма Смита — Уотермана для задачи автоматического распознавания слитной речи

В данной работе рассмотрен классический и модифицированный алгоритм Смита-Уотермана. Выполнено их сравнение в задаче улучшения результата автоматического распознавания слитной речи. Выделены преимущества и недостатки модифицированного алгоритма. Опис...

Методы решения нелинейных уравнений

Статья посвящена изучению методов решения нелинейных уравнений, в том числе, с использованием системы автоматизированного проектирования MathCAD. Рассмотрены шаговый метод, методы половинного деления и Ньютона, приведены подробные алгоритмы применени...

Методы и алгоритмы эффективного решения задачи маршрутизации транспорта на сетях больших размерностей

В данной работе подробно рассмотрена задача маршрутизации транспорта с временными окнами и ограниченной грузоподъёмностью. В ходе работы рассматриваются различные эвристические и мета-эвристические алгоритмы, применённые к данному типу задач. Более п...

Обзор аппаратных генераторов случайных чисел

Данная статья посвящена исследованию основных способов построения аппаратных генераторов случайных чисел. Рассмотрены их схемы и отличительные способности. В заключении статьи приведен краткий вывод.

Исследование некоторых квадратурных формул Ньютона — Котеса в среде Maplesoft Maple 2022

Численные методы являются мощным инструментом вычислительной математики, использование которого позволяет решать многие математические, физические, экономические, технические и другие задачи. В данной статье излагается решение задачи численного интег...

Разработка алгоритма нечеткого поиска на основе хэширования

Цель данной работы заключается в разработке оптимального алгоритма нечеткого поиска по словарю для базы данных. В ходе выполнения работы был реализован алгоритм поиска на основе хэширования. Основная метрика, которая применялась для сравнения строк ...

Цифровая обработка дважды стохастических моделей случайных полей

В настоящей статье представлен краткий обзор алгоритмов цифровой обработки дважды стохастических моделей. Основное внимание уделяется алгоритмам фильтрации и оценивания параметров. Также рассмотрены некоторые алгоритмы имитации таких случайных полей.

Похожие статьи

Программная реализация алгоритма Левенштейна для устранения опечаток в записях баз данных

В статье описан пример реализации алгоритма Левенштейна на языке PL/SQL для устранения опечаток в записях баз данных.

Имитационное моделирование квантового алгоритма решения систем линейных уравнений в прикладной программе MATLAB

Целью статьи является ознакомление с квантовым алгоритмом решения систем линейных алгебраических уравнений (СЛАУ) и программой для его моделирования на ЭВМ с помощью программы MATLAB. В работе представлен код программы модели и результат её работы.

Алгоритмы расщепления для задачи о пропозициональной выполнимости

В статье исследуется задача о пропозициональной выполнимости и известные алгоритмы ее решения. Приведено обоснование её значимости как широко применимой задачи, для которой впервые было сформулировано и доказано свойство NP-полноты. Автором разработа...

Модификация алгоритма Смита — Уотермана для задачи автоматического распознавания слитной речи

В данной работе рассмотрен классический и модифицированный алгоритм Смита-Уотермана. Выполнено их сравнение в задаче улучшения результата автоматического распознавания слитной речи. Выделены преимущества и недостатки модифицированного алгоритма. Опис...

Методы решения нелинейных уравнений

Статья посвящена изучению методов решения нелинейных уравнений, в том числе, с использованием системы автоматизированного проектирования MathCAD. Рассмотрены шаговый метод, методы половинного деления и Ньютона, приведены подробные алгоритмы применени...

Методы и алгоритмы эффективного решения задачи маршрутизации транспорта на сетях больших размерностей

В данной работе подробно рассмотрена задача маршрутизации транспорта с временными окнами и ограниченной грузоподъёмностью. В ходе работы рассматриваются различные эвристические и мета-эвристические алгоритмы, применённые к данному типу задач. Более п...

Обзор аппаратных генераторов случайных чисел

Данная статья посвящена исследованию основных способов построения аппаратных генераторов случайных чисел. Рассмотрены их схемы и отличительные способности. В заключении статьи приведен краткий вывод.

Исследование некоторых квадратурных формул Ньютона — Котеса в среде Maplesoft Maple 2022

Численные методы являются мощным инструментом вычислительной математики, использование которого позволяет решать многие математические, физические, экономические, технические и другие задачи. В данной статье излагается решение задачи численного интег...

Разработка алгоритма нечеткого поиска на основе хэширования

Цель данной работы заключается в разработке оптимального алгоритма нечеткого поиска по словарю для базы данных. В ходе выполнения работы был реализован алгоритм поиска на основе хэширования. Основная метрика, которая применялась для сравнения строк ...

Цифровая обработка дважды стохастических моделей случайных полей

В настоящей статье представлен краткий обзор алгоритмов цифровой обработки дважды стохастических моделей. Основное внимание уделяется алгоритмам фильтрации и оценивания параметров. Также рассмотрены некоторые алгоритмы имитации таких случайных полей.

Задать вопрос