\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{maeb_2025}

% 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,nonatbib]{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

%%%%%%%%%%%%%%%%%%%%%
% NUESTROS
%%%%%%%%%%%%%%%%%%%%%
\usepackage{biblatex}
\addbibresource{refs.bib}
\usepackage{arydshln}

%\usepackage[spanish]{babel}
\usepackage[linesnumbered,norelsize,ruled,vlined]{algorithm2e} 
\usepackage{csquotes} 
\usepackage{amsmath}
\usepackage{graphicx} 
\usepackage{caption} 
\usepackage{float} 

\renewcommand{\algorithmcfname}{Algoritmo}
\renewcommand{\tablename}{Tabla}
\renewcommand{\figurename}{Figura}
\DefineBibliographyStrings{english}{references = {Referencias}}

\renewcommand{\arraystretch}{0.8}
\DeclareMathOperator*{\argmin}{arg\,min}
\DeclareMathOperator*{\argmax}{arg\,max}

\usepackage{svg}
\usepackage{graphicx}
\usepackage{setspace}
\usepackage{arydshln}
\setlength{\arrayrulewidth}{0.1pt}
\usepackage{dashrule}
\usepackage{tablefootnote}



\title{Un algoritmo GRASP para el sistema de remanufactura en tres etapas}

% 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{%
  Teodor A. Diaconescu, Alberto Herrán, J. Manuel Colmenar \\
  Dpto. de Informática y Estadística, Universidad Rey Juan Carlos \\
  C/. Tulip\'{a}n, s/n, M\'{o}stoles, 28933 (Madrid), Spain\\
  \texttt{teodor.diaconescu@urjc.es}\\
  \texttt{alberto.herran@urjc.es}\\
  \texttt{josemanuel.colmenar@urjc.es}
  % Teodor A. Diaconescu \\
  % \thanks{Use footnote for providing further information
  %   about author (webpage, alternative address)---\emph{not} for acknowledging
  %   funding agencies.} \\
  % Dpto. de Informática y Estadística\\
  % Universidad Rey Juan Carlos\\
  % Móstoles, España \\
  % \texttt{teodor.diaconescu@urjc.es} 
  % \And
  % Alberto Herrán \\
  % % \thanks{Use footnote for providing further information
  % %   about author (webpage, alternative address)---\emph{not} for acknowledging
  % %   funding agencies.} \\
  % Dpto. de Informática y Estadística\\
  % Universidad Rey Juan Carlos\\
  % Móstoles, España \\
  % \texttt{alberto.herran@urjc.es} \\
  % \And
  % J. Manuel Colmenar \\ 
  % % \thanks{Use footnote for providing further information
  % %   about author (webpage, alternative address)---\emph{not} for acknowledging
  % %   funding agencies.} \\
  % Dpto. de Informática y Estadística\\
  % Universidad Rey Juan Carlos\\
  % Móstoles, España \\
  % \texttt{josemanuel.colmenar@urjc.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}
Este trabajo aborda el problema de la optimización de sistemas de remanufactura en tres etapas (3T-RSSP), cuyo objetivo es minimizar el tiempo de finalización de los trabajos del sistema (\textit{makespan}). Este tipo de problemas se sitúa en línea con los Objetivos de Desarrollo Sostenible 9 y 12. Para resolver el problema se propone una metaheurística GRASP compuesta por un método constructivo y una búsqueda local que operan en las tres etapas de las instancias del problema. Los resultados experimentales, obtenidos sobre un conjunto de 34 instancias del estado del arte, demuestran que la propuesta GRASP logra un excelente equilibrio entre la calidad de la solución y el tiempo de cómputo, obteniendo el mejor valor promedio para la función objetivo empleando un tiempo de ejecución promedio muy pequeño en comparación con los métodos del estado del arte.
\end{abstract}


\section{Introducción} \label{sec:intro}

El avance tecnológico y el crecimiento del consumo en las últimas décadas ha traído consigo un creciente aumento en el número de productos al final de su vida útil, conocidos como productos EOL (del inglés, \textit{End-Of-Life}). Los dispositivos electrónicos, vehículos o componentes industriales son algunos de estos productos, cuyo volumen no para de crecer, generando problemas en el medio ambiente, la economía y la salud. Ante esta problemática, reconocida globalmente en la Agenda 2030 para el Desarrollo Sostenible de las Naciones Unidas \cite{Agenda2030}, los modelos de economía circular han ganado protagonismo, mitigando estos desafíos para construir un futuro más sostenible \cite{GHISELLINI2016}. Dentro de estos modelos se encuentran los sistemas de remanufactura. Estos sistemas llevan a cabo diferentes procesos para dar mantenimiento y/o devolver los productos EOL a un estado ``como nuevo'', ayudando a reducir la demanda de materias primas, el consumo energético y la generación de residuos. Así, la optimización de los procesos involucrados en este tipo de sistemas es una importante tarea que ataca directamente a los Objetivos de Desarrollo Sostenible ODS 9 (industria, innovación e infraestructura) y ODS 12 (producción y consumo responsables). 

En concreto, este trabajo se centra en los sistemas de remanufactura en tres etapas (desensamblado, reprocesamiento y ensamblado), abreviado como 3T-RSSP (del inglés, \textit{Three-Stage Remanufacturing System Scheduling Problem}), con aplicaciones en la industria automovilística, aerogeneradora o aeroespacial \cite{NGU2020,Ruane2023}. El objetivo del 3T-RSSP es planificar la secuencia de procesamiento de un conjunto de productos, cada uno con varios componentes, en un sistema de remanufactura a través de estas tres etapas, tratando de optimizar una o varias métricas de eficiencia, como pueden ser la energía consumida, el tiempo de finalización de los trabajos (\textit{makespan}) o la reducción en las emisiones de carbono. El 3T-RSSP es un problema que pertenece a la familia de problemas conocida como FSSP (\textit{Flow Shop Scheduling Problem}), donde un conjunto de trabajos debe ser procesado secuencialmente a través de etapas ejecutadas por máquinas en serie \cite{Komaki2019}. En concreto, el 3T-RSSP considera la existencia de múltiples máquinas en paralelo en al menos una de las etapas de procesamiento, como en la variante híbrida del FSSP
%(\textit{Hybrid Flow Shop Scheduling Problem})
\cite{RUIZ2010}. Adicionalmente, el 3T-RSSP también comparte características con el UPMSP (\textit{Unrelated Parallel Machine Scheduling Problem}), ya que las máquinas paralelas, aunque realizan las mismas tareas, no son iguales, por lo que el tiempo de procesado para un mismo producto puede variar en función de la máquina en la que se procese \cite{FANJULPEYRO2019}.

El 3T-RSSP es un problema \textit{NP-Duro} que se ha trabajado desde enfoques tanto exactos como heurísticos. En la literatura se pueden encontrar diferentes variantes del problema en función de las características del sistema y objetivos a optimizar. Kim \textit{et al.} proponen en \cite{Kim2015} uno de los primeros modelos para una versión del 3T-RSSP con una única máquina en las etapas de desensamblado y ensamblado, pero manteniendo múltiples máquinas funcionando en paralelo en la etapa de reprocesamiento. En concreto, resuelven el problema mediante un algoritmo exacto y, adicionalmente, proponen tres heurísticas y una versión de la metaheurística \textit{Iterated Greedy} para resolver instancias de tamaño entre 20 y 80 productos. Por otro lado, Wang \textit{et al.} presentan en \cite{WANG2023b} la posibilidad de operar con varias máquinas en paralelo en las etapas de desensamblado y ensamblado. En particular, proponen un algoritmo genético para resolver instancias que incluyen entre 10 y 40 productos, con el objetivo de minimizar la energía consumida por el sistema. Más adelante, Wang propone en 2024 dos trabajos donde el objetivo es la minimización del \textit{makespan}. En concreto, en el trabajo \cite{WANG2024109257} propone un modelo exacto junto con 18 heurísticas para resolver instancias de tamaños entre 4 y 40 productos, mientras que en \cite{WANG-2.More-2024110379} añade otros cuatro modelos exactos para resolver instancias entre 4 y 200 productos.

En este trabajo se propone la aplicación de la metaheurística GRASP para resolver eficientemente el 3T-RSSP considerando el \textit{makespan} como función objetivo. Para la fase constructiva se utiliza la variante clásica, donde en primer lugar se utiliza una función voraz para seleccionar de una lista los posibles candidatos a formar parte de la solución inicial, y en segundo lugar entra en juego la componente aleatoria. Para la fase de mejora se propone una búsqueda local que explora un vecindario extendido generado a partir de movimientos de intercambio e inserción. La mejor variante del algoritmo propuesto se compara con el estado del arte sobre un total de 34 instancias, obteniendo resultados muy competitivos y reduciendo el tiempo de cómputo en dos órdenes de magnitud.

El resto de este trabajo se estructura de la siguiente forma. En la Sección \ref{sec:desc} se ofrece una descripción formal del problema 3T-RSSP.  La Sección \ref{sec:algoritmica} presenta la propuesta algorítmica para el 3T-RSSP basada en la metaheurística GRASP. La Sección \ref{sec:experimentos} está dedicada a la evaluación experimental de dicha propuesta frente al estado del arte. Finalmente, en la Sección \ref{sec:conclusion}, se resumen las principales conclusiones del trabajo y se proponen futuras líneas de investigación.


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

El 3T-RSSP bajo estudio considera \(n\) productos EOL, cada uno con \(r\) componentes, que llegan a un sistema de remanufactura compuesto por \(d\) máquinas de desensamblado, \(r\) líneas de reprocesamiento (dedicadas a cada uno de los \(r\) componentes) y \(e\) máquinas de ensamblado. Además, se conocen el tiempo de desensamblado de cada producto $p$ en cada máquina de desensamblado $m$, \textit{TD}$_{pm}$, el tiempo de procesado de cada componente $r$ de cada producto $p$ en cada fase $f$ de cada línea de reprocesamiento $r$, \textit{TR}$_{\mathit{prf}}$, y el tiempo de ensamblado de cada producto $p$ en cada máquina de ensamblado $m$, \textit{TE}$_{pm}$.

La Figura \ref{fig:diagramaEjemplo} muestra un ejemplo de este tipo de sistemas, en el que 2 máquinas desensamblan los productos que van llegando al sistema en sus componentes a medida que estas están libres. A continuación, cada componente entra en una línea de reprocesamiento dedicada para ser sometido a los procesos correspondientes. En el ejemplo de la figura, se dispone de una primera línea que realiza tres procesos (por ejemplo, lijado, pintado y pulido), mientras que la segunda línea está dedicada a los componentes que únicamente requieran los dos procesos que dicha línea lleva a cabo. Una vez reprocesados todos los componentes de cada producto, se dispone de 2 líneas de ensamblado para devolver el producto a su nuevo estado tan pronto como alguna de las máquinas esté libre.

%\setlength{\textfloatsep}{0.1cm} 
\begin{figure}[!ht]
    \centering
    \includegraphics[width=1\textwidth]{assets/diagramaEjemplo.pdf}
    \caption{Ejemplo de sistema de manufactura con tres etapas.}
    \label{fig:diagramaEjemplo}
\end{figure}

El objetivo del 3T-RSSP es minimizar el tiempo de remanufactura (\textit{makespan}) de una serie de productos en un sistema con tres etapas como el aquí descrito. Dicho tiempo depende del orden en el que los productos que llegan al sistema se someten a los diferentes procesos en cada una de estas tres etapas. Denotando con $D_m$, $R_m$ y $E_m$, la secuencia ordenada de productos en la \textit{m-ésima} máquina (o línea de reprocesamiento) de cada etapa, desensamblado, reprocesamiento y ensamblado, respectivamente, una solución al problema se puede escribir como $\varphi =\{\pi_D, \pi_R, \pi_E\}$, donde $\pi_D =\{D_1,..., D_d\}$, $\pi_R =\{R_1,..., R_r\}$ y $\pi_E =\{E_1,..., E_e\}$.

Para ilustrar mejor el problema, así como el cálculo de la función objetivo, supóngase que al sistema de la Figura \ref{fig:gantt} llegan 5 productos con 2 componentes cada uno. Una posible solución podría estar dada por las siguientes secuencias de desensamblado $D_1=\{3, 5, 2\}$ y $D_2=\{1, 4\}$, de reprocesamiento $R_1=\{3, 5, 2, 1, 4\}$ y $R_2 =\{3, 2, 1, 5, 4\}$, y de ensamblado $E_1=\{3, 2, 4\}$ y $E_2=\{5, 1\}$. Dada esta solución, y conocidos los tiempos de procesamiento de cada uno de los productos y componentes en cada una de las etapas, el diagrama de Gantt de la Figura \ref{fig:gantt} muestra la evolución de las diferentes tareas/procesos a lo largo del tiempo cuando el sistema funciona de acuerdo a la solución anterior.

\begin{figure}[!ht]
    \centering
    \includegraphics[width=1\textwidth]{assets/gantt.pdf}
    \caption{Diagrama de Gantt de una solución con cinco productos.}
    \label{fig:gantt}
\end{figure}

Sean $td_p$, $tr_{pr}$, $te_p$ los instantes de tiempo (desde el comienzo del proceso) en los que producto $p$ finaliza su desensamblado, reprocesamiento en la línea \(r\) asignada al componente correspondiente, y ensamblado, respectivamente. Siguiendo con  la solución de la Figura \ref{fig:gantt} y tomando como ejemplo el producto $P5$, el tiempo de remanufactura del dicho producto en el sistema es $te_5$. Para llegar a dicho tiempo, el producto $P5$ comienza su desensamblado en la primera máquina que, dado que está ocupada por el producto $P3$, no puede comenzar hasta que dicha máquina esté libre. Así, el producto $P5$ finaliza su desensamblado en el instante $td_5 = td_3 + \mathit{TD}_{51}$. A continuación, los dos componentes de $P5$ ($C_{51}$ y $C_{52}$) están disponibles para ser reprocesados en las líneas de reprocesamiento de la segunda etapa. Como puede verse en la Figura, el componente $C_{51}$ es sometido a los tres procesos de la primera línea sin esperas, finalizando su reprocesado en el instante $tr_{51}= td_5 + \mathit{TR}_{511} + \mathit{TR}_{512} + \mathit{TR}_{513}$. Por otro lado, el componente $C_{52}$ debe esperar a que la segunda línea esté libre, haciendo el instante de tiempo en el que finalice su reprocesado sea $tr_{52} = t_{d5} + t_{espera} + \mathit{TR}_{521} + \mathit{TR}_{522}$, donde $t_{espera}$, que en el ejemplo es la suma entre $t_{espera1}$ y $t_{espera2}$, indica el tiempo de espera entre $t_{d5}$ y el comienzo de su procesado en la segunda línea como consecuencia del bloqueo de la misma por el procesado de otros componentes. Una vez los dos componentes han sido reprocesados, ya puede comenzar el reensamblado del producto $P5$ en la tercera etapa. En este caso, dado que este ensamblado tiene lugar en la segunda máquina y esta está libre, la remanufactura del producto $P5$ finaliza en el instante $te_5 = max(tr_{51},tr_{52}) + \mathit{TE}_5$. Nótese que, al igual que con el componente de la segunda etapa, si la máquina de ensamblado hubiese estado ocupada, al cálculo de $te_5$ habría que sumarle un tiempo de espera. Una vez calculados el tiempo de ensamblado de cada uno de los productos $p \in \{1,...,n\}$, el \textit{makespan} del sistema bajo la solución $\varphi$ se calcula como:

\begin{equation}
    \mathcal{F}(\varphi) = \max_{p \in \{1,...,n\}} \{\mathit{te}_p\} \\
\end{equation}

Por tanto, el objetivo del 3T-RSSP de minimizar el makespan, %, consistente en minimizar el \textit{makespan} del sistema,
puede escribirse formalmente como se muestra en la Ecuación \eqref{eq:problem}, donde \(\Phi\) es el conjunto de todas las soluciones factibles.

\begin{equation}\label{eq:problem}
   \varphi^* = \argmin\limits_{\varphi \in \varPhi} \mathcal{F}(\varphi)
\end{equation}



% Para ejemplificar su cálculo y siguiendo con el ejemplo de la Figura \ref{fig:gantt}, se puede obtener el tiempo del primer producto de la primera máquina desensamblado, $P3$, como \(td_3=\mathit{TD}_{31}\), el segundo producto, $P5$, tiene que esperar a que $P3$ finalice, por lo que \(td_5=td_3 + \mathit{TD}_{51}\). La segunda etapa, tiene dos líneas de reprocesamiento: en la primera, el componente $C_{51}$ se calcula como \(tr_{51}= td_5 + \mathit{TR}_{511} + \mathit{TR}_{512} + \mathit{TR}_{513} \), se tiene en cuenta el instante de finalización del desensamblado, ya que no puede comenzar el reprocesamiento hasta que no finalice la etapa anterior. En la segunda línea, el componente $C_{52}$ tiene elementos previos, bloqueando el procesado de línea, ya que no se puede procesar más de un componente, o producto, por la misma línea, o máquina, al mismo tiempo, lo que hace que el componente tenga que esperar $t_{espera}$ tiempo para comenzar a ser procesado, por lo que $tr_{52} = t_{d5} + t_{espera} + \mathit{TR}_{521} + \mathit{TR}_{522}$. La etapa final, un producto, tiene que esperar a que todos sus componentes hayan finalizado la etapa de reprocesamiento, por lo que el proceso de ensamblado comienza cuando el último componente ha finalizado \(te_5 = max(tr_{51},tr_{52}) + \mathit{TE}_5 \). Nótese que, al que sucedía en las anteriores etapas, puede que la máquina de ensamblaje esté ocupada y al cálculo de $te_5$ haya que sumarle un tiempo de espera.


\section{Propuesta algorítmica} \label{sec:algoritmica}

En este trabajo se propone el uso de un método GRASP (del inglés, \textit{Greedy Randomized Adaptive Search Procedure}) para resolver el problema 3T-RSSP. GRASP es una metaheurística creada en 1989 por Feo y Resende \cite{FeoRes89a}. Tal y como se muestra en el Algoritmo \ref{algo:grasp}, es un procedimiento multiarranque en el que cada iteración tiene dos fases diferenciadas: una primera fase que construye una solución inicial siguiendo un procedimiento voraz-aleatorizado que depende del parámetro $\alpha$ (línea \ref{algo:grasp:const}), seguida de una segunda fase que trata de mejorar la calidad de la solución obtenida en la primera usando un método de búsqueda local (línea \ref{algo:grasp:lsc}). El procedimiento finaliza devolviendo en la línea \ref{algo:grasp:return} la mejor solución obtenida en las $t_{max}$ iteraciones ejecutadas, cuya actualización se lleva a cabo en las líneas \ref{algo:grasp:if} a \ref{algo:grasp:endif}.

\begin{algorithm}[h!]
    \small
    \setstretch{1.3}
    \DontPrintSemicolon
    $\mathcal{F}^* \gets \infty$\; 
    \For{$t=1$ $\mathbf{to}$ $t_{max}$} { 		
        $\varphi  \gets \mathtt{Constructivo}(\alpha)$\; \label{algo:grasp:const}
        $\varphi' \gets \mathtt{BusquedaLocal}(\varphi)$\;\label{algo:grasp:lsc}
        \If{$\mathcal{F}(\varphi') < \mathcal{F}^*$}{\label{algo:grasp:if}
            $\mathcal{F}^* \gets \mathcal{F}(\varphi')$\;\label{algo:grasp:f}
            $\varphi^\star  \gets \varphi'$\;	\label{algo:grasp:best}
        } \label{algo:grasp:endif}
    }
    \Return{$\varphi^\star$}\; \label{algo:grasp:return}
    \caption{{\sc GRASP ($t_{max},\alpha$)}}
    \label{algo:grasp}
\end{algorithm}


\subsection{Método constructivo} \label{sec:constructivo}

El propósito de la fase constructiva es generar una solución inicial con cierta calidad. Se trata de un método iterativo en el que, partiendo de una solución vacía, se va añadiendo un nuevo elemento en cada iteración. Esta fase suele estar guiada por una función de selección voraz que, junto con un parámetro $\alpha$, ayuda al método a elegir los elementos más prometedores para ser incluidos en la solución parcial. En esta propuesta, los productos se van asignando a las secuencias de procesamiento de las diferentes máquinas en cada etapa de uno en uno, utilizando el \textit{makespan} de la solución parcial como función voraz.

El Algoritmo \ref{algo:constructivo}, muestra el pseudocódigo de la fase de construcción, donde, partiendo de una solución vacía, las funciones \texttt{Desensamblado}, \texttt{Reprocesamiento} y \texttt{Ensamblado} van añadiendo a la solución parcial las secuencias de desensamblado, reprocesamiento y ensamblado, respectivamente, siendo detallado en el Algoritmo \ref{algo:desensamblado} para la etapa de desensamblado. El procedimiento es similar para las etapas de reprocesamiento y ensamblado, con la salvedad de que en la etapa de reprocesamiento la línea \ref{desensamblado:ecl} del Algoritmo \ref{algo:desensamblado} solo incluye el tipo de producto en lugar de los pares producto-máquina.

\begin{algorithm}[h!]
    \small
    \setstretch{1.3}
    \DontPrintSemicolon
    $\varphi \gets \emptyset$\;
    $\varphi  \gets \mathtt{Desensamblado}(\varphi, \alpha)$\;
    $\varphi  \gets \mathtt{Reprocesamiento}(\varphi, \alpha)$\;
    $\varphi  \gets \mathtt{Ensamblado}(\varphi, \alpha)$\;
    \Return{$\varphi$}\;  \label{grasp:return}
    \caption{$\mathtt{Constructivo} (\alpha)$}
    \label{algo:constructivo}
\end{algorithm}

El Algoritmo \ref{algo:desensamblado} comienza inicializando la secuencia de cada una de las máquinas de desensamblado a un conjunto vacío en las líneas \ref{desensamblado:ini-start} y \ref{desensamblado:ini-end}. A continuación, tras inicializar la lista de candidatos \(CL\) con el conjunto de todos los productos, se entra en un bucle (líneas \ref{desensamblado:while} a \ref{desensamblado:endwhile}) que construye la secuencia inicial añadiendo un elemento a la solución parcial en cada iteración. Para ello, dicho bucle comienza generando la lista de candidatos extendida \textit{ECL} que incluye todas las posibles combinaciones de producto $p \in CL$ y máquina de desensamblado $m \in \{1, \dots, d \}$ (línea \ref{desensamblado:ecl}). A continuación, se obtienen los valores mínimo y máximo de la función voraz (líneas \ref{desensamblado:gmin} y \ref{desensamblado:gmax}), denotada como $\mathcal{G}(\varphi,p,m)$, que calcula el valor de la función objetivo si a la solución $\varphi$ se le asigna el producto $p$ en la máquina $m$. Con estos valores y el parámetro $\alpha$ se genera la lista de candidatos reducida \textit{RCL} en la línea \ref{desensamblado:rcl}. Finalmente, tras seleccionar aleatoriamente un elemento de la \textit{RCL} en la línea \ref{desensamblado:rnd}, este es utilizado en las líneas \ref{desensamblado:actualizarD} y \ref{desensamblado:actualizarSol} para actualizar la solución parcial. La línea \ref{desensamblado:minus} elimina de la \textit{CL} el producto $p$ incluido en la solución, y el bucle continúa hasta que no queden elementos en dicha lista, devolviendo la solución construida.

\begin{algorithm}[h!]
    \small
    \setstretch{1.3}
    \DontPrintSemicolon
    \For{$m=1$ $\mathbf{to}$ $d$}{ \label{desensamblado:ini-start}
        $D_m \gets \emptyset$\;
    } \label{desensamblado:ini-end}
    $CL \gets \{1,\dots,n\}$\; \label{desensamblado:cl}
    \While{$|CL| > 0$}{ \label{desensamblado:while}
        $ECL \gets \{(p,m) \mid p \in CL \wedge m \in \{1, \dots, d \} \} $\; \label{desensamblado:ecl}
        $\mathcal{G}_{min} \gets \min\limits_{(p,m) \in ECL} \mathcal{G}(\varphi,p,m)$\; \label{desensamblado:gmin}
        $\mathcal{G}_{max} \gets \max\limits_{(p,m) \in ECL} \mathcal{G}(\varphi,p,m)$\; \label{desensamblado:gmax}
        $RCL \gets \{(p,m) \in ECL: \mathcal{G}(\varphi,p,m) \leq \mathcal{G}_{max} - \alpha \cdot (\mathcal{G}_{max} - \mathcal{G}_{min})\}$\; \label{desensamblado:rcl}
        $(p,m) \gets \mathtt{SeleccionarAleatorio}(RCL)$\; \label{desensamblado:rnd}
        $D_m \gets D_m \cup \{p\}$\; \label{desensamblado:actualizarD}
        $\varphi \gets \mathtt{Actualizar}(\varphi,D_m)$\; \label{desensamblado:actualizarSol}
        $CL \gets CL \setminus \{p\}$\; \label{desensamblado:minus}
    } \label{desensamblado:endwhile}
    \Return{$\varphi$}\;  \label{desensamblado:return}
    \caption{$\mathtt{Desensamblado} (\varphi,\alpha)$}
    \label{algo:desensamblado}
\end{algorithm}


\subsection{Búsqueda Local}

La búsqueda local propuesta en este trabajo para la fase de mejora se basa en la exploración de un vecindario extendido generado a partir de dos movimientos diferentes: \textit{inserción} e \textit{intercambio}. Dichos movimientos se aplican de manera análoga dentro de cada una de las tres etapas. Por simplicidad, a continuación solo se explican estos movimientos en la etapa de desensamblado, siendo aplicables de manera análoga en las otras dos etapas.

El movimiento de \textit{inserción} consiste en eliminar un producto $p$ ubicado en la posición $i$ de la secuencia de desensamblado de la máquina $m$, $D_m$, para a continuación insertarlo en otra posición diferente $j \neq i$ de la misma máquina $m$, o en cualquiera de las posiciones de la secuencia de desensamblado de otra máquina $m' \neq m$, $D_{m'}$. Así, siguiendo con la solución de la Figura 2, donde la secuencia de ensamblado es $\pi_D=\{ \{3, 5, 2\}, \{1, 4\} \}$, ejemplos de posibles movimientos de inserción en la etapa de desensamblado son $\pi_D'=\{ \{5, 3, 2\}, \{1, 4\} \}$, donde el producto $P3$ ha modificado su posición en la primera máquina, o $\pi_D'=\{ \{5, 2\}, \{1, 4, 3\} \}$, donde el producto $P3$ se coloca en la última posición de la segunda máquina. Como se ha comentado más arriba, este movimiento también es aplicable a las etapas de ensamblado o reprocesamiento, con la única excepción de que en la etapa de reprocesamiento las inserciones solo pueden tener lugar dentro de la misma línea. Siguiendo con el ejemplo, donde la secuencia de reprocesamiento es $\pi_R=\{\{3, 5, 2, 1, 4\}, \{3, 2, 1, 5, 4\}\}$, un posible movimiento es $\pi_R'=\{\{5, 2, 1, 3, 4\}, \{3, 2, 1, 5, 4\}\}$, donde el producto $P3$ ha modificado su posición en la secuencia de la primera línea de la etapa de reprocesamiento (nótese que dicho producto no puede ser insertado en $R_2$).

El movimiento de \textit{intercambio} consiste en intercambiar un producto $p$ ubicado en la posición $i$ de la secuencia de desensamblado de la máquina $m$, $D_m$, por otro producto $p'$ en otra posición diferente $j \neq i$ de la misma máquina $m$, o en cualquiera de las posiciones de la secuencia de desensamblado de otra máquina $m' \neq m$, $D_{m'}$. Así, siguiendo con la solución de la Figura \ref{fig:gantt}, donde la secuencia de desensamblado es $\pi_D=\{ \{3, 5, 2\}, \{1, 4\} \}$, ejemplos de posibles movimientos de intercambio en la etapa de ensamblado son $\pi_D'=\{ \{2, 5, 3\}, \{1, 4\} \}$ donde los productos $P2$ y $P3$ han intercambiado posiciones en la primera máquina, o $\pi_D'=\{ \{3, 5, 1\}, \{2, 4\} \}$ donde los productos $P1$ y $P2$ han intercambiado posición y máquina. Al igual que con el movimiento de \textit{inserción}, el movimiento de \textit{intercambio} es aplicable a las etapas de desensamblado y reprocesamiento, exceptuando que en la etapa de reprocesamiento el movimiento solo puede tener lugar dentro de la misma línea.

El Algoritmo \ref{algo:ls} muestra el pseudocódigo de la búsqueda local propuesta para el 3T-RSSP, que se basa en la exploración de los vecindarios extendidos generados con ambos movimientos, (\textit{inserción} e \textit{intercambio}), de manera secuencial en cada una de las tres etapas (desensamblado, reprocesamiento y ensamblado). Tras inicializar la variable \textit{mejora} en la línea \ref{ls:init1}, la búsqueda local entra en un bucle (líneas \ref{ls:while} a \ref{ls:executemove2}) que explora los vecindarios extendidos de cada una de las tres etapas en las líneas \ref{ls:explore1}, \ref{ls:explore2} y \ref{ls:explore3}. A continuación, la función \texttt{ObtenerMejor} devuelve en la línea \ref{ls:explore4} la mejor solución de las tres obtenidas, que se utiliza para actualizar la solución actual en caso de mejora (líneas \ref{ls:ifimproves} a \ref{ls:executemove2}). El bucle continúa hasta que no es posible encontrar ninguna mejora en los vecindarios explorados. 

\begin{algorithm}[h!]
    \small
    \setstretch{1.3}
    \DontPrintSemicolon
	$mejora \gets \mathtt{true}$\; \label{ls:init1}
	\While{$mejora$}{\label{ls:while}
	    $mejora \gets \mathtt{false}$\; \label{ls:init2}
        $\varphi_D \gets \mathtt{ExplorarD}(\varphi)$ \\ \label{ls:explore1}
        $\varphi_R \gets \mathtt{ExplorarR}(\varphi)$ \\ \label{ls:explore2}
        $\varphi_E \gets \mathtt{ExplorarE}(\varphi)$ \\ \label{ls:explore3} 
        $\varphi' \gets \mathtt{ObtenerMejor}(\varphi_D,\varphi_R,\varphi_E)$ \\ \label{ls:explore4}
    	\If{$\mathcal{F}(\varphi') < \mathcal{F}(\varphi)$} {\label{ls:ifimproves}
    	    $\varphi \gets \varphi'$\; \label{ls:executemove1}
    	    $mejora \gets \mathtt{true}$ \;\label{ls:executemove2} 
    	}
	}
	\Return{$\varphi$}\; \label{ls:return}
	\caption{$\mathtt{BusquedaLocal}(\varphi)$}
	\label{algo:ls}
\end{algorithm}


\section{Resultados experimentales} \label{sec:experimentos}

El GRASP propuesto en este trabajo para el 3T-RSSP se ha evaluado frente al estado del arte sobre el conjunto de 34 instancias propuesto en \cite{WANG2024109257}. Estas instancias están etiquetadas como \texttt{Pp\_Cr\_DdAe}, donde $p$ hace referencia al número de productos, $r$ hace referencia al número de componentes o líneas de reprocesamiento, $d$ al número de máquinas de desensamblado y $e$ el número de máquinas de ensamblado. En concreto, las instancias de este conjunto tienen entre 4 y 40 productos, entre 1 y 6 máquinas de desensamblado, entre 2 y 5 líneas de reprocesamiento (componentes), y entre 1 y 3 máquinas de ensamblado. Toda la experimentación ha sido realizada en una máquina con procesador AMD EPYC 7643 16-core virtual CPU con 8 GB de RAM, usando Java 21.

\subsection{Ajuste de parámetros} \label{sub:preliminar}

Como se ha comentado en la Sección \ref{sec:constructivo}, el algoritmo aquí propuesto depende del parámetro $\alpha$ que regula el equilibrio entre una selección totalmente aleatoria ($\alpha = 0$) o voraz ($\alpha = 1$) de los elementos a incluir en la solución inicial en la fase de construcción. Por tanto, para encontrar la mejor configuración del algoritmo, se ha realizado un experimento en el que se compara el rendimiento del mismo bajo diferentes valores del parámetro $\alpha$. En concreto, se han examinado los valores $\alpha = \{0,0; 0,25; 0,5; 0,75; 1,0\}$. 

La Tabla \ref{tab:preliminares} muestra el rendimiento del algoritmo para los diferentes valores de $\alpha$ estudiados utilizando como criterio de parada $t_{max} = 100$. Para cada valor de $\alpha$ se muestra el promedio de diferentes métricas sobre los resultados obtenidos en las 34 instancias bajo estudio, destacando en negrita el mejor valor de cada métrica. En particular, la primera columna muestra el coste de la función objetivo (Coste); la segunda, la desviación porcentual de dicho coste respecto al mejor valor encontrado en este experimento (Desv. (\%)); la tercera, el número de instancias en que la configuración asociada a cada valor de $\alpha$ obtiene la mejor solución encontrada (\#Best); y finalmente, la cuarta columna muestra el tiempo de ejecución en segundos (Tiempo (s)).

\begin{table}[h!]
    \centering
    \vspace{-2ex}
    \caption{Rendimiento del algoritmo para diferentes valores de $\alpha$.}
    \vspace{1ex}
    \setstretch{1.4}
    \scalebox{0.9}{
    \begin{tabular}{lrrrr}
        \toprule
        \boldmath{}\textbf{$\alpha$}\unboldmath{} & \textbf{Coste} & \textbf{Desv. (\%)} & \textbf{\#Best} & \textbf{Tiempo (s)} \\
        \midrule
        0,00 & \textbf{453,88} & \textbf{0,28} & 26    & 9,24 \\
        \textbf{0,25} & 454,06 & 0,71 & \textbf{28}    & 6,04 \\
        0,50 & 454,03 & 0,74 & 26    & 3,34 \\
        0,75 & 455,29 & 1,12 & 19    & 1,33 \\
        1,00 & 459,53 & 2,61 & 10    & \textbf{1,23} \\
        \bottomrule
    \end{tabular}
    \label{tab:preliminares}}
    \vspace{-2ex}
\end{table}

Como se observa en la tabla, a medida que se incrementa la voracidad en la construcción de la solución inicial, aumentando el valor de $\alpha$, el tiempo de ejecución del algoritmo se reduce. Esto es debido a que a mayor calidad de la solución generada por el método constructivo, menor es el recorrido de la búsqueda local antes de caer en un mínimo local. Por otro lado, se observa que incluyendo algo de aleatoriedad en la construcción de las soluciones iniciales, reduciendo el valor de $\alpha$, la búsqueda local es capaz de avanzar más, incrementando la calidad de las soluciones finales. En particular, el mejor valor del coste y desviación lo ofrece la versión con $\alpha=0,0$, mientras que la versión con $\alpha=0,25$ obtiene la mejor solución en 28 de las 34 instancias. Finalmente, aún con un coste promedio ligeramente inferior, dado el mayor número de instancias donde obtiene la mejor solución y la reducción del tiempo de ejecución en un 34,63\% respecto a la versión con $\alpha=0,0$, se selecciona la versión con $\alpha=0,25$ como la mejor configuración del GRASP aquí propuesto de cara a la comparativa con el estado del arte.

% Notese que 

\subsection{Comparativa con estado del arte} \label{sub:comparacion}

Una vez ajustado el parámetro $\alpha$, en esta sección se compara la mejor versión del algoritmo GRASP propuesto para el 3T-RSSP ($\alpha=0,25$) frente al estado del arte. En particular, el trabajo \cite{WANG2024109257} propone 18 heurísticas constructivas y el uso de CPLEX para resolver el modelo de programación lineal entera mixta (MILP) propuesto, limitando el tiempo de ejecución a 3600 segundos. Adicionalmente, el trabajo \cite{WANG-2.More-2024110379} propone cuatro modelos exactos (Modelo 1 a Modelo 4), limitando a 600 segundos la ejecución en las instancias pequeñas y 3600 segundos en las grandes. Cabe destacar que en el primer trabajo (\cite{WANG2024109257}) no se proporcionan las características de la CPU en la que se han ejecutado los experimentos, mientras que el segundo (\cite{WANG-2.More-2024110379}) utiliza un Intel i5-12500H que, de acuerdo a \url{http://www.cpubenchmark.net/}, tiene un rendimiento en ejecución \textit{single-thread} de un 21.8\% superior a la CPU utilizada en el trabajo aquí propuesto.

La Tabla \ref{tab:estadoArte} muestra la comparativa frente al estado del arte del GRASP propuesto para dos valores diferentes de $t_{max}$, utilizando las mismas métricas de la Tabla \ref{tab:preliminares}. Una primera versión que utiliza un valor de $t_{max} = 100$, denotada como GRASP-100, y una segunda versión con $t_{max} = 1000$, denotada como GRASP-1000. Estas dos versiones del algoritmo buscan un equilibrio entre calidad de la solución y tiempo de ejecución. En esta tabla es relevante destacar que los modelos etiquetados con el símbolo $^{\star}$ no llegan a resolver las 34 instancias en el límite de tiempo establecido. En particular, el modelo MILP presenta problemas de memoria en una de las instancias, por lo que sus resultados corresponden a 33 de las 34 instancias. Por otro lado, el Modelo 3 tan solo obtiene un resultado factible para 3 de las 34 instancias. Asimismo, el Modelo 4 resuelve de manera factible 32 instancias. Es por esto que los valores agregados de las métricas para los modelos etiquetados con el símbolo $^{\star}$ no han sido tomados en cuenta en la comparativa final.

\begin{table}[htbp]
    \centering
    \vspace{-3ex}
    \caption{Comparativa frente al estado del arte. El símbolo $^{\star}$ indica que no se han resuelto las 34 instancias en el límite de tiempo establecido.}
    \vspace{1ex}
    \setstretch{1.35}
    \scalebox{0.9}{
    \begin{tabular}{lrrrr}
    \toprule
    \textbf{Algoritmo} & \multicolumn{1}{l}{\textbf{Coste}} & \multicolumn{1}{l}{\textbf{Desv. (\%)}} & \multicolumn{1}{l}{\textbf{\#Best}} & \multicolumn{1}{r}{\textbf{Tiempo (s)}} \\
    \midrule
    LAPT-F & 465,03 & 4,56  & 13    & \textbf{0,20} \\
    LAPT-H & 488,74 & 11,64 & 1     & \textbf{0,20} \\
    LAPT-L & 589,47 & 43,26 & 0     & \textbf{0,20} \\
    LTPT-F & 464,00 & 4,29  & 12    & \textbf{0,20} \\
    LTPT-H & 485,44 & 10,85 & 2     & \textbf{0,20} \\
    LTPT-L & 585,97 & 40,99 & 0     & \textbf{0,20} \\
    LTRT-F & 462,47 & 4,11  & 12    & \textbf{0,20} \\
    LTRT-H & 493,62 & 13,13 & 4     & \textbf{0,20} \\
    LTRT-L & 607,29 & 43,69 & 0     & \textbf{0,20} \\
    SAPT-F & 463,68 & 4,71  & 9     & \textbf{0,20} \\
    SAPT-H & 496,00 & 12,82 & 3     & \textbf{0,20} \\
    SAPT-L & 602,29 & 45,23 & 0     & \textbf{0,20} \\
    STPT-F & 465,12 & 4,99  & 11    & \textbf{0,20} \\
    STPT-H & 495,12 & 13,31 & 3     & \textbf{0,20} \\
    STPT-L & 599,26 & 45,62 & 0     & \textbf{0,20} \\
    STRT-F & 465,85 & 5,07  & 9     & \textbf{0,20} \\
    STRT-H & 504,82 & 14,36 & 2     & \textbf{0,20} \\
    STRT-L & 607,12 & 44,70 & 0     & \textbf{0,20} \\
    MILP$^{\star}$ & 441,70 & 1,55  & 26    & 1602,64 \\
    \multicolumn{5}{c}{\hdashrule[1ex]{0,65\linewidth}{0,5pt}{2pt}}\\[-1ex]
    Modelo 1 & 458,47 & \textbf{0,53}  & \textbf{30}    & 782,29 \\
    Modelo 2 & 521,65 & 5,14  & 27    & 771,22 \\
    Modelo 3$^{\star}$ & 279,00 & 0,00  & 3     & 1473,82 \\
    Modelo 4$^{\star}$ & 408,69 & 1,48  & 25    & 1149,81 \\
    \multicolumn{5}{c}{\hdashrule[1ex]{0,65\linewidth}{0,5pt}{2pt}}\\[-1ex]
    GRASP-100 & 454,06 & 0,91  & 26    & 6,04 \\
    GRASP-1000 & \textbf{453,26} & 0,68  & 28    & 58,62 \\
    \bottomrule
    \end{tabular}
    }
    \label{tab:estadoArte}
    \vspace{-2ex}
\end{table}

Se puede observar que las 18 heurísticas constructivas generan soluciones empleando muy poco tiempo, pero en general tienen poca calidad. Los métodos exactos mejoran claramente los resultados de las heurísticas, especialmente el Modelo 1, que obtiene el mejor resultado en 30 instancias y la menor desviación, aunque empleando tiempos considerablemente elevados. Cabe destacar que los resultados obtenidos por el método GRASP propuesto en este trabajo alcanzan un buen compromiso entre calidad y tiempo de ejecución, llegando a obtener el mejor valor promedio para la función de coste y, en el caso de la versión GRASP-1000, el mejor valor posible en 28 instancias empleando menos del 7,5\% del tiempo utilizado por el modelo matemático.

Finalmente, la Tabla \ref{tab:detalle} muestra el detalle de los resultados del algoritmo GRASP propuesto en este trabajo considerando los dos límites de 100 y 1000 iteraciones para cada una de las instancias. Se han destacado en cursiva los mejores valores encontrados y en negrita los óptimos.

\begin{table}[h!]
    \centering
    \caption{Detalle de los resultados obtenidos por GRASP-100 y GRASP-1000 en las 34 instancias.}
    \vspace{1ex}
    \setstretch{1.35}
    \scalebox{0.9}{
    \begin{tabular}{lrrrrrr}
        \toprule
        &       & \multicolumn{2}{c}{\textbf{GRASP-100}} &       & \multicolumn{2}{c}{\textbf{GRASP-1000}} \\
        \cmidrule{3-4}\cmidrule{6-7}
        \textbf{Instancia} &       & \multicolumn{1}{l}{\textbf{Coste}} & \multicolumn{1}{l}{\textbf{Tiempo (s)}} &       & \multicolumn{1}{l}{\textbf{Coste}} & \multicolumn{1}{l}{\textbf{Tiempo (s)}} \\
        \cmidrule{1-1}\cmidrule{3-4}\cmidrule{6-7}    
        \texttt{P4\_C2\_D1A2} &       & \textit{295} & 0,02  &       & \textit{295} & 0,11 \\
        \texttt{P4\_C2\_D2A1} &       & \textbf{267} & 0,01  &       & \textbf{267} & 0,10 \\
        \texttt{P4\_C2\_D2A2} &       & \textbf{197} & 0,01  &       & \textbf{197} & 0,08 \\
        \texttt{P4\_C2\_D4A2} &       & \textbf{197} & 0,01  &       & \textbf{197} & 0,09 \\
        \texttt{P4\_C3\_D1A2} &       & \textbf{180} & 0,01  &       & \textbf{180} & 0,11 \\
        \texttt{P4\_C3\_D2A1} &       & \textbf{238} & 0,01  &       & \textbf{238} & 0,14 \\
        \texttt{P4\_C3\_D2A2} &       & \textbf{153} & 0,02  &       & \textbf{153} & 0,18 \\
        \texttt{P4\_C3\_D4A2} &       & \textbf{150} & 0,02  &       & \textbf{150} & 0,20 \\
        \texttt{P5\_C2\_D1A2} &       & \textit{314} & 0,01  &       & \textit{314} & 0,08 \\
        \texttt{P5\_C2\_D2A1} &       & \textbf{301} & 0,01  &       & \textbf{301} & 0,16 \\
        \texttt{P5\_C2\_D2A2} &       & \textbf{235} & 0,02  &       & \textbf{235} & 0,18 \\
        \texttt{P5\_C2\_D4A2} &       & \textbf{216} & 0,02  &       & \textbf{216} & 0,25 \\
        \texttt{P5\_C3\_D1A2} &       & \textbf{273} & 0,03  &       & \textbf{273} & 0,21 \\
        \texttt{P5\_C3\_D2A1} &       & \textbf{279} & 0,08  &       & \textbf{279} & 0,31 \\
        \texttt{P5\_C3\_D2A2} &       & \textbf{234} & 0,04  &       & \textbf{234} & 0,33 \\
        \texttt{P5\_C3\_D4A2} &       & \textbf{244} & 0,04  &       & \textbf{244} & 0,33 \\
        \texttt{P8\_C2\_D1A2} &       & \textit{412} & 0,06  &       & \textit{412} & 0,47 \\
        \texttt{P8\_C2\_D2A1} &       & \textbf{459} & 0,07  &       & \textbf{459} & 0,70 \\
        \texttt{P8\_C2\_D2A2} &       & 242   & 0,10  &       & \textit{229} & 1,03 \\
        \texttt{P8\_C2\_D4A2} &       & 232   & 0,10  &       & \textit{229} & 1,00 \\
        \texttt{P8\_C3\_D1A2} &       & \textit{405} & 0,17  &       & \textit{405} & 1,61 \\
        \texttt{P8\_C3\_D2A1} &       & \textbf{398} & 0,17  &       & \textbf{398} & 1,53 \\
        \texttt{P8\_C3\_D2A2} &       & \textbf{309} & 0,13  &       & \textbf{309} & 1,40 \\
        \texttt{P8\_C3\_D4A2} &       & \textbf{313} & 0,14  &       & \textbf{313} & 1,31 \\
        \texttt{P10\_C2\_D2A2} &       & \textit{376} & 0,18  &       & \textit{376} & 1,82 \\
        \texttt{P10\_C3\_D4A2} &       & \textit{377} & 0,25  &       & \textit{377} & 2,56 \\
        \texttt{P10\_C5\_D6A3} &       & \textit{377} & 0,60  &       & \textit{377} & 5,29 \\
        \texttt{P20\_C3\_D6A3} &       & \textit{710} & 1,88  &       & \textit{710} & 17,83 \\
        \texttt{P20\_C5\_D4A2} &       & \textit{718} & 6,58  &       & \textit{718} & 63,56 \\
        \texttt{P20\_C5\_D6A3} &       & \textit{718} & 4,84  &       & \textit{718} & 46,23 \\
        \texttt{P40\_C3\_D4A2} &       & \textit{1402} & 33,17 &       & \textit{1402} & 319,93 \\
        \texttt{P40\_C3\_D6A3} &       & \textit{1402} & 20,68 &       & \textit{1402} & 197,05 \\
        \texttt{P40\_C5\_D4A2} &       & 1413  & 84,11 &       & \textit{1402} & 822,04 \\
        \texttt{P40\_C5\_D6A3} &       & \textit{1402} & 51,91 &       & \textit{1402} & 504,93 \\
        \cmidrule{1-1}\cmidrule{3-4}\cmidrule{6-7}    \textbf{Promedio} &       & 454,06 & 6,04  &       & 453,26 & 58,62 \\
        \bottomrule
    \end{tabular}%
    \label{tab:detalle}}
\end{table}
\vspace{-2ex}

\section{Conclusiones y trabajo futuro} \label{sec:conclusion}
En este trabajo se ha abordado el problema de la optimización de sistemas de remanufactura en tres etapas mediante el uso de la metaheurística GRASP. El objetivo principal ha sido minimizar el \textit{makespan} del sistema, contribuyendo así a la eficiencia y sostenibilidad de los procesos de remanufactura, en línea con los Objetivos de Desarrollo Sostenible 9 y 12.

Los resultados experimentales, obtenidos para 34 instancias, demuestran que el método GRASP propuesto ofrece un buen equilibrio entre calidad de solución y tiempo de cómputo. En la comparativa con el estado del arte, el método propuesto ha obtenido el mejor coste promedio empleando menos de un 7,5\% del tiempo usado por el mejor método exacto.

Como trabajo futuro se planea mejorar el algoritmo desarrollado por medio de diferentes estrategias constructivas y de mejora. También se está estudiando mejorar la eficiencia del algoritmo con el objetivo de resolver instancias de mayor tamaño. Adicionalmente, se plantea la utilización de otras metaheurísticas o el uso de otras métricas de eficiencia como función objetivo.


\section*{Agradecimientos y declaración de financiación}
Este trabajo forma parte de los proyectos RED2022-134480-T y PID2021-125709OA-C22 financiados por el Ministerio de Ciencia e Innovaci\'on (MCIN/AEI/10.13039/501100011033) y FEDER, \textit{una manera de hacer Europa}, así como del proyecto TEC-2024/COM-404 financiado por la Comunidad Autónoma de Madrid.


% \section*{Referencias}

\printbibliography

\end{document}