\documentclass{article}


% if you need to pass options to natbib, use, e.g.:
%     \PassOptionsToPackage{numbers, compress}{natbib}
% before loading maeb_2025

% ready for submission
\usepackage[final]{maeb_2025}
\bibliographystyle{abbrvnat}

\usepackage[english,spanish,es-tabla,shorthands=off]{babel}

% to compile a preprint version, e.g., for submission to arXiv, add add the
% [preprint] option:
%     \usepackage[preprint]{maeb_2025}


% to compile a camera-ready version, add the [final] option, e.g.:
%     \usepackage[final]{maeb_2025}


% to avoid loading the natbib package, add option nonatbib:
%    \usepackage[nonatbib]{maeb_2025}


\usepackage[utf8]{inputenc} % allow utf-8 input
\usepackage[T1]{fontenc}    % use 8-bit T1 fonts
\usepackage{hyperref}       % hyperlinks
\usepackage{url}            % simple URL typesetting
\usepackage{booktabs}       % professional-quality tables
\usepackage{amsfonts}       % blackboard math symbols
\usepackage{nicefrac}       % compact symbols for 1/2, etc.
\usepackage{microtype}      % microtypography
\usepackage{xcolor}         % colors
\usepackage{amsmath}
\usepackage[spanish, onelanguage, linesnumbered, ruled, noend, noline]{algorithm2e}
\usepackage{enumitem}
\usepackage{tabularx}
\usepackage{graphicx}
\usepackage{colortbl}
\usepackage{soul}
\usepackage{icomma}
\usepackage{cleveref}

\crefname{equation}{}{}
\crefrangelabelformat{equation}{(#3#1#4, #5#2#6)}

\usepackage{tikz}
\usetikzlibrary{arrows, positioning, fit, calc}
\usepackage{xcolor}
\definecolor{dgreen}{RGB}{27,158,119}
\definecolor{dorange}{RGB}{217,95,2}
\definecolor{dpurple}{RGB}{117,112,179}


\title{Un algoritmo híbrido GRASP+RVND para un Problema de Rutas de Vehículos Capacitados con Ventanas de Tiempo y Sincronización}


% The \author macro works with any number of authors. There are two commands
% used to separate the names and addresses of multiple authors: \And and \AND.
%
% Using \And between authors leaves it to LaTeX to determine where to break the
% lines. Using \AND forces a line break at that point. So, if LaTeX puts 3 of 4
% authors names on the first line, and the last on the second line, try using
% \AND instead of \And before the third author name.


\author{%
  Oswaldo J. Pérez Luis \\
  Departamento de Ingeniería Informática y de Sistemas \\
  Instituto Universitario de Desarrollo Regional\\
  Universidad de La Laguna \\
  38200, San Cristóbal de La Laguna \\
  \texttt{operezlu@ull.edu.es} \\
  \And
  Belén Melián Batista \\
  Departamento de Ingeniería Informática y de Sistemas \\
  Instituto Universitario de Desarrollo Regional\\
  Universidad de La Laguna \\
  38200, San Cristóbal de La Laguna \\
  \texttt{mbmelian@ull.edu.es} \\
  \And
  J. Marcos Moreno Vega \\
  Departamento de Ingeniería Informática y de Sistemas \\
  Instituto Universitario de Desarrollo Regional\\
  Universidad de La Laguna \\
  38200, San Cristóbal de La Laguna \\
  \texttt{jmmoreno@ull.edu.es} \\
  % examples of more authors
  % \And
  % Coauthor \\
  % Affiliation \\
  % Address \\
  % \texttt{email} \\
  % \AND
  % Coauthor \\
  % Affiliation \\
  % Address \\
  % \texttt{email} \\
  % \And
  % Coauthor \\
  % Affiliation \\
  % Address \\
  % \texttt{email} \\
  % \And
  % Coauthor \\
  % Affiliation \\
  % Address \\
  % \texttt{email} \\
}


\begin{document}


\maketitle


\begin{abstract}
  En este trabajo estudiamos un Problema de Rutas de Vehículos Capacitados con Ventanas de Tiempo y Sincronización en la industria de la recogida de residuos, centrándonos específicamente en la coordinación de múltiples vehículos en las ubicaciones de los clientes. Este problema surge en contextos donde se requiere el servicio simultáneo de diferentes vehículos, como en la recogida especializada de residuos, en la que deben ser recogidos simultáneamente varios tipos de residuos. Proponemos una estrategia híbrida GRASP+RVND, en el que las soluciones construidas con un procedimiento GRASP son mejoradas con un método de Descenso por Entornos Variables Aleatorios (RVND). La experiencia computacional muestra la validez de nuestra propuesta. Se obtienen resultados que igualan o mejoran los obtenidos al resolver de manera exacta el modelo matemático. 
  
  %La validez de nuestro algoritmo se demuestra con un estudio computacional comparándolo con un enfoque exacto.
\end{abstract}


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Introducción}\label{sec:int}

Uno de los mayores desafíos a los que nos enfrentamos es la gestión de los residuos generados por la actividad humana. Se trata de una tarea compleja que involucra a numerosos actores y requiere la movilización y coordinación de diversos recursos. En esta tarea se identifican algunas fases o procesos entre los que destacan la recogida, el transporte, el tratamiento y el desecho final de los residuos no reutilizados o transformados. Estas fases se relacionan con el ciclo de vida de los residuos que, desde una perspectiva de economía circular, persigue reciclar, revalorizar y reutilizar tantos residuos como sea posible.

Para facilitar el posterior tratamiento de los residuos, se fomenta la separación en origen, que traslada a la población y a las empresas parte de la responsabilidad del proceso de reciclaje. Ello obliga a localizar en determinadas ubicaciones contenedores especializados en cada tipo de residuo. La recogida se realiza por medio de vehículos que recorren estas ubicaciones para trasladar los residuos a las plantas de tratamiento.

La eficiencia en la gestión de la recogida y transporte de residuos se vuelve más relevante en entornos urbanos, donde es necesario equilibrar restricciones operativas y medioambientales. La complejidad de estos sistemas se ve agravada por varios factores. Entre ellos se encuentran: la incertidumbre en la cantidad de residuos generados, lo que introduce variabilidad en la planificación y afecta tanto al diseño de las rutas como a la utilización de la capacidad de los vehículos; la necesidad de respetar estrictamente los plazos, no solo para atender a los clientes, sino también para coordinar la llegada de los vehículos a los puntos de recogida, con el objetivo de minimizar los tiempos de espera y los costes asociados; o la necesidad de que el sistema sea capaz de adaptarse a diversas limitaciones operativas, como las horas de trabajo de los empleados de la flota de vehículos.

Los problemas de rutas de vehículos en la recolección de residuos han sido clave en la optimización de estas operaciones, con varias extensiones desarrolladas para abordar retos específicos del mundo real, como se discute en la revisión realizada en \citet{Hess2023}. En este trabajo, los autores distinguen los Problemas de Rutas de Vehículos (VRP), entre otros, como uno de los modelos más utilizados para tratar la problemática de la recogida de residuos. 

Los sistemas de recogida de residuos suelen estructurarse en dos niveles. En el primero, vehículos de pequeño tamaño recogen los residuos de las zonas urbanas y los transfieren, en el segundo, a vehículos de mayor capacidad que los transportan a instalaciones de tratamiento o vertederos. Como señalan \citet{Ghiani2021}, esta configuración requiere una sincronización precisa en las estaciones de transferencia de residuos para garantizar una operación eficiente y evitar cuellos de botella operativos. Estudios recientes destacan la importancia de integrar la sincronización temporal con la gestión del espacio en los Problemas de Rutas de Vehículos de Recogida de Residuos de Dos Niveles (\citet{Rahmanifar2024}), especialmente cuando los vehículos de gran capacidad funcionan como puntos de transbordo dinámicos, donde el almacenamiento prolongado de residuos no resulta práctico ni deseable. El desafío consiste en desarrollar soluciones que, además de minimizar costes y distancias, optimicen la sincronización de los vehículos para reducir tiempos de espera y mejorar la eficiencia operativa.

La introducción de restricciones de sincronización supone una evolución significativa con respecto a las formulaciones tradicionales de los problemas de rutas de vehículos, donde las rutas suelen planificarse de forma independiente. En el contexto de la recogida de residuos, la sincronización es particularmente relevante cuando varios vehículos deben coordinar sus operaciones para recogidas conjuntas o en puntos de transferencia dentro de una red, como discuten \citet{Soares2024} en su revisión sobre problemas de rutas con sincronización. Estas restricciones introducen interdependencias complejas entre las rutas, ya que la viabilidad de una influye directamente en las demás.

\citet{Shao2020} tratan un problema de recogida selectiva de residuos con restricciones de sincronización. El problema abordado se centra en la contratación de servicios de transporte de para cargas que no llenan la capacidad total de los vehículos de recogida en el sector empresarial. En este contexto, varias empresas solicitan la recogida selectiva de sus residuos al único transportista que presta el servicio. Este dispone de una flota de vehículos especializados en cada tipo de residuo con los que realiza la recogida y transporte. Las empresas presentan diferentes ventanas de tiempo para la recogida y el precio que están dispuestas a pagar por ser atendidas en ellas. Además, imponen la restricción de que todos los vehículos que la visitan lo hagan de forma coordinada, es decir, llegando todos en la misma ventana de tiempo. Por limitaciones de capacidad, sincronización y costes, el transportista debe seleccionar los clientes que va a atender y diseñar las rutas de recogida. En su estudio, \citet{Shao2020} proponen un mecanismo de sincronización basado en subastas, donde el transportista actúa como subastador y los clientes pujan por los servicios de recogida, incorporando ventanas de tiempo en sus ofertas. Para abordar este problema, los autores presentan un algoritmo VNTS de dos capas que combina la Búsqueda por Entornos Variables, para la asignación de las ofertas, y la Búsqueda Tabú, para la construcción de las rutas. 

Sin embargo, el modelo de \citet{Shao2020} hace simplificaciones poco realistas para la validez de sus experimentos computacionales. En primer lugar, se considera que todas las empresas requieren la recogida de residuos de todos los tipos, lo que no es previsible que ocurra en la práctica. Asimismo, asumen que las empresas generan la misma cantidad de residuos, independientemente del tipo, lo que es muy poco probable.

En este trabajo realizamos una generalización más realista, donde los clientes pueden generar varios tipos de residuos en cantidades variables no negativas, evitando así la homogeneización en los datos. Un cliente puede, por ejemplo, generar residuos de tres tipos, pero otro solo generarlos de dos. Esto introduce complicaciones adicionales en el modelo, siendo la más significativa el hecho de que no existe un número fijo de vehículos que visiten a los clientes seleccionados para ser atendidos. En el modelo de \citet{Shao2020}, a los clientes seleccionados llega el mismo número de vehículos de recogida. Además, en su modelo, las cantidades de residuos a recoger en un cliente son todas iguales. Estos hechos simplifican de tal modo el problema que, en realidad, para dar solución al mismo, basta con planificar las rutas para un residuo y replicarlas para el resto. En nuestro modelo, las rutas diseñadas adoptan formas más diversas.

Para resolver este problema, proponemos un algoritmo híbrido GRASP+RVND en el que, en un esquema multiarranque, se mejoran las soluciones construidas con un Procedimiento de Búsqueda Adaptativa Aleatoria Adaptativa Voraz (GRASP) (\citet{Resende2019}) con un método de Descenso por Entornos Variables Aleatorios (RVND) (\citet{Hansen2019}). Los resultados computacionales demuestran que GRASP+RVND obtiene soluciones de alta calidad que mejoran las obtenidas al resolver el modelo matemático con Gurobi en problemas de mayor tamaño. 

El resto del artículo se estructura como sigue: en la Sección \ref{sec:despro} se describe el problema y se presenta un ejemplo ilustrativo; en la Sección \ref{sec:metsol} se detalla el algoritmo GRASP+RVND; en la Sección \ref{sec:expcom} se analizan los resultados computacionales; y en la Sección \ref{sec:conlinfut} se presentan las conclusiones y futuras líneas de investigación.


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Descripción del problema}\label{sec:despro}

Se considera una red de recogida de residuos compuesta por un único transportista y varios clientes que generan distintos tipos de residuos. El transportista dispone de una flota homogénea de vehículos especializados en cada tipo de residuo con los que presta el servicio de recogida. Si un cliente genera más de un tipo de residuo, varios vehículos deberán visitarlo. El tamaño de la flota es fijo y la cantidad de residuos generados por cada cliente es conocida de antemano. La cantidad generada es siempre inferior a la capacidad de los vehículos, lo que permite que un mismo vehículo pueda visitar a múltiples clientes hasta alcanzar su límite de capacidad. Para que la recogida interfiera lo menos posible en la operativa diaria de los clientes, todos los vehículos que los visiten deben llegar en la misma ventana de tiempo. Debido a las limitaciones de flota, capacidad total o rentabilidad, es posible que algunos clientes no sean atendidos, por lo que corresponde al transportista decidir qué clientes atenderá.

Los clientes expresan su demanda y preferencia horaria mediante pujas, pudiendo presentar varias. Cada puja indica una ventana de tiempo y el precio correspondiente que el cliente está dispuesto a pagar. El cliente asignará la puja más alta a la franja horaria que considere idónea para la recolección de sus residuos. Si su puja resulta ganadora, será atendido en la ventana de tiempo correspondiente por todos los tipos de vehículos necesarios. En este sistema, la empresa de transporte actúa como subastador, seleccionando las pujas ganadoras con el objetivo de maximizar su beneficio, definido como la diferencia entre el valor total de las pujas ganadoras y el coste de transporte asociado a la recolección de los residuos.

El objetivo es maximizar el beneficio de la empresa de transporte bajo cuatro restricciones naturales: la capacidad limitada de los vehículos, el tamaño de la flota disponible, las ventanas de tiempo establecidas en las pujas y la sincronización en la atención a cada cliente. Con este contexto, el problema se clasifica como un Problema de Rutas de Vehículos Capacitado con Ventanas de Tiempo y Sincronización; es decir, se trata de un problema NP-difícil. Esto se deduce del hecho de que el VRP puede reducirse a una formulación del Problema del Viajante de Comercio, uno de los problemas de optimización combinatoria más conocidos y que se sabe que es NP-difícil, lo que implica que no se conoce un algoritmo eficiente para resolver todas sus instancias de manera óptima.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{figure}[htbp]
    \centering
    \resizebox{\textwidth}{!}{
        \begin{tikzpicture}
            % Nodes for customers (Encapsulating name + blocks in a box)
            \node (C1) at (-5, 1.8) {Cliente $1$};
            \node (C2) at (-4.5, -1.5) {Cliente $2$};
            \node (C3) at (-2.1, 3.3) {Cliente $3$};
            \node (C4) at (0, -2.3) {Cliente $4$};
            \node (C5) at (4.5, -2.5) {Cliente $5$};
            \node (C6) at (4.5, 1.9) {Cliente $6$};
            \node (C7) at (4.5, 4.3) {Cliente $7$};

            % Depósito
            \node[inner sep=10pt] (WD) at (0, 1) {Depósito};

            % Blocks inside customer boxes
            \node[draw, fill=dgreen!20] (C1A) at ([yshift=0.25cm, xshift=-0.575cm]C1.north) {$A$};
            \node[draw, fill=dorange!20] (C1B) at ([yshift=0.25cm]C1.north) {$B$};
            \node[draw, fill=dpurple!20] (C1C) at ([yshift=0.25cm, xshift=0.575cm]C1.north) {$C$};
        
            \node[draw, fill=dpurple!20] (C2C) at ([yshift=0.25cm]C2.north) {$C$};
        
            \node[draw, fill=dgreen!20] (C3A) at ([yshift=0.25cm]C3.north) {$A$};
        
            \node[draw, fill=dgreen!20] (C4A) at ([yshift=0.25cm, xshift=-0.3cm]C4.north) {$A$};
            \node[draw, fill=dpurple!20] (C4C) at ([yshift=0.25cm, xshift=0.3cm]C4.north) {$C$};
        
            \node[draw, fill=dorange!20] (C5B) at ([yshift=0.25cm, xshift=-0.3cm]C5.north) {$B$};
            \node[draw, fill=dpurple!20] (C5C) at ([yshift=0.25cm, xshift=0.3cm]C5.north) {$C$};
        
            \node[draw, fill=dgreen!20] (C6A) at ([yshift=0.25cm, xshift=-0.575cm]C6.north) {$A$};
            \node[draw, fill=dorange!20] (C6B) at ([yshift=0.25cm]C6.north) {$B$};
            \node[draw, fill=dpurple!20] (C6C) at ([yshift=0.25cm, xshift=0.575cm]C6.north) {$C$};
        
            \node[draw, fill=dgreen!20] (C7A) at ([yshift=0.25cm, xshift=-0.575cm]C7.north) {$A$};
            \node[draw, fill=dorange!20] (C7B) at ([yshift=0.25cm]C7.north) {$B$};
            \node[draw, fill=dpurple!20] (C7C) at ([yshift=0.25cm, xshift=0.575cm]C7.north) {$C$};

            % Fit nodes (Group customer + blocks)
            \node[fit=(C1)(C1A)(C1B)(C1C)] (G1) {};
            \node[fit=(C2)(C2C)] (G2) {};
            \node[fit=(C3)(C3A)] (G3) {};
            \node[fit=(C4)(C4A)(C4C)] (G4) {};
            \node[fit=(C5)(C5B)(C5C)] (G5) {};
            \node[fit=(C6)(C6A)(C6B)(C6C)] (G6) {};
            \node[fit=(C7)(C7A)(C7B)(C7C)] (G7) {};

            % Draw routes            
            \draw[->, dgreen, dotted, very thick] ($(WD.west)+(0,0.3)$) -- ($(G1.east)+(0,0.3)$);
            \draw[->, dorange, dashed] ($(WD.west)+(0,0.1)$) -- ($(G1.east)+(0,0.1)$);
            \draw[<-, dorange, dashed] ($(WD.west)+(0,-0.1)$) -- ($(G1.east)+(0,-0.1)$);
            \draw[->, dpurple] ($(WD.west)+(0,-0.3)$) -- ($(G1.east)+(0,-0.3)$) node[black, midway, sloped, below] {\small 36min};

            \draw[->, dpurple] (G1) -- (G2) node[black, midway, sloped, above] {\small 33min};
            \draw[->, dpurple] ($(G2.north)+(0.5,0)$) -- ($(WD.south)+(-0.8,0)$) node[black, midway, sloped, above] {\small 35min};

            \draw[->, dgreen, dotted, very thick] ($(G1.east)+(0,0.4)$) -- ($(G3.south)+(-0.6, 0)$) node[black, midway, sloped, below] {\small 22min};
            \draw[->, dgreen, dotted, very thick] (G3) -- ($(WD.north)+(-0.8, 0)$) node[black, midway, sloped, below] {\small 31min};
        
            \draw[->, dgreen, dotted, very thick] ($(WD.north)+(0.8,0)$) -- ($(G7.west)+(0,-0.2)$) node[black, midway, sloped, below] {\small 42min};
            \draw[->, dgreen, dotted, very thick] ($(G7.south)+(-0.2,0)$) -- ($(G6.north)+(-0.2,0)$) node[black, midway, sloped, below] {\small 25min};
            \draw[->, dgreen, dotted, very thick] ($(G6.west)+(0,0.2)$) -- ($(WD.east)+(0,0)$) node[black, midway, sloped, below] {\small 32min};
        
            \draw[->, dorange, dashed] ($(WD.north)+(0.6,0)$) -- (G7.west);
            \draw[->, dorange, dashed] (G7.south) -- (G6.north);
            \draw[->, dorange, dashed] (G6.south) -- (G5.north) node[black, midway, sloped, above] {\small 35min};
            \draw[->, dorange, dashed] ($(G5.west)+(0,0.4)$) -- ($(WD.south)+(0.8,0)$) node[black, midway, sloped, above] {\small 35min};
        
            \draw[->, dpurple] ($(WD.north)+(0.4,0)$) -- ($(G7.west)+(0,0.2)$);
            \draw[->, dpurple] ($(G7.south)+(0.2,0)$) -- ($(G6.north)+(0.2,0)$);
            \draw[->, dpurple] ($(G6.south)+(0.2,0)$) -- ($(G5.north)+(0.2,0)$);
            \draw[->, dpurple] ($(G5.west)+(0,0.2)$) -- ($(WD.south)+(0.6,0)$);

            % Pricing tables
            \node[above=0.1cm of G1, xshift=-0.5cm, yshift=-0.2cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    \rowcolor{gray!30} $08$:$00$--$09$:$00$ & $270$€ \\
                    \hline
                    $09$:$00$--$10$:$00$ & $240$€ \\
                    \hline
                    $10$:$00$--$12$:$00$ & $150$€ \\
                    \hline
                \end{tabular}
            };

            \node[below=0.1cm of G2, xshift=-0.5cm, yshift=0.3cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    $08$:$00$--$10$:$00$ & $120$€ \\
                    \hline
                    \rowcolor{gray!30} $10$:$00$--$12$:$00$ & $90$€ \\
                    \hline
                    $12$:$00$--$14$:$00$ & $45$€ \\
                    \hline
                \end{tabular}
            };

            \node[above=0.1cm of G3, xshift=-0.5cm, yshift=-0.2cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    \rowcolor{gray!30} $08$:$00$--$10$:$00$ & $150$€ \\
                    \hline
                    $10$:$00$--$12$:$00$ & $90$€ \\
                    \hline
                    $12$:$00$--$14$:$00$ & $60$€ \\
                    \hline
                \end{tabular}
            };

            \node[above=0.1cm of G4, xshift=-0.5cm, yshift=-0.2cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    $07$:$30$--$09$:$00$ & $90$€ \\
                    \hline
                    $09$:$00$--$12$:$00$ & $60$€ \\
                    \hline
                    $12$:$00$--$13$:$30$ & $90$€ \\
                    \hline
                \end{tabular}
            };

            \node[right=0.1cm of G5, xshift=-0.2cm, yshift=0.25cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    $08$:$00$--$09$:$30$ & $210$€ \\
                    \hline
                    $09$:$00$--$10$:$30$ & $150$€ \\
                    \hline
                    \rowcolor{gray!30} $10$:$30$--$13$:$00$ & $90$€ \\
                    \hline
                \end{tabular}
            };

            \node[right=0.1cm of G6, xshift=-0.2cm, yshift=0.25cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    $07$:$00$--$09$:$00$ & $150$€ \\
                    \hline
                    \rowcolor{gray!30} $09$:$00$--$10$:$00$ & $165$€ \\
                    \hline
                    $10$:$00$--$14$:$00$ & $45$€ \\
                    \hline
                \end{tabular}
            };

            \node[right=0.1cm of G7, xshift=-0.2cm, yshift=0.25cm] (T1) {
                \renewcommand{\arraystretch}{1.1}
                \begin{tabular}{|c|c|}
                    \hline
                    \rowcolor{gray!30} $07$:$30$--$08$:$00$ & $300$€ \\
                    \hline
                    $08$:$00$--$09$:$00$ & $165$€ \\
                    \hline
                    $09$:$00$--$11$:$00$ & $60$€ \\
                    \hline
                \end{tabular}
            };

        \end{tikzpicture}
    }
    \caption{Ejemplo ilustrativo del problema de recogida de residuos.}
    \label{fig:ejemplo}
\end{figure}
\vspace{\baselineskip}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

La Figura \ref{fig:ejemplo} ilustra un ejemplo ilustrativo del problema de recogida de residuos con múltiples ventanas de tiempo y sincronización en los puntos de recogida (clientes). Supongamos que el transportista dispone de dos vehículos por tipo de residuo y que el tiempo de servicio en cada punto de recogida es homogéneo e igual a $90$ minutos. La jornada laboral comienza a las $07$:$00$ y finaliza a las $14$:$00$ en el depósito, con un coste de transporte equivalente a $1$€ por unidad de distancia recorrida. En el grafo de la Figura \ref{fig:ejemplo} se representa el tiempo de viaje entre el depósito y los clientes, así como entre estos entre sí. El tiempo de viaje entre el depósito y el cliente $4$ es igual a $28$ minutos. La sincronización obliga a iniciar el servicio antes de que finalice la ventana de tiempo seleccionada. Si un vehículo llega a un cliente antes del inicio de la franja horaria, debe esperar a su apertura, contemplándose así tiempos de espera. 

En este ejemplo, la red consta de de siete clientes que requieren el servicio de recogida de residuos. Cada uno propone tres ventanas de tiempo, asociando una puja a cada una según su conveniencia y flexibilidad. El transportista solamente selecciona una por cliente. Así, de las ventanas propuestas por el cliente $1$, el transportista elige la franja [$08$:$00$--$09$:$00$], lo que le genera unos ingresos de $270$€. De los tres vehículos necesarios para atenderlo, el encargado de recoger el residuo de tipo $B$ regresa al depósito tras la recogida, pues no hay otros clientes que requieran ese servicio sin generar costes de transporte superiores al posible beneficio. El resto de vehículos continúa operando antes de regresar al depósito, de tal manera que uno atiende al cliente $2$ para recoger el residuo de tipo $C$, y el otro atiende al cliente $3$ para el residuo de tipo $A$. Nótese que el cliente $3$ se encuentra lo suficientemente cerca del cliente $1$ como para ser atendido en su ventana de tiempo con mayor puja, mientras que para el cliente $2$ se debe optar por la segunda mejor puja para mantener la factibilidad de la solución. 

Por otro lado, nótese que el cliente $4$ no es atendido pese a estar relativamente cerca del depósito, ya que los gastos de transporte superan su mayor puja. Para recoger sus residuos, sería necesario enviar dos vehículos directamente desde el depósito, uno por cada tipo de residuo, con un coste total de $112$€, superior a su mayor puja de $90$€. Las pujas seleccionadas por el transportista le reportan unas ganancias de $1065$€, mientras que los costes de transporte ascienden a $638$€. Con esta solución, el transportista obtiene unos beneficios de $448$€.

Sean $C = \{ 1, 2, \ldots, \lvert C \rvert \}$ un conjunto de clientes, $W = \{ 1, 2, \ldots, \lvert W \rvert \}$ un conjunto de tipos de residuos y $V^w = \{ 1, 2, \ldots, |V^w| \}$ un conjunto de vehículos para el tipo de residuo $w \in W$. Cada cliente $i \in C$ tiene un conjunto de ventanas de tiempo $T_i = \{ 1, 2, \ldots, \lvert T_i \rvert \}$ determinadas por él mismo. Se denota por $p_i^t$ la ganancia obtenida si el cliente $i \in C$ es atendido en la ventana de tiempo $t \in T_i$; es decir, existe una asignación factible para el cliente $i \in C$ en alguna ruta que satisface todas las restricciones del problema en su ventana $t \in T_i$. El transportista debe determinar un conjunto de rutas que atiendan al subconjunto de clientes factibles garantizando que se cumplan las restricciones de factibilidad y sincronización con el propósito de maximizar el beneficio. Para ello, se debe balancear el valor de las ganancias obtenidas con el valor del coste de transporte que surge del servicio dado a los clientes. Nótese que, a diferencia de las ganancias, el coste de transporte depende de la cantidad de tipos de residuos que se deben recoger en la ubicación de cada cliente. 

Sean $\tau_{ij}$ el coste de transporte entre los nodos $i,j \in N = C \cup \{ 0 \}$, donde $\{ 0 \}$ representa el depósito, y $z_i^{vw}$ el tiempo en el que el vehículo $v \in V^w$ comienza a dar su servicio al cliente $i \in C$ para recoger el residuo de tipo $w \in W$. Sean $x_{ij}^{vw} \in \{0, 1\}$ e $y_i^t \in \{0, 1\}$ las variables de decisión que indican si el arco de ruta que une a los nodos $i, j \in N$ seleccionado en la solución para el itinerario de los vehículos asociados al residuo $w \in W$ y si el cliente $i \in C$ es atendido en su ventana de tiempo $t \in T_i$, respectivamente.

Para garantizar la factibilidad y coherencia del plan de rutas de recogida de residuos se imponen las siguientes restricciones: cada cliente puede tener una puja aceptada a lo sumo entre las disponibles \eqref{eq:r1}; si se acepta una puja, deben recogerse todos los tipos d residuos solicitados, asegurando que cada tipo de residuo se recoja solo una vez \eqref{eq:r2}; cada vehículo asignado a al menos un cliente debe iniciar y finalizar su recorrido en el deposito \crefrange{eq:r3}{eq:r4}; si un vehículo llega a un cliente, debe continuar su ruta hacia otro destino \eqref{eq:r6}; la cantidad total de residuos transportados por un vehículo no puede superar su capacidad máxima \eqref{eq:r7}; todos los vehículos comienzan su servicio al inicio del horizonte de planificación \eqref{eq:r8}; la hora de llegada a cada cliente debe considerar tanto el tiempo de viaje como el de servicio \eqref{eq:r9}; la llegada al depósito y a otros puntos también debe cumplir con relaciones temporales consistentes \eqref{eq:r10}; cada vehículo debe respetar las ventanas de tiempo de las pujas aceptadas, asegurando que las llegadas se produzcan dentro del periodo especificado \eqref{eq:r11}. 

Por lo tanto, el problema de optimización resultante se formula como un modelo de programación entera, cuyo objetivo es maximizar el beneficio neto de la empresa de transporte sujeto a todas las restricciones anteriores \eqref{eq:o}, donde el primer término representa los ingresos totales obtenidos por atender a los clientes dentro de sus ventanas de tiempo seleccionadas, mientras que el segundo término corresponde a los costes de transporte asociados a todos los tipos de residuos y vehículos.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{align} 
    % Objective Function
    & \max \sum_{i \in C} \sum_{t \in T_i} p_i^t y_i^t - \sum_{w \in W} \sum_{v \in V} \sum_{i \in N} \sum_{j \in N} \tau_{ij}x_{ij}^{vw} \label{eq:o} \\
    & s.a: \nonumber \\
    % Selected bid
    & \sum_{t \in T_i} y_i^t \leq 1, \quad \forall i \in C \label{eq:r1} \\
    % Satisfied demand
    & \sum_{v \in V^w} \sum_{j \in N} x_{ij}^{vw} = \sum_{t \in T_i} y_i^t, \quad \forall i \in C, \, w \in W, \, d_i^w > 0 \label{eq:r2} \\
    % Start depot
    & \sum_{j \in N} x_{0j}^{vw} = 1, \quad \forall w \in W, \, v \in V^w \Longleftrightarrow \exists i \in C \colon d_i^w > 0 \label{eq:r3} \\
    % Return depot
    & \sum_{i \in N} x_{i,|C|+1}^{vw} = 1, \quad \forall w \in W, \, v \in V^w \Longleftrightarrow \exists i \in C \colon d_i^w > 0 \label{eq:r4} \\
    % Route flow
    & \sum_{i \in N} x_{ih}^{vw} = \sum_{j \in N} x_{hj}^{vw}, \quad \forall h \in C, \, w \in W, \, v \in V^w \label{eq:r6} \\
    % Vehicle capacity
    & \sum_{i \in C} d_i^w \cdot \sum_{j \in N} x_{ij}^{vw} \leq Q^w, \quad \forall w \in W, \, v \in V^w \label{eq:r7} \\
    % Service start depot
    & z_0^{vw} = 0, \quad \forall w \in W, \, v \in V^w \label{eq:r8} \\
    % Departure time
    & z_i^{vw} + \tau_{ij} + s_i - M \cdot (1 - x_{ij}^{vw}) \leq z_j^{vw}, \quad \forall i,j \in C, \, i \neq j, \, w \in W, \, v \in V^w \, d_i^w > 0 \label{eq:r9} \\
    % Arrival time
    & z_0^{vw} + \tau_{ij} - M \cdot (1 - x_{ij}^{vw}) \leq z_j^{vw}, \quad \forall j \in N, \, i \neq j, \, w \in W, \, v \in V^w \, d_i^w > 0 \label{eq:r10} \\
    % Time flow
    & L_i^t - M \cdot (1 - y_i^t) \leq z_i^{vw} \leq U_i^t + M \cdot (1 - y_i^t), \quad \forall i \in C, \, t \in T_i, \, w \in W, \, v \in V^w \label{eq:r11} \\
    % Domain of decision variables
    & x_{ij}^{vw} \in \{0,1\}, \quad \forall i,j \in N, \, w \in W, \, v \in V^w \, d_i^w > 0 \label{eq:r12} 
\end{align}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Método de solución}\label{sec:metsol}
Para tratar el problema descrito, proponemos una heurística híbrida que construye soluciones siguiendo una estrategia GRASP que luego son mejoradas con RVND. La fase constructiva de GRASP garantiza que los clientes seleccionados sean atendidos para todos los residuos que generan. Sea $R^w = \{ r^w_1, r^w_2, \ldots, r^w_{|V^w|} \}$ el conjunto de rutas asociadas al residuo $w$, con $r^w_v$ la ruta asociada al vehículo $v$. El proceso se inicia escogiendo al azar un tipo de residuo $w' \in W$ y considerando el conjunto de clientes $C^{w'}$ con demanda positiva para este. Para cada uno de estos clientes, se evalúa su factibilidad y beneficio en las rutas actuales de $R^{w'}$. Se genera una lista restringida $C_k^{w'}$ con los $k$ clientes más prometedores. De esta lista, se selecciona aleatoriamente uno para su mejor inserción y se añade al conjunto $C'$ de clientes a visitar; en caso contrario, se descarta. Este proceso se repite hasta agotar los candidatos.

Tras definir el subconjunto de clientes $C'$, se construyen rutas para los tipos de residuos restantes. Para cada residuo $w \in W \setminus \{w'\}$, se filtran los clientes del conjunto común que tienen demanda positiva para ese residuo ($d_i^w > 0$). De esta manera, se garantiza que cada cliente sea atendido para todos los tipos de residuos que demanda, cumpliendo con la restricción principal del problema. Para estos clientes, se construyen rutas factibles $r_v^w \in R^w$ siguiendo los criterios de inserción descritos anteriormente.

Luego, una solución factible $s = \bigcup_{w \in W} R^w$ del problema está representada por un itinerario factible para cada tipo de residuo implicado; es decir, un conjunto de rutas en el que, si un cliente aparece en alguna ruta de un tipo de residuo, debe aparecer también en las rutas correspondientes a los demás residuos para los que genere demanda. El Algoritmo \ref{alg:GRASP} describe este procedimiento. Nótese que en la heurística diseñada para generar una solución inicial no se permite la violación de ninguna restricción; es decir, al seleccionar un nuevo cliente para insertar en una ruta este debe de satisfacer tanto las restricciones de ventanas de tiempo como su demanda no sobrepasar la capacidad del vehículo asociado a la ruta actual.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% \nolinenumbers
\setlength{\algomargin}{1.5em
\begin{algorithm}[H]
    \caption{Marco de la fase constructiva del GRASP}
    \label{alg:GRASP}
    \DontPrintSemicolon
    \KwIn{$C$, conjunto de clientes; $W$, conjunto de residuos; $V^w$, conjunto de vehículos $v$ para el residuo $w$; $R^w$, conjunto de rutas para el residuo $w$}
    \KwOut{$s$, solución con rutas por tipo de residuo}    
    Seleccionar $w' \in W$ un tipo de residuo al azar;
    Fijar $k \in \mathbb{N}$\;
    $C' \gets \emptyset$;
    $C^{w'} \gets \{i \in C \mid d_i^{w'} > 0 \}$; $R^{w'} = \emptyset$ \;
    \While{$C^{w'} \neq \emptyset \wedge \exists i \in C^{w'}$ con inserción factible en alguna ruta $r_v^{w'} \in R^{w'}$}{
        $C_k^{w'} \gets k$ clientes de $C^{w'}$ de mayor beneficio que sean factibles\;
        Seleccionar al azar $i \in C_k^{w'}$ e insertar en $r^{w'}_v \in R^{w'}$\;
        $C' \gets C' \cup \{i\}$\;
        $C^{w'} \gets C^{w'} \setminus \{i\}$\;      
    }    
    \ForEach{$w \in W \setminus \{w'\}$}{
        $C^w \gets \{i \in C' \mid d_i^w > 0 \}$\;        
        Construir rutas $r^w_v \in R^w$ factibles para $C^w$ usando vehículos $v \in V^w$\;
    }
    \Return{$s = \bigcup_{w \in W} R^w$}\;
\end{algorithm}
}
\vspace{\baselineskip}
% \linenumbers
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


%\section{Búsquedas locales}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%% Búsquedas locales ------------------------------------------------------------------------%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
Los métodos de búsqueda local mejoran iterativamente una solución explorando su entorno hasta alcanzar un óptimo local. En problemas de rutas de vehículos, las estructuras de entorno más comunes incluyen: intercambiar las posiciones de dos clientes en la misma ruta o en rutas diferentes, reubicar un cliente en su ruta o hacia otra, o aplicar movimientos 2-opt.

En el problema abordado en el presente trabajo, algunas demandas de clientes pueden no ser atendidas dentro del horizonte de planificación debido a las restricciones impuestas por la limitación en el número de vehículos disponibles y en la capacidad total de los mismos. En consecuencia, se implementan, además, estructuras de entorno que consideran la reinserción de clientes no presentes en la solución, la posibilidad de excluir clientes de la solución, y el intercambio entre clientes omitidos y clientes que forman parte de la solución. Además, dado un par de clientes, pueden darse diversas combinaciones en su asignación a las rutas; es decir, pueden compartir la misma ruta para un residuo, estar en rutas distintas para otros o, incluso, no ser incluidos en ciertas rutas si no generan demanda para determinados residuos. Este hecho complica el proceso de verificación de la factibilidad de los movimientos. En definitiva, los movimientos considerados en este trabajo son: reinserción intra-ruta, reinserción inter-rutas, reinserción de clientes excluidos, intercambio intra-ruta, intercambio inter-rutas, intercambio con clientes excluidos y movimiento $2$-opt. A continuación se describen brevemente las mismas.

Un movimiento de reinserción intra-ruta consiste en reubicar un cliente dentro de su propia ruta. Para ello, se elimina de su posición original y se inserta en la mejor ubicación factible, garantizando que se respeten las restricciones de tiempo. Si resulta beneficioso para la solución, se permite ajustar la ventana horaria del cliente, siempre que las rutas a la que pertenezca el cliente permanezcan factibles. De manera similar, un movimiento de reinserción inter-ruta traslada un cliente a una ruta diferente, y un movimiento de reinserción de clientes excluidos reintroduce clientes previamente eliminados en la mejor ruta disponible. En ambos casos, además de las restricciones de tiempo, se debe garantizar que no se exceda la capacidad del vehículo.

Un movimiento de intercambio intra-ruta consiste en intercambiar las posiciones de dos clientes dentro de una misma ruta. Para ello, se elimina a un cliente de su posición original y se intercambia con otro en la mejor ubicación factible, garantizando que se respeten las restricciones de tiempo. A diferencia de los movimientos de reinserción, no se permite ajustar la ventana horaria del cliente. De manera análoga, un movimiento de intercambio inter-rutas afecta a clientes de rutas distintas, y un movimiento de intercambio con clientes excluidos introduce a un cliente previamente excluido en una ruta a cambio de otro que es retirado. En estos dos casos, también se debe respetar la restricción de capacidad del vehículo.

Por último, un movimiento $2$-opt consiste en modificar la estructura de una ruta invirtiendo la secuencia de un subconjunto de clientes. Este procedimiento busca reducir la distancia recorrida eliminando cruces innecesarios en la trayectoria, respetando las restricciones de ventanas de tiempo, sin permitir cambiar la franja horaria de los clientes afectados.

Todas estas estructuras de entornos se integran en un esquema RVND, un algoritmo que se deriva del estándar del Descenso por Entornos Variables, que selecciona al azar una de las estructuras de entornos disponibles y aplica la búsqueda local con dicha estructura hasta alcanzar un óptimo local. Si este óptimo mejora la solución actual, se actualiza la mejor solución y se deshabilita la estructura de entornos empleada. En este trabajo se permite la reactivación de las otras estructuras de entornos que no mejoraron la solución en iteraciones previas. No se permite seleccionar consecutivamente la misma estructura de entornos dado que, al haberse alcanzado el óptimo local en dicho entorno, repetirla resultaría en la convergencia al mismo punto. Este proceso se describe en el Algoritmo \ref{algo:RVND} y termina cuando ninguna de las estructuras de entornos disponibles logra mejorar la solución actual. De esta manera, se obtiene un óptimo local con respecto a todas las estructuras de entornos disponibles, superior al construido con el método GRASP.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% \nolinenumbers
{\setlength{\algomargin}{1.5em}
\begin{algorithm}[H]
    \caption{Marco general del RVND}
    \label{algo:RVND}
    \DontPrintSemicolon
    \KwIn{$s$, solución inicial; $\mathcal{N}$, conjunto de estructuras de entornos}
    \KwOut{$s^*$, solución mejorada }    
    $s^* \gets s$; 
    $\mathcal{N}' \gets \mathcal{N}$\;    
    \While{$s^* \leq s' \; \land  \; \mathcal{N}' \neq \emptyset$}{
        Seleccionar aleatoriamente una estructura de entornos $N \in \mathcal{N}$\;
        $s' \gets$ Aplicar búsqueda local de $N$ sobre $s^*$\;
        \eIf{$f(s') > f(s^*)$}{
            $s^* \gets s'$\;
            $\mathcal{N'} \gets \mathcal{N} \setminus \{N\}$\;
        }{
            $\mathcal{N}' \gets \mathcal{N}' \setminus \{N\}$\;
        }
    }
    \Return{$s^*$}\;
\end{algorithm}
}
\vspace{\baselineskip}
% \linenumbers
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Experiencia computacional}\label{sec:expcom}

Para evaluar la validez de nuestra propuesta, comparamos los resultados de GRASP+RVND con los obtenidos al resolver el modelo matemático \eqref{eq:o} con Gurobi 11.0.3 en Python para instancias pequeñas. Los experimentos computacionales se realizaron en un sistema Windows de 64 bits con un procesador Intel Core i5-12500T (2GHz) y 16GB de RAM.

Para facilitar una comparación detallada, se diseñó un conjunto de instancias basado en las de Solomon para el VRP (\citet{Solomon1997}), seleccionando nueve instancias: R$101$, R$102$ y R$103$, con clientes distribuidos aleatoriamente; C$101$, C$102$ y C$103$, con clientes agrupados; RC$101$, RC$102$ y RC$103$, que combinan ambos esquemas.

Las instancias de Solomon incluyen información sobre la ubicación del depósito y los clientes, su demanda, las ventanas de tiempo, la capacidad de los vehículos y el tamaño de la flota. Para adaptar estas instancias a nuestro problema de sincronización múltiple, se realizaron las siguientes modificaciones: se consideran hasta tres tipos de residuos simultáneamente, asignando demanda mediante una distribución uniforme discreta no negativa acotada superiormente por el valor original; se crean ventanas de tiempo de sincronización, duplicando y reduciendo a la mitad la duración original; cada cliente pueda presenta tres pujas distintas, generadas aleatoriamente entre $100$ y $500$, asignando la mayor puja a la ventana más corta y la menor a la más amplia; por último, se dispone de una flota de $20$ vehículos con capacidad homogénea de $200$ unidades por tipo de residuo.

Las instancias generadas se nombran siguiendo el formato ``instancia base de Solomon''--``número de clientes''--``número de tipos de residuos''. Por ejemplo, ``C$101$--$10$--$3$'' indica que se usa la instancia C$101$, con los diez primeros clientes y tres tipos de residuos.
%\subsection{Comparativa de Gurobi y GRASP+RVND}

{\bf Comparativa entre Gurobi y GRASP+RVND}

La Tabla \ref{tab:resultados} muestra la comparación entre la resolución del modelo de programación entera con \citet{Gurobi} y GRASP+RVND. La primera columna de esta tabla indica el nombre de la instancia. A continuación, se reportan: el valor objetivo obtenido con Gurobi, el \textit{gap} con respecto a la cota superior y el tiempo de ejecución, donde se fijó un límite de $7200$ segundos. Las tres últimas columnas indican el mejor valor objetivo alcanzado con GRASP+RVND en $5$ ejecuciones de $1000$ iteraciones cada una, la desviación con respecto a Gurobi y el tiempo de ejecución.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{table}[htbp]
    \centering
    \caption{Resultados de comparación de algoritmos}
    \label{tab:resultados}
    \begin{tabular}{lrrrrrr}
        \toprule
         & \multicolumn{3}{c}{\textbf{Gurobi}} & \multicolumn{3}{c}{\textbf{GRASP+RVND}} \\
        \midrule
        Instancia & Objetivo & Gap (\%) & Tiempo (s) & Objetivo & Desv. (\%) & Tiempo (s) \\
        \midrule
        C$101$--$10$--$3$  &  $3238,36$  &  $0,00$  &     $8,69$  &  $3238,36$  &  $0,00$  &  $0,001$  \\
        C$102$--$10$--$3$  &  $3203,79$  &  $1,78$  &  $7200,00$  &  $3196,80$  &  $0,22$  &  $0,001$  \\
        C$103$--$10$--$3$  &  $3195,25$  &  $1,09$  &  $7200,00$  &  $3166,59$  &  $0,90$  &  $0,001$  \\
        R$101$--$10$--$3$  &  $2656,57$  &  $0,00$  &    $23,82$  &  $2652,61$  &  $0,15$  &  $0,001$  \\
        R$102$--$10$--$3$  &  $2721,69$  &  $0,00$  &  $1534,05$  &  $2709,18$  &  $0,46$  &  $0,001$  \\
        R$103$--$10$--$3$  &  $2742,10$  &  $0,00$  &   $506,86$  &  $2739,21$  &  $0,11$  &  $0,001$  \\
        RC$101$--$10$--$3$ &  $2929,04$  &  $0,00$  &   $570,10$  &  $2913,63$  &  $0,53$  &  $0,001$  \\
        RC$102$--$10$--$3$ &  $2911,45$  &  $5,14$  &  $7200,00$  &  $2899,83$  &  $0,40$  &  $0,001$  \\
        RC$103$--$10$--$3$ &  $2888,89$  &  $5,73$  &  $7200,00$  &  $2888,89$  &  $0,00$  &  $0,001$  \\
        C$101$--$15$--$3$  &  $5115,94$ &  $0,00$  &    $92,64$  &  $5115,94$  &  $0,00$  &  $0,001$  \\
        C$102$--$15$--$3$  &  $5041,35$ &  $3,74$  &  $7200,00$  &  $5006,18$  &  $0,70$  &  $0,001$  \\
        C$103$--$15$--$3$  &  $5058,19$ &  $4,00$  &  $7200,00$  &  $5044,00$  &  $0,28$  &  $0,001$  \\
        R$101$--$15$--$3$  &  $4485,46$ &  $0,00$  &  $1230,35$  &  $4427,20$  &  $1,30$  &  $0,001$  \\
        R$102$--$15$--$3$  &  $4612,27$ &  $1,43$  &  $7200,00$  &  $4604,24$  &  $0,17$  &  $0,001$  \\
        R$103$--$15$--$3$  &  $4673,21$ &  $4,72$  &  $7200,00$  &  $4670,85$  &  $0,05$  &  $0,001$  \\
        RC$101$--$15$--$3$ &  $4881,56$ &  $4,12$  &  $7200,00$  &  $4851,81$  &  $0,61$  &  $0,001$  \\
        RC$102$--$15$--$3$ &  $4948,15$ &  $7,29$  &  $7200,00$  &  $4924,44$  &  $0,48$  &  $0,001$  \\
        RC$103$--$15$--$3$ &  $4919,20$ &  $7,69$  &  $7200,00$  &  $4883,14$  &  $0,73$  &  $0,001$  \\
        C$101$--$25$--$3$  &  $9309,11$ &  $0,51$  &  $7021,99$  &  $9130,51$  & $1,92$  &  $0,003$  \\
        C$102$--$25$--$3$  &  $9088,67$ &  $5,69$  &  $7200,00$  &  $9113,18$  & $-0,27$ &  $0,003$  \\
        C$103$--$25$--$3$  &  $9104,25$ &  $5,53$  &  $7200,00$  &  $9113,18$  & $-0,10$ &  $0,003$  \\
        R$101$--$25$--$3$  &  $8302,21$ &  $6,72$  &  $7200,00$  &  $8185,58$  & $1,40$   &  $0,002$  \\
        R$102$--$25$--$3$  &  $8231,07$ &  $9,32$  &  $7200,00$  &  $8237,01$  & $-0,07$  &  $0,005$  \\
        R$103$--$25$--$3$  &  $6003,63$ &  $52,02$ &  $7200,00$  &  $8571,04$  & $-42,76$ &  $0,002$  \\
        RC$101$--$25$--$3$ &  $8543,47$ &  $11,72$ &  $7200,00$  &  $8631,20$  & $-1,03$  &  $0,001$  \\
        RC$102$--$25$--$3$ &  $8754,20$ &   $9,51$ &  $7200,00$  &  $8777,37$  & $-0,26$  &  $0,003$  \\
        RC$103$--$25$--$3$ &  $8612,74$ &  $11,30$ &  $7200,00$  &  $8744,58$  & $-1,53$  &  $0,002$  \\
        \bottomrule
    \end{tabular}
\end{table}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

Se observa que Gurobi alcanza la optimalidad solamente en $6$ de las $27$ instancias, $4$ de ellas con $10$ clientes y otras $2$ con $15$ clientes, lo que evidencia la complejidad de este problema de sincronización múltiple en la recogida de residuos. En contraste, nuestro algoritmo muestra robustez con bajas desviaciones respecto a las soluciones óptimas. Además, supera a Gurobi en casi todas las instancias con $25$ clientes, destacando su desempeño en R$103$-$25$-$3$, donde Gurobi tiene dificultades para aproximarse al óptimo.

El tiempo de ejecución de GRASP+RVND se mantiene bajo a medida que aumenta el número de clientes, sin variaciones significativas según su distribución espacial. En cambio, la precisión de Gurobi depende de la distribución, obteniendo mejores soluciones en instancias con clientes agrupados, mientras que en distribuciones aleatorias la complejidad del problema aumenta.

%\subsection{Resultados para instancias de mayor tamaño}
{\bf Resultados para instancias de mayor tamaño}

La Tabla \ref{tab:rvnd_50_100} presenta los resultados de GRASP+RVND en instancias de $50$ y $100$ clientes, mostrando el mejor valor objetivo y el tiempo de ejecución. No se incluyen resultados de Gurobi ya que no logró encontrar soluciones en un tiempo razonable. Como en la comparativa anterior, el algoritmo GRASP+RVND se ejecuta $5$ veces con un criterio de parada de $1000$ iteraciones por ejecución.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{table}[htbp]
    \centering
    \caption{Resultados del algoritmo GRASP+RVND para instancias con 50 y 100 clientes}
    \label{tab:rvnd_50_100}
    \begin{tabular}{lrrlrr}
        \toprule
        \multicolumn{3}{c}{\textbf{Instancias con 50 clientes}} & \multicolumn{3}{c}{\textbf{Instancias con 100 clientes}} \\
        \midrule
        Instancia & Objetivo & Tiempo (s) & Instancia & Objetivo & Tiempo (s) \\
        \midrule
        C$101$--$50$--$3$  &  $19022,1$  &  $0,321$  & C$101$--$100$--$3$  &  $37041,5$  &  $6,354$ \\
        C$102$--$50$--$3$  &  $18809,6$  &  $0,380$  & C$102$--$100$--$3$  &  $36859,1$  &  $6,403$ \\
        C$103$--$50$--$3$  &  $18783,6$  &  $0,340$  & C$103$--$100$--$3$  &  $36786,7$  &  $6,660$ \\
        R$101$--$50$--$3$  &  $17317,3$  &  $0,318$  & R$101$--$100$--$3$  &  $36315,4$  &  $6,877$ \\
        R$102$--$50$--$3$  &  $17578,3$  &  $0,350$  & R$102$--$100$--$3$  &  $36454,0$  &  $6,372$ \\
        R$103$--$50$--$3$  &  $18030,5$  &  $0,409$  & R$103$--$100$--$3$  &  $36656,4$  &  $6,399$ \\
        RC$101$--$50$--$3$  &  $17443,1$  &  $0,318$  & RC$101$--$100$--$3$  &  $35991,2$  &  $6,185$ \\
        RC$102$--$50$--$3$  &  $17876,2$  &  $0,332$  & RC$102$--$100$--$3$  &  $36106,7$  &  $6,283$ \\
        RC$103$--$50$--$3$  &  $17528,5$  &  $0,334$  & RC$103$--$100$--$3$  &  $35899,9$  &  $6,399$ \\
        \bottomrule
    \end{tabular}
\end{table}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

Se puede apreciar que el tiempo de ejecución de nuestro algoritmo varía poco con la distribución de clientes, aunque crece significativamente con su número, manteniéndose dentro de límites razonables.


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Conclusiones y líneas futuras}\label{sec:conlinfut}

En este trabajo, proponemos un algoritmo híbrido GRASP+RVND para resolver un Problema de Rutas de Vehículos Capacitados con Ventanas de Tiempo y Sincronización en la recogida selectiva de residuos. Aunque nuestro enfoque muestra resultados prometedores, identificamos varias oportunidades de mejora. 

Hemos observado 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 solo 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 estas observaciones, proponemos que las futuras implementaciones consideren una búsqueda local con estructuras de entornos combinadas que gestionen 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 identificar soluciones superiores.


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newpage
\section*{Agradecimientos}

Este trabajo ha sido financiado por la Agencia Estatal de Investigación (España; proyecto PID2019-104410RB-I00/AEI/10.13039/501100011033).

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\bibliography{cvrptws}

\end{document}
