Для решения данной задачи был написан метод min_dist, который находит расстояние от точки до отрезка и расстояние между двумя отрезками. В классе Polygon при вычислении расстояния до отрезка создается словарь adj_matrix, ключами которого являются ребра выпуклого многоугольника, а ключами - расстояния от них до заданного отрезка. Соответственно класс Segment был сделан хэшируемым. Индуктивное вычисление расстояния заключается в следующем: находятся все затененные ребра и удаляются из словаря adj_matrix, а добавленные в результате метода add ребра добавляются в этот словарь, затем ищется минимум в словаре - это и есть искомое расстояние.
Пусть задана точка
Тогда уравнение прямой проходящей через точки выглядит следующим образом:
Уравнение проходящей через точку
Необходимо написать программу, находящую выпуклую оболочку последовательно поступающих точек плоскости и вычисляющую её периметр и площадь. Решение должно быть индуктивным, что означает определение выпуклой оболочки и вычисление её характеристик сразу после поступления очередной точки с использованием методов теории индуктивных функций.
- Ключевое понятие проекта: освещённость ребра из точки
- Вспомогательные классы:
R2Point
— точка на плоскостиDeq
— контейнер дек (double ended queue)
- Основные классы:
Figure
— «абстрактная» фигураVoid
— нульугольникPoint
— одноугольникSegment
— двуугольникPolygon
— многоугольник
- Файлы проекта:
README.md
— данный файлREADME.html
— полученный из файлаREADME.md
html
-файлr2point.py
— реализация классаR2Point
deq.py
— реализация классаDeq
convex.py
— реализация основных классовrun_convex.py
— файл запускаtk_drawer.py
— интерфейс к графической библиотекеrun_tk_convex.py
— файл запуска с использованием графикиtests/test_r2point.py
— тесты к классуR2Point
tests/test_convex.py
— тесты к основным классам
Файлы run_tk_convex.py
и run_tk_convex.py
являются исполняемыми (они имеют
бит x
), в первой строке каждого из них используется шебанг и команда env
с
опцией (ключом) -S
. Это обеспечивает передачу интерпретатору языка Python
опции (ключа) -B
, отменяющего генерацию pyc
-файлов в директории
__pycache__
.
Для языка Python существуют соглашения о стиле
кода. Они являются лишь
рекомендациями (интерпретатор игнорирует их нарушение), но основную их
часть при написании программ целесообразно соблюдать. Существует простой
способ проверить соблюдение считающегося правильным
стиля записи кода с помощью утилиты (программы) pycodestyle
. Утилита
yapf
позволяет даже изменить код в соответствии с этими соглашениями.
Команда
pycodestyle r2point.py
позволяет, например, проверить соблюдение стиля для файла r2point.py
.
С помощью очень мощной и часто используемой утилиты find
проверить
корректность стиля всех файлов проекта можно так:
find . -name '*.py' -exec pycodestyle {} \;
Эта команда находит все файлы с расширением py
и запускает программу
pycodestyle
последовательно для каждого из них.
Уже известная нам команда (см. материал, посвящённый тестированию программ)
python -B -m pytest -p no:cacheprovider tests
запускает pytest, выполняя все начинающиеся с test
методы классов,
имена которых начинаются с Test
, содержащиеся во всех файлах test_*.py
директории tests
.
./run_convex.py
./run_tk_convex.py