
%%%% Inter-route movement ---------------------------------------------------------------------%%%%
\subsection{Reinserción inter-ruta}

Los movimientos entre rutas buscan optimizar el itinerario de la flota de vehículos para cada tipo de residuo. Este proceso explora la reinserción de clientes entre diferentes rutas, siempre que se respeten las restricciones establecidas y se aplique de manera sincronizada para cada tipo de residuo. Un movimiento consiste en eliminar un cliente de su posición actual en una ruta e insertarlo en una posición factible dentro de otra ruta. Para ello hay que verificar la factibilidad del movimiento en dos aspectos. 

La búsqueda del mejor movimiento de reinserción inter-ruta para un cliente se desarrolla en dos pasos. En el primero, para cada posición de reinserción, se identifican las ventanas de tiempo que hacen factible el movimiento. A continuación, se comprueba cuáles de estas ventanas suministran rutas factibles para el resto de residuos. De ser necesario, se permiten movimientos de reinserción en estas últimas rutas para mantener la factibilidad de las mismas. Se comprueba también que se cumplen las restricciones de capacidad de los vehículos de cada ruta. De todas las combinaciones posibles se toma aquella que maximiza el beneficio global de la solución. 

Sean $r_m^w$ y $r_l^w$ dos rutas asociada al residuo $w \in W$ y $c[i], c[j] \in C$ los clientes que ocupan las posiciones $i$ y $j$ en cada ruta, respectivamente. Sea, asimismo, $t[i]$ la actual ventana de tiempo del cliente $c[i]$ y $T_{ij}$ el conjunto de ventanas de tiempo que aseguran la factibilidad de la reinserción de $c[i]$ tras $c[j]$. El conjunto de ventanas factibles para el movimiento de reinserción inter-ruta del cliente $c[i]$ en la ruta $r_l^w$ se define como
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\[
   T_i^* = \bigcup_{j} T_{ij}
\]
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
Para cada ventana de tiempo $t \in T_i^*$ se debe comprobar si, adoptándola, son factibles el resto de rutas a las que pertenece el cliente. Se permite durante este proceso movimientos de reinserción inter-ruta sin cambio de ventana para alcanzar la factibilidad. Sea $\hat{T_i}$ el conjunto de ventanas de tiempo del cliente $c[i]$ que suministran rutas factibles para todos los residuos y $t^*$ la ventana con la que se obtiene el máximo beneficio. Si el beneficio es mayor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.


%%%% Route reinsertion of unvisited customers -------------------------------------------------%%%%
\subsection{Reinserción de clientes excluidos}

Los movimientos de reinserción de clientes no visitados en el itinerario de vehículos para distintos tipos de residuos es una extensión de la función anterior que trata de incluir clientes con demanda positiva que no fueron atendidos inicialmente. Esto genera un problema de sincronización ya que, si un cliente es atendido para la recolección de un tipo de residuo, este debe serlo también para todos aquellos en los que presente demanda positiva. Es por ello que, si se encuentra una inserción factible en un tipo de residuo, es necesario verificar que se pueda encontrar a su vez una inserción factible para los demás residuos. 

La búsqueda del mejor movimiento de reinserción de clientes excluidos se desarrolla en dos pasos. En el primero, para cada posición de reinserción, se identifican las ventanas de tiempo que hacen factible el movimiento. A continuación, se comprueba cuáles de estas ventanas suministran rutas factibles para el resto de residuos. Se comprueba también que se cumplen las restricciones de capacidad de los vehículos de cada ruta. De todas las combinaciones posibles se toma aquella que maximiza el beneficio global de la solución. 

Sean $r_m^w$ una ruta asociada al residuo $w \in W$ y $c[j] \in C$ el cliente que ocupa la posición $j$ en dicha ruta, respectivamente. Sean, asimismo, $c[i] \in C$ el cliente excluido de la solución inicial que se trata de reinsertar tras la posición $j$ y $T_{ij}^*$ el conjunto de ventanas de tiempo que aseguran la factibilidad de la reinserción de $c[i]$ tras $c[j]$. El conjunto de ventanas factibles para el movimiento de reinserción de clientes excluidos del cliente $c[i]$ en la ruta $r_m^w$ se define como
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\[
   T_i^* = \bigcup_{j} T_{ij}^*
\]
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
Para cada ventana de tiempo $t \in T_i^*$ se debe comprobar si, adoptándola, son factibles el resto de rutas a las que se trata de reinsertar el cliente. Durante este proceso no se permite el cambio de ventana para alcanzar la factibilidad. Sea $\hat{T_i}$ el conjunto de ventanas de tiempo del cliente $c[i]$ que suministran rutas factibles para todos los residuos y $t^*$ la ventana con la que se obtiene el máximo beneficio. Si el beneficio es mayor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.


%%%% Route exclusion of visited customers -----------------------------------------------------%%%%
\subsection{Exclusión de clientes}

La exclusión de clientes en los itinerarios de recolección de residuos busca optimizar la solución actual eliminando clientes ya incluidos. Este proceso considera el impacto global de cada cliente, dado que los costos de transporte dependen de la cantidad y tipo de residuos generados. Dado que el objetivo es la eliminación del cliente del itinerario, no es necesario verificar la factibilidad del movimiento ni las ventanas de tiempo establecidas; es suficiente con calcular su impacto en el beneficio. Si el beneficio es mayor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.

%%%% Intra-route swap -------------------------------------------------------------------------%%%%
\subsection{Intercambio intra-ruta}

Los movimientos de intercambios dentro de una ruta es una técnica de búsqueda local que optimiza rutas individuales mediante la permutación de dos clientes en diferentes posiciones de la misma ruta. Su objetivo principal es reducir el coste de transporte, respetando siempre las restricciones de tiempo. 

Dada una ruta $r_l^w$, con $l \in \mathbb{N}$, para el residuo $w \in W$, la función selecciona dos posiciones $i, j \in \mathbb{N}$, con $i < j$, e intercambia a los clientes $c[i], c[j] \in C$ en dichas posiciones de lugar. Al tratarse de movimientos dentro de una misma ruta, solo se deben verificar las restricciones de tiempo, lo que incluye comprobar que los clientes intercambiados pueden ser atendidos dentro de sus ventanas de tiempo, y verificar la factibilidad temporal de los clientes intermedios y posteriores a la posición $j$. 

A diferencia de los movimientos de reinserción, en este caso no permitimos que el cliente pueda variar su ventana de tiempo adjudicada ya que esto podría crear multitud de complejidades con la sincronización del movimiento con el resto de tipos de residuos. De esto sigue que, una vez confirmada la factibilidad, se evalúa el impacto del movimiento solamente en el coste de transporte. Si el coste de transporte es menor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.

%%%% Inter-route swap -------------------------------------------------------------------------%%%%
\subsection{Intercambio inter-ruta}

Los movimientos de intercambios entre rutas optimiza el itinerario de recolección de un tipo de residuo al permutar clientes asignados a diferentes rutas, siempre que se cumplan las restricciones establecidas. Su objetivo es mejorar la solución inicial redistribuyendo los clientes entre rutas. 

Dadas dos rutas $r_l^w$ y $r_m^w$, con $l, m \in \mathbb{N}$, que sirven el tipo de residuo $w \in W$, el movimiento consiste en intercambiar los clientes $c[i]$ y $c[j]$ en las posiciones $i$ y $j$, con $i, j \in \mathbb{N}$, en las rutas $r_l^w$ y $r_m^w$, respectivamente. Antes de aceptar un intercambio se deben realizar las comprobaciones de factibilidad. En este caso, se comienza comprobando que en el intercambio no se supere el limite de capacidad máxima de los vehículos implicados en cada ruta. Luego se comprueba la factibilidad de las restricciones de tiempo; es decir, para cada una de las rutas afectadas, se evalúa si los nuevos clientes pueden ser atendidos en las rutas modificadas, asegurando que las ventanas de tiempo de todos los clientes posteriores también se cumplan. Superadas las restricciones de factibilidad, se procede al calculo del impacto del intercambio en el coste de transporte de la solución. Si el coste de transporte es menor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.

%%%% Inter-route swap with unvisited customers ------------------------------------------------%%%%
\subsection{Intercambio con clientes excluídos}

Los movimientos de intercambios entre clientes visitados y no visitados es una extensión de la función anterior que permite la permutación de clientes no seleccionados a pesar de presentar una demanda positiva para el tipo de residuos dado. A diferencia del caso previo, ahora se debe considerar un problema de sincronización múltiple ya que, en caso de que se encuentre un intercambio factible con un cliente en el itinerario de un tipo de residuos, se debe asegurar que el intercambio se pueda realizar también en el itinerario de los restantes. Por lo tanto, solo se consideran intercambios entre clientes con demanda positiva para los mismos tipos de residuos. Asimismo, se deben considerar todas las ventanas de tiempo disponibles para el cliente no visitado para su incorporación en el itinerario; es decir, no solamente se estudia su impacto en el coste de transporte de la ruta, sino también en el beneficio de la ruta. 

La búsqueda del mejor movimiento de intercambio de clientes excluidos se desarrolla en dos pasos. En el primero, para cada posición de intercambio, se identifican los clientes incluidos que generan los mismos tipos de residuos que el cliente que se trata de intercambiar y las ventanas de tiempo que hacen factible el movimiento. A continuación, se comprueba cuáles de estas ventanas suministran rutas factibles para el resto de residuos. Se comprueba también que se cumplen las restricciones de capacidad de los vehículos de cada ruta. De todas las combinaciones posibles se toma aquella que maximiza el beneficio global de la solución. 

Sean $r_m^w$ una ruta asociada al residuo $w \in W$ y $c[j] \in C$ el cliente que ocupa la posición $j$ en dicha ruta, respectivamente. Sean, asimismo, $c[i] \in C$ el cliente excluido de la solución inicial que se trata de intercambiar con el cliente $c[j]$ y $T_{ij}^*$ el conjunto de ventanas de tiempo que aseguran la factibilidad del intercambio de $c[i]$ con $c[j]$. El conjunto de ventanas factibles para el movimiento de intercambio con clientes excluidos del cliente $c[i]$ en la ruta $r_m^w$ se define como
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\[
   T_i^* = \bigcup_{j} T_{ij}^*
\]
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
Para cada ventana de tiempo $t \in T_i^*$ se debe comprobar si, adoptándola, son factibles el resto de rutas a las que se trata de intercambiar el cliente. Durante este proceso no se permite el cambio de ventana para alcanzar la factibilidad. Sea $\hat{T_i}$ el conjunto de ventanas de tiempo del cliente $c[i]$ que suministran rutas factibles para todos los residuos y $t^*$ la ventana con la que se obtiene el máximo beneficio. Si el beneficio es mayor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.


%%%% Two-Opt movement -------------------------------------------------------------------------%%%%
\subsection{2-Opt}

Un movimiento $2$-Opt es una estrategia de búsqueda local que invierte la secuencia de clientes entre dos posiciones de una ruta con el objetivo de minimizar el coste de transporte de la ruta. Sea $r_l^w$, con $l \in \mathbb{N}$, una ruta para el tipo de residuo $w \in W$, y sean $c[i], c[j] \in C$ dos clientes que se encuentran en las posiciones $i$ y $j$, con $i, j \in \mathbb{N}$, respectivamente. Este movimiento invierte la secuencia de clientes en ese segmento. Antes de aplicar la inversión, se verifica que el movimiento cumple las restricciones de tiempo, asegurando la factibilidad para todos los clientes afectados en dicho segmento. Si la operación es viable, se evalúa su impacto en el coste de transporte. Si el coste de transporte es menor que el de la solución original, se realiza el movimiento. En caso contrario, se descarta el mismo.




La construcción de las soluciones de partida se desarrolla en dos fases. En la primera, seleccionado un tipo de residuo, se construyen rutas tentativas para el mismo. Para ello, se seleccionan, del conjunto de clientes que generan residuos de este tipo, un subconjunto con el que se obtienen rutas factibles de alta calidad. Posteriormente, se construyen rutas para el resto de residuos que solo visitan a los clientes seleccionados en la fase anterior. Nótese que, con esta forma de actuar, aseguramos la construcción de rutas de recogida factibles para todos los residuos. En el peor de los casos, las rutas construidas serán iguales a las c



Proponemos un algoritmo que sigue un enfoque basado en GRASP (\textit{Greedy Randomised Adaptive Search Procedure}, \citet{Resende2016}, \citet{Resende2019}), que consta de dos fases, una de construcción de la solución inicial mediante una heurística ``greedy'' y otra de mejora de las soluciones construidas aplicando RVND (\textit{Random Variable Neighbourhood Descent} \citet{Amous2017}). Nuestro objetivo es asignar clientes a los vehículos de forma que se maximicen los beneficios mientras se cumplen las restricciones operativas. El algoritmo comienza inicializando una flota de vehículos, todos ellos con origen y destino en un depósito designado, en el que cada vehículo está inicialmente vacío, sin clientes asignados, con carga cero y sin coste asociado. El problema involucra múltiples clientes, cada uno caracterizado por una ubicación, múltiples demandas, múltiples ventanas de tiempo y múltiples ofertas asociadas a cada ventana de tiempo. Además, ningún cliente debe ser atendido en más de una ventana de tiempo; lo que implica un problema de sincronización de vehículos en el caso de presentar demanda positiva para varios tipos de residuos.



La calidad de la solución se evalúa mediante la función objetivo:
\begin{equation}
    \text{Beneficio} = \sum_{i \in C} \sum_{t \in T_i} p_i^ty_i^t - \sum_{w \in W}\sum_{v \in V} \sum_{i \in N} \sum_{j \in N} \tau_{ij}x_{ij}^{vw},
\end{equation}
donde el primer término representa las ganancias totales obtenidos por atender a los clientes en sus ventanas de tiempo seleccionadas y el segundo término representa los costes totales de transporte en todos los tipos de residuos y vehículos.


Este trabajo propone un algoritmo híbrido GRASP+RVND para resolver un Problema de Rutas de Vehículos Capacitados con Ventanas de Tiempo y Sincronización. Aunque nuestro enfoque muestra resultados prometedores, aún quedan varias oportunidades de mejora. Nuestro algoritmo maneja eficazmente los principales retos de la construcción de rutas, pero muestra limitaciones en la calidad de la solución y la eficiencia computacional al abordar los complejos requisitos de sincronización a través de múltiples tipos de residuos. De nuestros resultados experimentales pueden extraerse que el hecho de que las estructuras de entornos actuales funcionen de forma independiente limita su eficacia cuando las modificaciones en la ruta de un tipo de residuo afectan a la viabilidad de las recogidas sincronizadas. Asimismo, las restricciones de ventanas de tiempo restringen significativamente el espacio de soluciones, excluyendo potencialmente soluciones de alta calidad que sólo violan ligeramente estas restricciones. Además, en ocasiones, el algoritmo alcanza los óptimos locales antes de tiempo, lo que sugiere la necesidad de mecanismos de diversificación más sofisticados.

Basándonos en estos resultados, proponemos que las futuras implementaciones implementen una búsqueda local con estructuras de entornos combinadas que consideren simultáneamente múltiples tipos de residuos. Cuando un movimiento encuentra una nueva posición factible para un cliente con un tipo de residuo pero altera su ventana de tiempo de servicio, los ajustes correspondientes deben propagarse a otros tipos de residuos para mantener la sincronización. Este enfoque integrado mejoraría la calidad de la solución al ampliar el espacio de soluciones.

Por otra parte, relajar las restricciones de ventana temporal permitiendo infracciones menores (llegadas tempranas o tardías) podría ampliar significativamente el espacio de soluciones. Esta modificación requeriría el desarrollo de funciones de penalización apropiadas que equilibren las expectativas de nivel de servicio. Este planteamiento reflejaría mejor la flexibilidad operativa del mundo real y podría descubrir soluciones superiores.

Asimismo, la aplicación de técnicas de oscilación estratégica podría ayudar al algoritmo a escapar de los óptimos locales permitiendo temporalmente soluciones inviables durante el proceso de búsqueda. Además, reformular el problema dentro de un marco multiobjetivo proporcionaría a los responsables de la toma de decisiones un espectro de soluciones que abordarían explícitamente las compensaciones entre diferentes métricas de rendimiento.

Finalmente, quizá la dirección más prometedora consista en combinar nuestro enfoque metaheurístico con técnicas de aprendizaje automático. Entre las posibles aplicaciones se incluyen, algoritmos de reconocimiento de patrones para identificar regiones prometedoras del espacio de soluciones, o aprendizaje por refuerzo para guiar de forma adaptativa la selección de estructuras de entorno durante la fase de búsqueda local.

Aunque nuestra implementación actual de GRASP+RVND proporciona una base sólida para abordar el VRP Capacitado con Ventanas de Tiempo y Sincronización, las mejoras propuestas representan oportunidades significativas para avanzar tanto en la comprensión teórica como en la aplicación práctica de enfoques de solución para esta compleja clase de problemas. El trabajo futuro se centrará en la implementación y evaluación de estas mejoras, con especial énfasis en la integración de técnicas de aprendizaje automático con procedimientos metaheurísticos tradicionales.