Алгоритм Фрейвальдса (названный в честь Русиньш Мартиньш Фрейвальдс) является вероятностным рандомизированный алгоритм используется для проверки матричное умножение. Учитывая три п × п матрицы , , и , общая проблема состоит в том, чтобы проверить, . Наивный алгоритм вычислил бы продукт явно и сравните по срокам, равен ли этот продукт . Однако самый известный алгоритм умножения матриц работает в время.[1] Алгоритм Фрейвальдса использует рандомизация чтобы сократить это время, привязанное к [2]с большой вероятностью. В время, когда алгоритм может проверить матричное произведение с вероятностью отказа меньше, чем .
Алгоритм
Вход
Три п × п матрицы , , и .
Выход
Да, если ; В противном случае нет.
Процедура
- Создать п × 1 случайный 0/1 вектор .
- Вычислить .
- Выведите «Да», если ; «Нет», иначе.
Ошибка
Если , то алгоритм всегда возвращает «Да». Если , то вероятность того, что алгоритм вернет «Да», меньше или равна половине. Это называется односторонняя ошибка.
Повторяя алгоритм k раз и возвращает «Да», только если все итерации дают «Да», время выполнения и вероятность ошибки Достигнут.
Пример
Предположим, кто-то желает определить:
Выбирается случайный двухэлементный вектор с элементами, равными 0 или 1, например - и используется для вычисления:
Это дает нулевой вектор, предполагая возможность того, что AB = C. Однако, если во втором испытании вектор выбран, результат становится:
Результат отличен от нуля, что доказывает, что AB ≠ C.
Имеется четыре двухэлементных вектора 0/1, половина из которых в данном случае дает нулевой вектор ( и ), поэтому шанс случайного выбора их в двух испытаниях (и ложного заключения о том, что AB = C) равен 1/2.2 или 1/4. В общем случае доля р дающий нулевой вектор может быть меньше 1/2, и будет использовано большее количество попыток (например, 20), что сделает вероятность ошибки очень малой.
Анализ ошибок
Позволять п равно вероятность ошибки. Мы утверждаем, что если А × B = C, тогда п = 0, а если А × B ≠ C, тогда п ≤ 1/2.
Дело А × B = C
Это независимо от стоимости , поскольку он использует только это . Следовательно, вероятность ошибки в этом случае равна:
Дело А × B ≠ C
Позволять такой, что
Где
- .
С , у нас есть этот элемент отличен от нуля. Предположим, что элемент . По определению матричное умножение, у нас есть:
- .
Для некоторой постоянной .С помощью Теорема Байеса, мы можем разделить :
| | (1) |
Мы используем это:
Подключив их к уравнению (1), мы получили:
Следовательно,
Это завершает доказательство.
Разветвления
Простой алгоритмический анализ показывает, что время работы этого алгоритм является О(п2), превосходя классический детерминированный алгоритм граница О(п3). Анализ ошибок также показывает, что если мы запустим алгоритм k раз мы можем достичь граница ошибки менее чем , экспоненциально малая величина. Алгоритм также быстр на практике из-за широкой доступности быстрых реализаций для произведений матрица-вектор. Следовательно, использование рандомизированные алгоритмы может ускорить очень медленно детерминированный алгоритм. Фактически, наиболее известный детерминированный алгоритм умножения матриц, известный в настоящее время, является вариантом метода Алгоритм Копперсмита – Винограда с асимптотическим временем работы О(п2.3729).[1]
Алгоритм Фрейвальдса часто встречается при введении в вероятностные алгоритмы из-за его простоты и того, как он иллюстрирует превосходство вероятностных алгоритмов на практике для некоторых задач.
Смотрите также
Рекомендации
- Р. Фрейвальдс (1977), «Вероятностные машины могут использовать меньшее время работы», Конгресс ИФИП 1977 г., стр. 839–842.
|
---|
Ключевые идеи | |
---|
Проблемы | |
---|
Аппаратное обеспечение | |
---|
Программного обеспечения | |
---|