-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathga.py
94 lines (77 loc) · 2.65 KB
/
ga.py
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
import numpy as np
import csv
import networkx as nx
from numpy.random import choice
from copy import deepcopy
from pprint import pprint
from tqdm import tqdm
import json
import sys
from helpers.utils import get_node_vals, get_nbrs, random_walk, add_weights, \
fitness, simulate_people, GA, CreateGraph, get_diff
from helpers.route import Route, Routes
import matplotlib.pyplot as plt
from routePath import optimal_route
from webtools import *
if len(sys.argv) < 2:
print("Usage: python3 ga.py [prefix for in/out file]")
exit(0)
pre = sys.argv[1]
# Get the graph
G = CreateGraph(75, fname=f'./data/{pre}_final_full_graph.csv', pre=pre, node_prob=True)
#G_ = CreateGraph(75, fname=f'./data/{pre}_final_full_graph.csv', pre=pre)
#print(np.max(nx.get_edge_attributes(G,'length')))
# Hyper parameters
pop_size = 100
walk_length = [7, 15]
num_routes = [12, 25]
num_ppl = 50000
cap = 60
consts = {
'optimal': (30, -500, -70),
'people': (1, 0, 0),
'money': (0, 1000, 70),
}
opt_bus = 20
max_trips = 5 # no of times a bus can run on a specific route
elite = 0.1
iter = 200
crossover_perc = 0.20
mutation_prob = 0.01
mode = 'people'
pop = []
print("Generating initial routes ...")
Route.initialize_class(G)
for i in tqdm(range(pop_size)):
routenum = np.random.randint(num_routes[0], num_routes[1] + 1)
rts = []
for i in range(routenum):
source, destination = choice(list(G.nodes()), size=2)
length = np.random.randint(walk_length[0], walk_length[1] + 1)
rts.append(Route(cap, random_walk(G, source, destination, length)))
pop.append(Routes(rts))
ppl = simulate_people(G, num_ppl)
fit = [fitness(p, ppl, G, consts, opt_bus, max_trips, components=True) for p in pop]
fit = np.array(fit)
print(fit.shape)
print(np.mean(fit, axis=0))
# Add graph to the routes
Route.initialize_class(G)
Routes.initialize_class(G)
rs = pop[0]
src = pop[0].routes[1].v[2]
dest = pop[0].routes[2].v[3]
path = optimal_route(rs.routes, src, dest)
print(path)
#plot_route(G, rs.routes, show=True)
plot_route_sd(G, rs.routes, src, dest, show=True)
"""
# Use a GA to solve the problem
best, ppl, final_pop, avg, bst, wst = GA(iter, pop, pop_size, G, num_ppl, consts, \
opt_bus, max_trips, elite, mutation_prob, \
crossover_perc, pre=pre, mode=mode, plot=True, every=20)
print("\nFinal Solution:")
print(best)
best_fit = fitness(best, ppl, G, consts, opt_bus, max_trips, components=True)
print(f'\nThis route serves {100*best_fit[0]/best.cap}% ({best_fit[0]}) of people , About {best_fit[1]} buses run with a total capacity of {best.cap} and the average length of a bus route is {best_fit[2]} km')
"""