-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtraining.py
More file actions
117 lines (97 loc) · 6.24 KB
/
Copy pathtraining.py
File metadata and controls
117 lines (97 loc) · 6.24 KB
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
110
111
112
113
114
115
116
117
# Importar las librerías necesarias
import os
import pickle
import numpy as np
import tensorflow as tf
from tensorflow.keras.preprocessing.text import Tokenizer
from tensorflow.keras.preprocessing.sequence import pad_sequences
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Embedding, LSTM, Dense, Bidirectional
from sklearn.model_selection import train_test_split
# CARGA DE LOS DATOS
# Se define el directorio data donde se almacenan los fragmentos de código organizados por lenguaje de programación
data_dir = "data"
# Crear una lista vacía para almacenar los datos
data = []
# Recorre cada lenguaje de programación y cada archivo de estos subdirectorios
print(f'===================================================================================================================================================')
for language in os.listdir(data_dir):
language_dir = os.path.join(data_dir, language)
for file_name in os.listdir(language_dir):
file_path = os.path.join(language_dir, file_name)
try: # Intentamos abrir el archivo con codificación UTF-8
with open(file_path, "r", encoding="utf-8") as file:
code = file.read()
except UnicodeDecodeError: # Si falla, intentamos con otra codificación por tildes, $, etc.
print(f"Error descodificando el archivo: '{file_path}' como UTF-8, intentando una alternativa de codificación...")
# Intentamos abrir el archivo con codificación latin-1
with open(file_path, "r", encoding="latin-1") as file:
# Leemos el contenido del archivo
code = file.read()
# Imprimimos un mensaje de éxito
print(f"Codificación exitosa con el archivo: '{file_path}' en latin-1")
# Agregamos el contenido del código y el lenguaje de promación a la lista de datos
data.append((code, language))
print(f'===================================================================================================================================================')
# Ahora `data` contiene una lista de tuplas, donde cada tupla contiene un bloque de código y su lenguaje correspondiente
print(f"| Se han cargado {len(data)} fragmentos de código de diferentes lenguajes de programación. |")
print(f'===================================================================================================================================================')
# PREPARACIÓN DE LOS DATOS PARA EL ENTRENAMIENTO
# Separa el código y el lenguaje en listas separadas
texts, labels = zip(*data)
languages = sorted(set(labels))
# Se crea el mapeo de cada lenguaje a un número y su inverso
label_to_index = {label: idx for idx, label in enumerate(languages)}
index_to_label = {idx: label for label, idx in label_to_index.items()}
# Convertir etiquetas a índices númericos
labels = [label_to_index[label] for label in labels]
# Tokeniza el código usando Keras con un vocabulario máximo de 500 palabras
tokenizer = Tokenizer(num_words=500)
tokenizer.fit_on_texts(texts)
# Convierte los textos tokenizados a secuencias numéricas y ajusta todas las secuencias a la misma longitud
sequences = tokenizer.texts_to_sequences(texts)
max_length = max(len(seq) for seq in sequences)
X = pad_sequences(sequences, maxlen=max_length)
# Convertir las etiquetas a un array numpy
y = np.array(labels)
# DIVISIÓN DE LOS DATOS
# Se divide los datos en conjuntos de entrenamiento y prueba
# El 70% de los datos se utiliza para el entrenamiento y el 30% para la prueba
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)
# DEFINICIÓN Y ENTRENAMIENTO DEL MODELO
model = Sequential([
# Convierte las secuencias numéricas a vectores densos
Embedding(input_dim=500, output_dim=32, input_length=max_length),
# Se usa una capa LSTM bidireccional para aprender patrones en ambas direcciones de las secuencias
Bidirectional(LSTM(32)), #Al modificar la capa oculta cambian los porcentajes
# Es una capa densa de 64 neuronas con función de activación ReLU
Dense(32, activation='relu'),
# Es una capa de salida con activación softmax para clasificar los lenguajes de programación
Dense(len(languages), activation='softmax')
])
# Compilar el modelo
model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy'])
print(f'===================================================================================================================================================')
print(f'===================================================================================================================================================')
# Entrenar el modelo usando el conjunto de datos de entrenamiento y validando con el conjunto de datos de prueba
model.fit(X_train, y_train, epochs=35, validation_data=(X_test, y_test))
# Evaluar el modelo utilizando el conjunto de datos de prueba
loss, accuracy = model.evaluate(X_test, y_test) #Esta precision es promedios calculados en el momento, no es la final
error_general = 1 - accuracy
print(f'===================================================================================================================================================')
print(f'Precisión en el conjunto de datos de prueba: {accuracy}') #Precision final
print(f'Porcentaje del error general en el conjunto de datos de prueba: {error_general}')
print(f'===================================================================================================================================================')
# GUARDAR EL MODELO Y LOS DICCIONARIOS
# Guardar el modelo
model.save("model/language_model.keras")
# Guardar el tokenizer y los diccionarios
with open("model/tokenizer.pickle", "wb") as handle:
pickle.dump(tokenizer, handle, protocol=pickle.HIGHEST_PROTOCOL)
with open("model/label_to_index.pickle", "wb") as handle:
pickle.dump(label_to_index, handle, protocol=pickle.HIGHEST_PROTOCOL)
with open("model/index_to_label.pickle", "wb") as handle:
pickle.dump(index_to_label, handle, protocol=pickle.HIGHEST_PROTOCOL)
# Guardar la longitud máxima de secuencia
with open("model/max_length.pickle", "wb") as handle:
pickle.dump(max_length, handle, protocol=pickle.HIGHEST_PROTOCOL)