diff options
Diffstat (limited to 'report/lab10')
| -rw-r--r-- | report/lab10/images/test10.png | bin | 0 -> 475309 bytes | |||
| -rw-r--r-- | report/lab10/lab10.pdf | bin | 0 -> 528911 bytes | |||
| -rw-r--r-- | report/lab10/lab10.tex | 81 | ||||
| -rwxr-xr-x | report/lab10/maker.sh | 35 |
4 files changed, 116 insertions, 0 deletions
diff --git a/report/lab10/images/test10.png b/report/lab10/images/test10.png Binary files differnew file mode 100644 index 0000000..67dfc55 --- /dev/null +++ b/report/lab10/images/test10.png diff --git a/report/lab10/lab10.pdf b/report/lab10/lab10.pdf Binary files differnew file mode 100644 index 0000000..50eed16 --- /dev/null +++ b/report/lab10/lab10.pdf diff --git a/report/lab10/lab10.tex b/report/lab10/lab10.tex new file mode 100644 index 0000000..2612ecc --- /dev/null +++ b/report/lab10/lab10.tex @@ -0,0 +1,81 @@ +\documentclass[a4paper,oneside]{article}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T2A]{fontenc}
+\usepackage[english,russian]{babel}
+
+\usepackage{amsmath}
+\usepackage{mathtools}
+\usepackage{amsfonts}
+\usepackage{enumitem}
+\usepackage{amsthm}
+\usepackage{minted}
+\setminted{fontsize=\small, breaklines=true, style=emacs, linenos}
+\usepackage{graphicx}
+\graphicspath{ {./images/} }
+\usepackage{float}
+
+\newtheorem{theorem}{Теорема}[subsection]
+\newtheorem*{theorem*}{Теорема}
+
+% --- Определение --- %
+\theoremstyle{definition}
+\newtheorem{definition}{Определение}[subsection]
+\newtheorem*{definition*}{Определение}
+% ------------------- %
+
+\title{{Алгоритмы алгебры и теории чисел}\\{Лабораторная работа №10}}
+\author{Гущин Андрей, 431 группа, 1 подгруппа}
+\date{\the\year{} г.}
+
+\begin{document}
+
+\maketitle
+
+\section{Задание}
+Осуществить построение большого простого числа с
+использованием теоремы Поклингтона.
+
+
+\section{Алгоритм}
+Критерий Поклингтона — детерминированный тест на простоту, разработанный
+Генри Поклингтоном и Дерриком Генри Лехмером. Критерий Поклингтона
+позволяет определять, является ли данное число простым.
+
+Пусть $n$ — натуральное число. Пусть число $n-1$ имеет простой делитель
+$q$, причем ${\displaystyle q>{\sqrt {n}}-1}$. Если найдётся такое целое
+число $a$, что выполняются следующие два условия:
+
+\begin{enumerate}
+ \item $a^{n-1} \equiv 1 \pmod n$
+ \item числа $n$ и $a^{(n-1)/q}-1$ взаимнопросты
+\end{enumerate}
+
+тогда $n$ - простое число.
+
+Практическая реализация основана на выборе случайного числа в
+диапазоне значений от $2^{b - 1} + 1$ до $2^b - 1$ (где $b$ определяет
+число бит генерируемого простого числа). Далее это число проверяется на
+наличие небольших простых делителей (простые числа меньше 500), и если
+таких делителей не найдено, осуществляется проверка с помощью теоремы
+Поклингтона. Для этого перед запуском программы вводится значение
+верхнего порога $a$, определяющее, что в рамках проверки на простоту с
+помощью теоремы Поклингтона будут использоваться целые числа, значение
+которых не превосходит $a$. Если число проходит тест, значит оно
+является сгенерированным простым числом. Если же число не проходит тест
+или у него есть делители среди небольших первых простых чисел, то выбирается
+другое число из этого диапазона, пока выбранное число не будет проходить
+тест успешно.
+
+
+\section{Реализация}
+\inputminted{python}{../../lab10/lab10.py}
+
+
+\section{Тестирование}
+\begin{figure}[H]
+ \centering
+ \includegraphics[width=0.8\textwidth]{test10.png}
+\end{figure}
+
+\end{document}
diff --git a/report/lab10/maker.sh b/report/lab10/maker.sh new file mode 100755 index 0000000..e847acf --- /dev/null +++ b/report/lab10/maker.sh @@ -0,0 +1,35 @@ +#!/bin/sh + +watch() { + [ -z "$1" ] && echo "Необходимо указать название основного документа" && help + set -o xtrace + latexmk -pdf -f -shell-escape -interaction=nonstopmode -pvc $1 +} + +doc() { + [ -z "$1" ] && echo "Необходимо указать название основного документа" && help + set -o xtrace + latexmk -pdf -f -shell-escape -interaction=nonstopmode $1 +} + +clean() { + set -o xtrace + rm -rf _minted-* + find . -name "*.aux" -exec rm {} \; + rm -f *.dvi *.fdb_latexmk *.fls *.log *.out *.toc +} + +help() { + echo "Использование:" + echo "./maker.sh watch <main-doc>.tex -> Запуск процесса, пересобирающего документ при изменениях" + echo "./maker.sh doc <main-doc>.tex -> Пересобрать документ" + echo "./maker.sh clean -> Удаление сгенерированных файлов" + exit 1 +} + +case "$1" in + watch) watch $2 ;; + doc) doc $2 ;; + clean) clean ;; + *) help ;; +esac |