Skip to content

Latest commit

 

History

History
56 lines (42 loc) · 4.45 KB

README.md

File metadata and controls

56 lines (42 loc) · 4.45 KB

Описание

  • Предмет: Технологическая практика по "Объектно-ориентированное программирование на платформе .NET" осень 2024
  • Выполнил: студент 4 курса ВМК МГУ, Дорофеев, 441/2

Постановка задачи

Задача коммивояжёра (или TSP от англ. Travelling Salesman Problem) [Wiki]

Important

Задана симметричная квадратная матрица расстояний между $N$ городами $D={d_{ij}}\in R^{N \times N}; \quad d_{ij}=d_{ji}>0; \quad d_{ii}=0$. Требуется найти близкий к кратчайшему маршрут, проходящий по одному разу через все указанные города с возвратом в исходный город.

В качестве множества решений задачи можно взять множество всех перестановок первых $N$ натуральных чисел. Каждый экземпляр решения определяет порядок посещения городов. Более приспособленным является экземпляр с меньшей длиной маршрута. Мутация - перестановка двух элементов экземпляра.

Задания

Задание Статус выполнения Статус сдачи
Задание №1 ✅ 22.09 ✅ 22.09
Задание №2 ✅ 27.10 ✅ 11.11
Задание №3 ✅ 24.11 ✅ 02.12
Задание №4 ✅ 09.12 ✅ 09.12

Задание №1

Выполнено:

  • Разработана библиотека классов для решения задачи коммивояжёра методом генетического программирования;
  • Библиотека классов размещена в отдельном пакете NuGet: GeneAlgoPack;
  • Написаны unit-test;
  • Написано простое приложение для демонстрации работоспособности библиотеки классов (см. рис. ниже).

img-1

img-2

Задание №2

Выполнено:

  • Разработано графическое приложение: WpfApp;
  • В библиотеку классов из задания №1 добавлены многопоточные вычисления;
  • Реализовано автоматическое создание матрицы расстояний между городами, удовлетворяющей неравенству треугольника.

img-3

Задание №3

Выполнено:

  • Добавлена возможность сохранения всех параметров задачи и актуального состояния популяции после завершения очередных шагов процесса оптимизации (сохраненному эксперименту присваивается имя, которое вводит пользователь).
  • Реализована возможность загрузки сохранённых ранее экспериментов и запуска процесс поиска оптимального решения с сохранённого состояния популяции (выбор сохранённого эксперимента выполняется в окне-списке имён экспериментов).
  • Для организации постоянного хранилища применяется технология Entity Framework Core.

img-4

Задание №4

Выполнено: разработано веб-приложение.

img-5

Лицензия

GNU General Public License v3.0