Skip to main content

Elliptic Curve Factorization

Project description

Elliptic Curve Factorization

Данный модуль предназначен для нахождения всех делителей числа (факторизация, разложение на простые множители). В качестве метода факторизации используется алгоритм, предложенный Хендриком Ленстрой в 1987 году.

Использование через скрипт

Склонируйте репозиторий, и установите зависимости используя:

git clone https://github.com/NikitaYurasov/ECF.git
cd ECF
poetry install
  • pip
git clone https://github.com/NikitaYurasov/ECF.git
cd ECF
pip install -r requirements.txt

И выполните следующую команду:

python pyecf.py -n 9671406556917033397649407  # или любое другое число

Использование как пакет

Установите пакет используя pip (или любой другой менеджер зависимостей)

pip install pyecf

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

from pyecf import LenstraAlgorithm

n = 9671406556917033397649407
algo = LenstraAlgorithm(n)
factors = algo.factorize() # factors - отсортированный список делителей

Описание алгоритма

Пусть требуется найти делить числа . Считаем, что у числа существует делитель (). Сгенерируем тройку чисел для случайной эллиптической кривой над , где и с условием, что кривая не сингулярна (). Случайной точкой на кривой выберем .

Пусть также задано число , обозначающее степень, в которое будем возводить начальную точку : , где и -- некоторые целые положительные числа.

Следующим шагом выполняется возведение в степень на выбранной кривой:

, где операция + определена по следующему алгоритму:

Алгоритм сложения

Требуется сложить две точки и :

  1. Если , то ; если , то .

  2. Иначе, пусть

    a. Найти . Если , то -- делитель . Конец алгоритма.

    b. Если , то НОД дает Конец алгоритма.

    c. Если , тогда . Требуется найти .

    • Если , -- делитель, конец алгоритма.
    • В противном случае, если , считаем, что , конец алгоритма.
    • Если , то и .

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

Нахождение всех делителей числа

  1. Пусть заданы два массива: пустой массив для простых делителей и массив с составными делителями. На первом шаге, во втором массиве находится число .

  2. По всем числам из массива составных делителей пока он не пустой:

    • Берем первое число;
    • Проверяем на простоту (тест Миллера-Рабина): если число простое, заносим его в массив простых чисел, и удаляем первое число из массива составных чисел;
    • Если не простое, проверяем на четность: если число четное, в список простых делителей заносим 2, в список составных - в конец;
    • Если не четное, аналогично проверяем делимость на 3;
    • В противном случае используем алгоритм Ленстры для поиска делителя, пока он не будет найден. Когда делитель найден, добавляем его и в список составных делителей в конец.
  3. Результатом алгоритма будут все числа из списка простых делителей.

Скорость работы

Время работы данного алгоритма зависит не от самого факторизуемого числа, а то размера наименьшего делителя.

Время работы: Время работы

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyecf-0.1.3.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

pyecf-0.1.3-py3-none-any.whl (12.0 kB view details)

Uploaded Python 3

File details

Details for the file pyecf-0.1.3.tar.gz.

File metadata

  • Download URL: pyecf-0.1.3.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.9.6 Darwin/23.1.0

File hashes

Hashes for pyecf-0.1.3.tar.gz
Algorithm Hash digest
SHA256 0d071ce0f620865afc2196e298babf5fdad6bc1430bb3ced98d7cfa64165830d
MD5 3accdb50f5cff7222422944fda8f9906
BLAKE2b-256 7db02f58783fe7c003ad89da5d6b5c8e435db1102e903b062fc7b0c76b5cc1ae

See more details on using hashes here.

File details

Details for the file pyecf-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: pyecf-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 12.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.9.6 Darwin/23.1.0

File hashes

Hashes for pyecf-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 8da617be507d334d2e10b1822a421c5358043ab14b5da65bbe752a3068eeed6e
MD5 21c8d41eee78f2b480af6a9e535d5bc6
BLAKE2b-256 5853be98c1faf9d77d24bfb464f8620360de73151ccc58c7e75d587f6d8de8d7

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page