File size: 4,120 Bytes
7fdb6c5
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
97
98
99
100
101
102
103
104
105
106
107
108
109
import streamlit as st

from pages.vrp.Origen import Grafo, Vehiculos
from pages.vrp.Algoritmo_gen茅tico import Algoritmo_Genetico

#######################
## FUNCIONES AUXILIARES
#######################

def grafar(reparto : list[list[int]]):   
    
    result = "digraph { \n"

    for ruta in reparto:
        result += "Almac茅n ->"
        for nodo in ruta:
            result += str(nodo) + "\n"
            result += str(nodo) + "->"
        result += "Almac茅n \n"

    result += "}" 

    return result

def presentar(reparto : list[list[int]]):

    result = ""

    for i in range(len(reparto)):
        result += "Camion " + str(i) + ": " + "Almac茅n -> "
        for parada in reparto[i]:
            result += str(parada) + " -> "
        result += "Almac茅n \n"

    return result

st.set_page_config(page_title="LupercAI", page_icon= "馃殯")

st.title("LupercAI 馃殯")

valores_vitales = ["distancias", "demandas_clientes", "capacidad_vehiculos"]
importado = True
for valor in valores_vitales: importado = importado and valor in st.session_state

if not importado: 
    st.warning("Faltan datos", icon="鈿狅笍")
else:
    #if "num_nodos" not in st.session_state: st.session_state["num_nodos"] = len(st.session_state["demandas_clientes"])
    #if "num_vehiculos" not in st.session_state: st.session_state["num_vehiculos"] = len(st.session_state["capacidad_vehiculos"])

    grafo = Grafo(st.session_state["distancias"], st.session_state["demandas_clientes"])
    vehiculos = Vehiculos(st.session_state["capacidad_vehiculos"])

    if "activar_generaciones" in st.session_state:
        if st.session_state["activar_generaciones"]:
            if "alg_genetico" not in st.session_state: st.session_state["alg_genetico"] = Algoritmo_Genetico(tamano_poblacion = st.session_state["tamano_poblacion"], 
                generaciones = st.session_state["generaciones"], tamano_torneo = st.session_state["tamano_torneo"], 
                crossover_prob = st.session_state["crossover_prob"], mutation_prob = st.session_state["mutation_prob"])
        else:
            if "alg_genetico" not in st.session_state: st.session_state["alg_genetico"] = Algoritmo_Genetico()
    else:
        if "alg_genetico" not in st.session_state: st.session_state["alg_genetico"] = Algoritmo_Genetico()

    alg_genetico = st.session_state["alg_genetico"]

    from threading import Thread
    Thread(target=alg_genetico.generar, args = (grafo, vehiculos)).start()
    

    #Computaci贸n:

    empty_latest_iteration = st.empty()
    empty_mejor_coste = st.empty()

    st.subheader("Barra de progreso")
    barra_progreso = st.progress(0)  

    st.subheader("Grafo del mejor recorrido actual")
    
    empty_txt = st.empty()
    
    empty_grafo = st.empty()

    i = 0
    while alg_genetico.generacion_actual < alg_genetico.generaciones:
        #Generaci贸n por escrito
        empty_latest_iteration.write("Generaci贸n: " + str(alg_genetico.generacion_actual))

        #Barra de progreso
        barra_progreso.progress( alg_genetico.generacion_actual/alg_genetico.generaciones)

        #Mejor coste actual (texto)
        empty_mejor_coste.write("**Mejor coste**: " + str(alg_genetico.mejor_candidato[1]))

        #Descarga de grafo
        empty_txt.download_button("Mejor recorrido 馃斀", presentar(alg_genetico.mejor_candidato[0]), file_name="Mejor reparto - Generacion " + str(alg_genetico.generacion_actual) + ".txt", key=str(i))
        i += 1

        #Mostrar el grafo
        empty_grafo.graphviz_chart(grafar(alg_genetico.mejor_candidato[0]))

        
    #Ultima iteracion
    empty_latest_iteration.write("Generaci贸n: " + str(alg_genetico.generacion_actual))
    barra_progreso.progress( alg_genetico.generacion_actual/alg_genetico.generaciones)
    empty_mejor_coste.write("**Mejor coste**: " + str(alg_genetico.mejor_candidato[1]))
    empty_txt.download_button("Mejor recorrido 馃斀", presentar(alg_genetico.mejor_candidato[0]), file_name="Mejor reparto - Generacion " + str(alg_genetico.generacion_actual) + ".txt", key=str(i))
    empty_grafo.graphviz_chart(grafar(alg_genetico.mejor_candidato[0]))