Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 07.10.2019
Сообщений: 80

Оптимизационная задача Генетическим Алгоритмом

09.06.2023, 05:09. Показов 513. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Алгоритм уже написан, но только с входом: 1 массив.
В задаче на входе: 2 вектора и 1 массив. Нужно правильно подать это в алгоритм.

Генетический алгоритм это 3 этапа 1) селекция 2) скрещивание 3) мутация, которые повторяются много раз
Входные данные здесь нужны только для того, чтобы посчитать значение функции приспособленности
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import numpy as np
 
# 0.входы с задачи
with open("input.txt", "r") as file:
    n = int(file.readline())
 
nlevel = np.loadtxt('input.txt', skiprows=1, max_rows=1)
ntime = np.loadtxt('input.txt', skiprows=2, max_rows=1)
 
with open("input.txt", "r") as file:
    m = int(file.readline())
 
mcoef = np.array(np.loadtxt('input.txt', skiprows=4))
#print(nlevel)
#print(ntime)
#print(mcoef[0])
 
#оригинальный алгоритм
class GeneticAlgorithm:
 
    def __init__(self,
                 dots: np.ndarray,
                 size: int,
                 max_len_individual: int,
                 size_population: int,
                 size_selection: int,
                 p_mutation_ind: float,
                 p_mutation_gen: float
                 ):
        self.dots = dots  # точки для посещения
        self.size = size  # размер поля
        self.max_len_individual = max_len_individual  # количество шагов который делает каждая особь
        self.size_population = size_population  # количество особей
        self.size_selection = size_selection  # выживаемые особи во время селекции
        self.p_mutation_ind = p_mutation_ind  # вероятность мутации детей
        self.p_mutation_gen = p_mutation_gen  # вероятность мутации генов
        self.rng = np.random.default_rng()  # генератор случайных элементов
        self.population = self.rng.integers(0, 4, size=(self.size_population, self.max_len_individual))
 
    directions = np.array(((0, 1), (0, -1), (1, 0), (-1, 0)))
 
    def get_paths(self) -> tuple[np.ndarray, np.ndarray]:
        paths = np.full((self.size_population, self.max_len_individual + 1, 2), self.size // 2)
        visited = np.full((self.size_population, self.size, self.size), -1)  # матрица посещений
        visited[:, self.size // 2, self.size // 2] = 0  # посещение всех центральных ячеек
        idx = np.arange(self.size_population)
 
        for i in range(self.max_len_individual):
            paths[:, i + 1] = (paths[:, i] + self.directions[self.population[:, i]]) % self.size
            ind = np.ravel_multi_index((idx, paths[:, i + 1, 0], paths[:, i + 1, 1]), visited.shape)
            values = np.ravel(visited)[ind]
            np.ravel(visited)[ind] = np.where(values >= 0, values, i + 1)
        return paths, visited
 
    def fitness(self) -> np.ndarray:
        _, visited = self.get_paths()
        result = visited[:, self.dots[:, 0], self.dots[:, 1]]
        count = (result >= 0).sum(axis=1)
        steps = result.max(axis=1)
        # steps = np.where(steps == -1, self.max_len_individual, steps)
        steps[steps == -1] = self.max_len_individual
 
        return count * self.max_len_individual - steps
 
    def selection(self) -> None:
        self.selected = self.population[np.argsort(self.fitness())[-self.size_selection:]]
 
    def crossover(self) -> None:
        new_count = self.size_population - self.size_selection
        parent1 = self.rng.integers(0, self.size_selection, size=new_count)
        parent2 = (self.rng.integers(1, self.size_selection, size=new_count) + parent1) % self.size_selection
 
        point = self.rng.integers(1, self.max_len_individual - 1, size=new_count)
        self.childs = np.where(
            np.arange(self.max_len_individual)[None] <= point[..., None],
            self.selected[parent1],
            self.selected[parent2]
        )
 
    def mutation(self) -> None:
        mut_childs_mask = self.rng.choice(2, p=(1 - self.p_mutation_ind, self.p_mutation_ind),
                                          size=len(self.childs)) > 0
        mut_childs = self.rng.integers(0, 4, size=(mut_childs_mask.sum(), self.max_len_individual))
        gen_childs_mask = self.rng.random(size=mut_childs.shape) <= self.p_mutation_gen
        self.childs[mut_childs_mask] = np.where(gen_childs_mask, mut_childs, self.childs[mut_childs_mask])
 
    def step(self) -> None:
        self.selection()
        self.crossover()
        self.mutation()
        self.population = np.concatenate([self.selected, self.childs], axis=0)
 
 
width, height = 11, 11
dots = np.array([(1, 1), (1, 9), (7, 3), (9, 8), (3, 5)])
ga = GeneticAlgorithm(dots, width, 100, 200, 20, 0.5, 0.15)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.06.2023, 05:09
Ответы с готовыми решениями:

Задача о 8 ферзях генетическим алгоритмом (бинарная кодировка)
Добрый день! Нужно решить задачу о 8 ферзях генетическим алгоритмом. Алгоритм, в сущности, ясен, но сразу возникли трудности с бинарной...

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

Генерация музыки генетическим алгоритмом
Здравствуйте. Мне нужно сделать программку. Реализовать генетический алгоритм для генерации последовательности, в частности музыкальной...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.06.2023, 05:09
Помогаю со студенческими работами здесь

Многослойный персептрон обучить генетическим алгоритмом
Помогите в разработке кода. Нужно Многослойный персептрон обучить с помощью генетического алгоритма. На входе вектора значений на выходе n...

Оптимизационная задача
дравствуйте, уважаемые математики Возникла необходимость программировать одну очень важную задачу. Пытаюсь придумать алгоритм...

Оптимизационная задача
Доброго времени суток! Не могу решить задачу хоть убей. Весь день убил на неё и всё равно никак, хотя до этого решил похожую более...

Оптимизационная задача
Всем привет. Есть такая задача. ограничение по времени на тест: 2 секунды ограничение по памяти на тест: 256 мегабайт 1 &lt;= n, m...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru