\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[nonatbib,preprint]{maeb_2025}


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


% 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}
\usepackage{subcaption}
\usepackage{graphicx}

\addbibresource{refs.bib}

\usepackage[spanish]{babel}
\usepackage{csquotes}
\def\tablename{Tabla}
\addto\captionsspanish{\renewcommand{\tablename}{Tabla}}
\def\figurename{Figura}
\spanishdecimal{.}
%\floatname{algorithm}{Algoritmo}

\usepackage{algorithm}
\usepackage{algorithmic}
\usepackage{amsmath}

\title{Constructivo GRASP para la Optimización de una Planta de Producción en la Industria Automotriz}


% 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{
Sergio Cavero \\
Departamento de Informática y Estadística \\
Universidad Rey Juan Carlos (URJC) \\
Madrid, España \\
\href{mailto:sergio.cavero@urjc.es}{sergio.cavero@urjc.es} \\
\And
Isaac Lozano-Osorio \\
Departamento de Informática y Estadística \\
Universidad Rey Juan Carlos (URJC) \\
Madrid, España \\
\href{mailto:isaac.lozano@urjc.es}{isaac.lozano@urjc.es} \\
\And
Manuel Laguna \\
Leeds School of Business \\
University of Colorado Boulder \\
Boulder, CO, USA \\
\href{mailto:manuel.laguna@colorado.edu}{manuel.laguna@colorado.edu} \\
}


\begin{document}


\maketitle


\begin{abstract}
Este artículo aborda un problema de planificación de la producción en la fabricación de asientos para automóviles.  Ante la complejidad de múltiples líneas de producción y la diversidad de los productos a producir, se propone un algoritmo heurístico basado en la metaheurística GRASP. El objetivo del algoritmo es encontrar soluciones factibles al problema y minimizar los costosos cambios de configuración, manteniendo los niveles de inventario dentro de los rangos deseados. La efectividad del algoritmo se valida comparándolo con un modelo exacto, demostrando su capacidad para generar soluciones factibles y eficaces para la mayoría de los casos reales estudiados. Los resultados confirman la utilidad del enfoque GRASP como solución eficiente y adaptable, e inspiran futuras investigaciones en heurísticas más avanzadas para este problema.
\end{abstract}


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

En la industria automotriz, la fabricación de asientos para automóviles presenta diferentes desafíos: la variedad de modelos, la necesidad de mantener niveles de inventario dentro de rangos específicos y la simulación de plantas de producción que involucran complejos procesos. Este artículo aborda un problema derivado directamente de la industria de fabricación de asientos para automóviles, que involucra múltiples líneas de producción y una variedad de modelos de automóviles. El desafío principal radica en determinar la secuencia óptima de moldes, cada molde puede montarse en una línea para mantener los niveles de inventario  en los rangos deseados, satisfacer la demanda y minimizar al mismo tiempo el número de cambios de configuración de la planta.

En el caso de estudio analizado, la planificación se realiza actualmente mediante métodos manuales basados en la experiencia de los trabajadores y hojas de cálculo. Esto resulta en un enfoque insuficiente ante la escalabilidad productiva y los requisitos dinámicos del sector. En una primera aproximación al problema, se implementó un modelo de programación lineal entera mixta (más conocido como MIP, del inglés \textit{Mixed-Integer Programming}) que lo formaliza matemáticamente. Sin embargo, la dependencia de herramientas de optimización comerciales con altos costes limita su aplicabilidad práctica. Por otro lado, los elevados tiempos de generación del modelo matemático y su posterior resolución eran excesivamente elevados para la empresa en algunos escenarios. Por lo tanto, esta investigación se centra en un enfoque distinto, el diseño de algoritmos heurísticos que equilibren calidad de solución y eficiencia computacional, que, además, no requieran de la licencia de un software en concreto para poder ser ejecutados.

Dado que no es estrictamente necesario alcanzar la solución óptima global, sino obtener soluciones de calidad aceptable en tiempos computacionales razonables, se ha desarrollado un algoritmo constructivo heurístico basado en el Procedimiento de Búsqueda Adaptativa Aleatoria Codiciosa (comúnmente conocido como GRASP, por sus siglas en inglés derivadas de \textit{Greedy Randomized Adaptive Search Procedure}). Este algoritmo está diseñado para proporcionar soluciones eficientes en instancias complejas derivadas de las operaciones reales de la empresa. El objetivo de este artículo es presentar el problema y analizar el enfoque constructivo propuesto, resaltando su capacidad para generar soluciones factibles y eficaces. Este trabajo sienta las bases para futuras investigaciones, donde se podrían explorar algoritmos heurísticos más avanzados.

En las siguientes secciones, se describe el problema (Sección~\ref{sec:problema}), la literatura relevante (Sección~\ref{sec:literatura}), el algoritmo heurístico propuesto (Sección~\ref{sec:algoritmo}), y los resultados de los experimentos computacionales realizados para evaluar su rendimiento (Sección~\ref{sec:experimentos}). Finalmente, se presentan las conclusiones y las líneas de investigación futuras (Sección~\ref{sec:conclusion}).

\section{Presentación del problema} \label{sec:problema}

El problema de planificación de la producción abordado en este trabajo se sitúa en un sistema de fabricación de automóviles, concretamente en líneas de producción heterogéneas con forma circular (también denominadas como ``pistas de producción'', ``líneas'' o ``pistas''). Estas líneas de producción disponen de posiciones para alojar portadores, que a su vez contienen montajes equipados con moldes para la fabricación de productos (partes de asientos). La Figura~\ref{fig:introduccion} ilustra una representación gráfica de la planta y sus componentes principales.


\begin{figure} \centering \includegraphics[width=\linewidth]{introduction.pdf} \caption{Representación gráfica de una planta de producción y sus componentes principales.} \label{fig:introduccion} \end{figure}

Cada línea de producción posee una capacidad productiva diferenciada, determinada por su velocidad y cantidad de portadores que puede albergar. Los portadores contienen montajes de moldes (denotados como ``M1'', ``M2'' y ``M3'' en la Figura~\ref{fig:introduccion}), sujetos a restricciones de capacidad (el tamaño total de los moldes no debe superar el 100\% de la capacidad del portador) y compatibilidad (atributos como productos químicos y ángulos de inclinación). Los moldes se destinan a la producción de diversos tipos de partes de asientos, cada uno con un nivel de inventario objetivo y una demanda diaria.


El horizonte de planificación considera periodos de varios días para la demanda y franjas temporales dentro de cada día para secuenciar la producción. La capacidad de producción de cada línea varía según el número de posiciones de portadores y su velocidad. El inventario de cada parte se incrementa con la producción diaria y se reduce con la demanda al final del día. No satisfacer la demanda se considera una solución no factible. Adicionalmente, existen restricciones de inventario superior e inferior (nivel de seguridad) para cada producto.

Una instancia del problema se define por: las características de las líneas de producción (portadores, moldes y productos); el inventario inicial; las demandas diarias; la planificación del horario de producción (días y franjas de producción); y el estado inicial de las líneas de producción. El objetivo principal es obtener una planificación factible que satisfaga la demanda. Entre las soluciones factibles se busca minimizar el número de cambios de portadores, que se denotan como ``intercambios'' o ``cambios'', y la desviación del inventario respecto a los niveles objetivo. La minimización de cambios de portadores es la función objetivo principal, mientras que las desviaciones del nivel objetivo de inventario se usan como medida de rendimiento de la producción de la planta.


Desde el punto de vista empresarial, se debe proveer a la empresa de una planificación de cada línea, indicando los portadores y moldes que se utilizarán a lo largo de todo el horizonte de planificación. Por lo tanto, la principal decisión del problema de optimización será determinar la combinación de moldes que se montarán en los portadores y la línea de producción en la que este estará asignado. Estas decisiones deben tomarse al comienzo de cada intervalo de producción. Una vez que un portador con un conjunto particular de moldes se monta en la línea antes del inicio de un intervalo, el portador produce las partes correspondientes durante todo el intervalo. Cabe mencionar que hay un límite en el número de cambios de portadores que pueden ocurrir entre dos franjas de tiempo consecutivas, pudiendo ser cero. 

\section{Literatura} \label{sec:literatura}

El problema de planificación de las líneas de producción en el entorno de la fabricación de asientos de coche se puede clasificar dentro de la familia de problemas de dimensionamiento discreto de lotes y planificación de máquinas heterogéneas paralelas (en inglés, \textit{discrete lot-sizing and scheduling of parallel heterogeneous machines}). Este tipo de problemas ha sido ampliamente estudiado en la literatura debido a su importancia en la optimización de procesos industriales. Diversos enfoques y modelos han sido propuestos para abordar las complejidades inherentes a estos problemas. Concretamente, en \cite{copil2017simultaneous} se realiza una revisión exhaustiva y una clasificación de los modelos que abordan problemas simultáneos de dimensionamiento y planificación de lotes. Esta revisión proporciona una visión general de los enfoques y técnicas utilizados en la literatura para resolver estos problemas complejos. En esta sección, se recogen algunos problemas que tienen una mayor relación con el trabajo abordado

De Matta y Guignard desarrollaron un modelo de programación de enteros mixtos para un problema de dimensionamiento de lotes y planificación en una empresa de fabricación de azulejos \cite{de1994dynamic}. Su objetivo era minimizar la suma de los costes de producción, intercambios y mantenimiento de inventarios. Los costes de producción e intercambios dependían del producto y la línea, pero no del período de producción o la secuencia de producción. Utilizaron un enfoque de relajación lagrangiana para descomponer el problema en subproblemas de una sola línea, cuyas soluciones se combinaban para generar un programa a nivel de planta. Dado que este programa no garantizaba soluciones factibles, desarrollaron una heurística para lograr la factibilidad.

Jans y Degraeve propusieron un modelo y un procedimiento de solución para un problema de planificación de la producción en un fabricante de neumáticos \cite{jans2004industrial}. Los moldes y calentadores producen neumáticos en grandes series de ciclos de producción. El problema resultante de dimensionamiento de lotes es una extensión del problema estándar de dimensionamiento y planificación de lotes discretos \cite{wagner1958dynamic}. Las complicaciones adicionales incluyen tiempos de inicio de producción generales, múltiples máquinas alternativas con diferentes configuraciones, múltiples recursos (moldes y calentadores) y gestión de inventarios.

Güngör, Unal y Taşkın abordaron recientemente un problema similar en la industria automotriz, donde los moldes se utilizan para fundir ruedas de aluminio \cite{gungor2018parallel}. Su objetivo principal era aumentar la utilización de los recursos de producción minimizando el número de cambios. Ignoraron los tiempos de configuración y desmontaje y las restricciones de flujo de inventario porque podían tratar cada semana de producción de manera independiente. En este artículo se proponen dos formulaciones de programación de enteros mixtos, demostrando que el problema es $\mathcal{NP}$-difícil y ofreciendo una aproximación heurística.

Colmenar, Laguna y Martín-Santamaría abordan un problema similar, también en la industria automovilística, en el que, en este caso, se producen piezas metálicas para asientos de coche \cite{colmenar2024changeover}. El objetivo del problema es minimizar los tiempos de cambio en líneas de producción en un entorno complejo caracterizado por máquinas heterogéneas paralelas y una alta variedad de piezas. 

A pesar de la gran variedad de problemas estudiados, ninguno aborda un problema tan específico como el presentado en este trabajo, que contempla numerosas restricciones derivadas del cliente. Esto convierte al problema en un gran reto. Aunque se pueden extraer ideas y estrategias de la literatura para abordar restricciones concretas, ninguna resuelve este problema concreto. Adicionalmente, desde el punto de vista de la formulación matemática, existe una limitación con el alto coste de la licencia comercial. Es por ello, que este trabajo propone una heurística específica para resolver este problema de manera efectiva.

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

El objetivo de esta sección es presentar un algoritmo constructivo aleatorizado inspirado en GRASP \cite{grasp1,grasp2} con la finalidad de encontrar soluciones factibles para el problema estudiado, minimizando el número de intercambios de portadores y, de manera secundaria, mejorar los indicadores de rendimiento relacionados con el inventario. Se recuerda que una solución factible es aquella en la que se satisfacen todas las demandas de los clientes. Esta sección presenta, en primer lugar, la representación de la solución (Sección~\ref{subsec:representacion}) y luego el algoritmo propuesto (Sección~\ref{subsec:grasp}).

\subsection{Representación de la solución} \label{subsec:representacion}

Para presentar el algoritmo propuesto, es necesario definir la representación formal de una solución y las operaciones fundamentales para modificarla.

Inicialmente, se asume la creación de un catálogo de montajes compatibles con cada pista de producción \(r \in R\), considerando restricciones de capacidad y compatibilidad. Además, se define \( K_r \) como el conjunto de portadores compatibles con la pista \( r \), considerando que no todos los moldes ni todos los montajes son compatibles con todas las pistas. Esta simplificación permite evitar la necesidad de modelar explícitamente todas las restricciones inherentes a la combinación de moldes, montajes y portadores a lo largo del proceso de producción, centrando el algoritmo en la gestión de portadores en cada pista.

Una solución \( Q \) se representa como un conjunto de listas de portadores, donde cada lista \( Q_{rts} \) contiene los portadores \( k \in K_r \) asignados a la pista \( r \) en la franja horaria \( s \in S_t \) del día \( t \in T \):
\[ Q = \{Q_{rts} : r \in R, t \in T, s \in S_t\}, \]

\[ Q_{rts} = [k_1, k_2, \ldots, k_p] \text{ donde } k_i \in K_r \text{ para } i = 1, \ldots, p,\]

\noindent donde $p$ es el identificador de un portador. 

La cardinalidad \( |Q_{rts}| \) es igual al número de puestos en la pista \( r \). Inicialmente, \( Q \) refleja el estado de partida de las pistas.

Se definen dos operaciones básicas para modificar una solución \( Q \): {``Añadir''} (\( k^{rts}_{\text{add}} \)) y {``Quitar''} (\( k^{rts}_{\text{drop}} \)). La operación {``Añadir''} asigna un portador \( k \) a una posición disponible en la pista \( r \) durante la franja \( s \) del día \( t \), insertándolo en la lista \( Q_{rts} \). La operación {``Quitar''} retira un portador de la pista \( r \) en la franja \( s \) del día \( t \), eliminándolo de \( Q_{rts} \). La transición entre soluciones se representa de la siguiente manera:
\[ Q_{rts} \leftarrow Q^o_{rts} \cup \{k^{rts}_{\text{add}}\} \setminus \{k^{rts}_{\text{drop}}\} .\]

Por simplicidad, se asume que el efecto de una operación en una franja horaria \( s \) del día \( t \) persiste en todas las franjas posteriores hasta el final del horizonte de planificación, a menos que se aplique una operación posterior que involucre el portador añadido o retirado. Además, es importante considerar el número de cambios de portadores permitidos en cada franja de tiempo. 

La calidad de una solución \( Q \) se evalúa mediante dos componentes principales: el {número de intercambios} y la {desviación con respecto a los inventarios deseados}. El {número de intercambios} es la función objetivo principal a minimizar y se calcula contabilizando las operaciones \( k^{rts}_{\text{add}} \) y \( k^{rts}_{\text{drop}} \) a lo largo del horizonte de planificación. La {desviación de inventarios} se utiliza como métrica de rendimiento auxiliar, midiendo la diferencia entre los inventarios resultantes y los niveles objetivo. Adicionalmente, se verifica la {factibilidad de la solución} comprobando si se satisfacen todas las demandas de producción.

Para optimizar la eficiencia, se implementan {actualizaciones incrementales} al aplicar las operaciones. Al añadir o quitar un portador, solo se recalculan los inventarios de las partes afectadas por el cambio, desde el día \( t \) en adelante. A pesar de estas optimizaciones, es importante reconocer que la ejecución de cada operación sigue siendo computacionalmente costosa, requiriendo la actualización de \( Q \) y la revaluación de la función objetivo y la factibilidad. El diseño eficiente de estas operaciones y evaluaciones incrementales es crucial para el rendimiento de los algoritmos de optimización.


\subsection{Algoritmo constructivo basado en GRASP} \label{subsec:grasp}

El procedimiento de Búsqueda Voraz, Aleatorizado y Adaptativo, más conocido por su acrónimo GRASP (\textit{Greedy Randomized Adaptive Search Procedure}), es una metaheurística iterativa ampliamente utilizada en diferentes problemas de optimización \cite{LozanoOsorio2021,GRASPReview,Robles25}. Cada iteración de GRASP se centra en dos fases: construcción y mejora. En la fase de construcción, GRASP genera una solución factible mediante un proceso voraz y aleatorizado. Aunque GRASP típicamente incluye una fase mejora con una búsqueda local, en este trabajo  el enfoque se centra exclusivamente en la fase constructiva, generando múltiples soluciones durante un tiempo máximo establecido y seleccionando la mejor de entre ellas.

Un elemento central de la fase constructiva de GRASP es la función voraz. En el algoritmo constructivo GRASP que se propone en este trabajo, se emplean dos funciones voraces distintas, una para la selección de portadores a añadir y otra para la selección de portadores a retirar. La función voraz para añadir se evalúa el impacto de incorporar un portador específico a la solución en construcción, estimando su contribución a la reducción de la escasez de partes. Concretamente, cuantifica el número de partes en escasez que un portador candidato puede producir. Por otro lado, la función voraz para la retirada evalúa el impacto de retirar un portador, cuantificando el número de partes en escasez que dejarán de producirse al retirar el portador.

Basándose en estas dos evaluaciones voraces, esta propuesta GRASP construye dos listas de candidatos restringidas (RCL): RCL\textsubscript{add} para añadir portadores y RCL\textsubscript{drop} para eliminar portadores. La RCL\textsubscript{add} contiene los portadores mejor evaluados para ser añadidos, es decir, aquellos que ofrecen la mayor reducción potencial en la escasez de partes según la función voraz de adición. La RCL\textsubscript{drop} contiene los portadores mejor evaluados para ser retirados, es decir, aquellos que, según la función voraz de retirada, producen el menor número de partes en escasez (minimizando el impacto negativo de la retirada). La aleatoriedad se introduce al seleccionar un portador para añadir desde la RCL\textsubscript{add} y un portador para retirar desde la RCL\textsubscript{drop}, ambos de forma aleatoria dentro de sus respectivas listas. 

El algoritmo constructivo itera hasta alcanzar una solución factible o cuando se exceda el tiempo máximo que la compañía establece para obtener una solución, realizando intercambios de portadores únicamente si contribuyen a disminuir la escasez de partes. Concretamente, el pseudocódigo del algoritmo constructivo GRASP propuesto se detalla en el Algoritmo \ref{alg:grasp_constructive}. 

\begin{algorithm}[htpb]
\caption{Algoritmo constructivo GRASP}
\label{alg:grasp_constructive}
\begin{algorithmic}[1]
\STATE Entradas: \( K \), \( R \), \( T \), \( S_t \), demandas, \( Q^0 \), \( \alpha \in [0, 1] \). \label{alg:entrada}
\STATE \( Q \leftarrow Q^0 \) \label{alg:ini}
\WHILE{$Q$ no es factible \textbf{and} no se alcanza el tiempo límite}
\STATE Calcular escasez $z$ para $Q$. \label{alg:escasez}
\STATE $K_{\text{candidatos}} \leftarrow$ portadores que producen partes en escasez $z$. \label{alg:candidatos}
\IF{$K_{\text{candidatos}} = \emptyset$} \label{alg:empty_check}
\STATE \textbf{return} $Q$. \label{alg:return_infactible_1}
\ENDIF
\STATE Evaluar $K_{\text{candidatos}}$ con FunciónVoraz\textsubscript{add}. \label{alg:eval_add}
\STATE Obtener $v_{\text{mejor}}^{\text{add}}$ y $v_{\text{peor}}^{\text{add}}$. \label{alg:best_worst_add}
\STATE $\text{RCL}_{\text{add}} \leftarrow \{k \in K_{\text{candidatos}} \mid \text{FunciónVoraz}_{\text{add}}(k) \geq v_{\text{mejor}}^{\text{add}} - \alpha \cdot (v_{\text{mejor}}^{\text{add}} - v_{\text{peor}}^{\text{add}}) \}$. \label{alg:rcl_add}
\STATE Seleccionar $k_{\text{add}} \in \text{RCL}_{\text{add}}$ aleatoriamente. \label{alg:select_add}
\STATE Determinar $r^*$, $s^*$ y $t^*$ para $k_{\text{add}}$ que reduzca escasez $z$. \label{alg:determine_slot}
\STATE $K'_{\text{candidatos}} \leftarrow$ portadores en $Q_{r^*t^*s^*}$ que se pueden retirar. \label{alg:candidatos_drop}
\STATE Evaluar $K'_{\text{candidatos}}$ con FunciónVoraz\textsubscript{drop}. \label{alg:eval_drop}
\STATE Obtener $v_{\text{mejor}}^{\text{drop}}$ y $v_{\text{peor}}^{\text{drop}}$. \label{alg:best_worst_drop}
\STATE $RCL_{\text{drop}} \leftarrow \{k \in K'_{\text{candidatos}} \mid \text{FunciónVoraz}_{\text{drop}}(k) \leq v_{\text{peor}}^{\text{drop}} + \alpha \cdot (v_{\text{mejor}}^{\text{drop}} - v_{\text{peor}}^{\text{drop}}) \}$. \label{alg:rcl_drop}
\STATE Seleccionar $k_{\text{drop}} \in RCL_{\text{drop}}$ aleatoriamente. \label{alg:select_drop}
\STATE $Q_{r^*t^*s^*} \leftarrow Q_{r^*t^*s^*} \cup \{k^{r^*t^*s^*}_{\text{add}}\} \setminus \{k^{r^*t^*s^*}_{\text{drop}}\}$. \label{alg:intercambio}
\STATE Actualizar $Q$. \label{alg:actualizar}
\ENDWHILE
\STATE \textbf{return} $Q$ \label{alg:return_factible}
\end{algorithmic}
\end{algorithm}

El proceso comienza inicializando una solución (Paso~\ref{alg:ini}) y, en cada iteración, identifica las partes con escasez (Paso~\ref{alg:escasez}). Luego, genera una lista de portadores candidatos (K\textsubscript{candidatos}) que producen partes en escasez y que son candidatos para ser añadidos (Paso~\ref{alg:candidatos}). Para cada portador candidato en K\textsubscript{candidatos}, la función voraz de añadir calcula el número de partes en escasez (Paso~\ref{alg:eval_add}). Se construyen RCL\textsubscript{add} (Paso~\ref{alg:rcl_add}) y RCL\textsubscript{drop} (Paso~\ref{alg:rcl_drop}) basándose en los valores voraces de los portadores candidatos a añadir y a retirar, respectivamente. Se selecciona aleatoriamente un portador de RCL\textsubscript{add} para ser añadido (Paso \ref{alg:select_add}). A continuación, se determina la pista y la franja horaria de un día ($r^*$, $s^*$ y $t^*$ respectivamente) en la que se añadirá el portador (Paso~\ref{alg:determine_slot}). Concretamente, se selecciona aquella combinación que minimiza la escasez, evitando añadirlo en un momento temporal cuyo aporte a la solución vaya a ser insignificante (por ejemplo, si se produce después de que no se haya podido satisfacer la demanda) o bien cuando no es posible realizar cambios de portadores. Simultáneamente, se selecciona aleatoriamente un portador de RCL\textsubscript{drop} para ser retirado de la pista donde se realizará la adición (Paso~\ref{alg:select_drop}). El intercambio se realiza en la primera franja horaria válida que permita reducir la escasez (Paso~\ref{alg:intercambio}), persistiendo el cambio hasta el final del horizonte de planificación.

El algoritmo finaliza cuando se encuentra una solución factible (Paso~\ref{alg:empty_check}), \textit{i.e.}, sin escasez, cuando K\textsubscript{candidatos} está vacía (Paso~\ref{alg:return_factible}), indicando que no hay portadores disponibles que puedan reducir la escasez o cuando se excede el límite de tiempo. Es importante reconocer que, inherentemente, el constructivo propuesto no garantiza la factibilidad en todos los casos (Paso~\ref{alg:return_infactible_1}), siendo necesaria la posible implementación de procedimientos de reparación en trabajos futuros como se ha planteado en trabajos similares por medio de procedimientos de búsqueda local \cite{cavero2024solving}. 

Para mantener la claridad del pseudocódigo, se han simplificado ciertos detalles de la implementación. Es importante señalar que durante la ejecución pueden presentarse dos situaciones críticas no explícitas en el algoritmo: (1) que para un portador seleccionado $k_{\text{add}}$ no exista ninguna combinación válida de franja, pista y día ($r^*$, $s^*$, $t^*$) que cumpla con las restricciones del problema (Paso~\ref{alg:determine_slot}), o (2) que no se encuentre ningún portador candidato para ser eliminado de la pista (Paso~\ref{alg:candidatos_drop}). En ambos casos, el algoritmo retrocedería para seleccionar otro portador de la RCL\textsubscript{add} (iría al Paso~\ref{alg:rcl_add}). Si se agotan todos los candidatos de la RCL\textsubscript{add} sin encontrar una combinación viable, la solución se declarará no factible.

Por último, también es importante indicar que hay un único parámetro $\alpha$ que se utiliza para generar ambas listas RCL\textsubscript{add} y RCL\textsubscript{drop} (Pasos~\ref{alg:rcl_add}-\ref{alg:rcl_drop}). En un trabajo futuro, podría considerarse el manejo de dos parámetros $\alpha$ distintos para controlar de manera independiente el tamaño y la calidad de las listas de candidatos para añadir y retirar portadores, respectivamente, lo que podría conducir a una mejor exploración del espacio de soluciones.


\section{Experimentos} \label{sec:experimentos}

Toda la experimentación se ha desarrollado en un servidor con las siguientes características: procesador AMD EPYC 7282 (2.8 GHz), 32 cores, 8 GB de memoria RAM y Ubuntu Server 20.04. El algoritmo heurístico ha sido implementado en Java 21 utilizando el \textit{framework} de desarrollo MORK \cite{martin2024practical}, mientras que el modelo matemático se ha codificado en Python 3.9 y resuelto con Gurobi 11.0.3. Para evaluar el rendimiento de ambos enfoques, se han utilizado 60 instancias reales proporcionadas por la industria, debidamente anonimizadas para preservar la confidencialidad de los datos.

Los experimentos realizados persiguen diversos objetivos. El primero busca determinar la configuración paramétrica que maximice el número de soluciones factibles obtenidas. Esta priorización se justifica porque, en el contexto real de la industria para la cual se elabora esta investigación, encontrar una solución factible resulta más crítico que minimizar cualquier objetivo. La Figura~\ref{fig:exp:alpha} muestra, para cada valor de $\alpha$ en el rango $[0.00, 0.50]$, el número de soluciones sin escasez que se obtienen. Los valores de $\alpha$ superiores a 0.50 han sido omitidos del análisis, dado que, experimentalmente, se comprobó que ninguna configuración con estos valores logró generar soluciones sin escasez.

% EXPERIMENTO 1: Figura mostrando número de soluciones factibles según alpha
\begin{figure}[htpb] \centering 
\resizebox{0.90\textwidth}{!}{
\includegraphics[width=\linewidth]{Soluciones.pdf} 
}\caption{Número de soluciones factibles según valor $\alpha$.} \label{fig:exp:alpha} 
\end{figure}

Como puede observarse en la figura, el intervalo $[0.01-0.15]$ concentra los valores de $\alpha$ que generan mayor cantidad de soluciones factibles. Específicamente, $\alpha=0.07$ alcanza el máximo rendimiento, produciendo soluciones factibles para 38 de las 60 instancias evaluadas. Por lo tanto, este valor de $\alpha$ ha sido seleccionado para la comparación posterior con el algoritmo exacto.

% EXPERIMENTO 2: Mejoras según el número de iteraciones realizadas en los intercambios

El segundo experimento analiza la convergencia del algoritmo a lo largo del tiempo de ejecución. Cabe destacar que la empresa estableció como requisito operativo obtener soluciones en menos de 10 minutos. Por esa razón, se fijó este valor como tiempo máximo de ejecución para todas las instancias. La Figura~\ref{fig:iteraciones} muestra la evolución del promedio de intercambios (función objetivo) durante el tiempo de ejecución.

\begin{figure}[htb] \centering 
\resizebox{0.90\textwidth}{!}{
\includegraphics[width=\linewidth]{Convergencia.pdf} 
}
\caption{Evolución temporal del promedio de intercambios necesarios para todas las instancias.} \label{fig:iteraciones} 
\end{figure}

Como puede observarse en la gráfica, la reducción en el número promedio de intercambios presenta tres fases diferenciadas: una disminución significativa durante los primeros 150 segundos, seguida de una reducción más moderada hasta aproximadamente los 400 segundos, tras lo cual la convergencia se estabiliza y apenas se producen mejoras adicionales en la función objetivo hasta completar los 600 segundos (10 minutos) de ejecución.


 Finalmente, en un último experimento se compara el rendimiento del método exacto (Gurobi) frente a la propuesta constructiva GRASP. Cabe señalar que el análisis se centra en las 38 instancias para las cuales se encontró una solución factible. Los resultados obtenidos se presentan en la Tabla~\ref{tab:exacto}. Las métricas reportadas son: Intercambios (promedio entre todas las instancias), Inventario (desviación respecto a los inventarios objetivo), Tiempo (s) y \#Óptimo (número de soluciones óptimas encontradas).



% EXPERIMENTO 3: Tabla final comparativa con Gurobi frente a soluciones factibles

\begin{table}[htpb]
    \centering
    \caption{Resultados de Gurobi frente a la propuesta sobre las instancias que encuentran solución.}
    \vspace{0.2 cm}
    \label{tab:exacto}
    \begin{tabular}{lrrrrrr}
    \toprule
    \textbf{Algoritmo}      & \textbf{Intercambios}                & \textbf{Inventario}  & \textbf{Tiempo (s)}    & \textbf{\#Óptimo}       \\ \midrule
Gurobi	&   16,87	&	987,12	&	16,16 & 38	\\	\midrule
Constructivo GRASP	&		18,55	&	1069,63	& 600,00 &	25	\\	\bottomrule

    \end{tabular}
\end{table}

La Tabla~\ref{tab:exacto} evidencia que Gurobi obtiene la solución óptima en 16,16 segundos.  En contraste, el método constructivo GRASP, con un tiempo de cómputo limitado a 600 segundos, se desvía un 7,30\% del óptimo, pero identifica 25 soluciones óptimas de las 38 instancias consideradas. En promedio, Gurobi requiere 16,87 intercambios frente a 18,55 de GRASP. Es importante destacar que, en la práctica industrial, dos intercambios adicionales podrían implicar un coste inferior a la implementación de la solución exacta.



\section{Conclusión} \label{sec:conclusion}

En este artículo, se ha abordado un problema de planificación de la producción en la industria de fabricación de asientos para automóviles, caracterizado por líneas de producción heterogéneas y una gran variedad de productos. Ante la complejidad del problema, derivado directamente de la industria, así como las limitaciones de los modelos exactos en términos de coste computacional y requisitos de software, se ha propuesto un algoritmo heurístico constructivo basado en la metaheurística GRASP.

Los resultados experimentales obtenidos con 60 instancias reales proporcionadas por la industria demuestran la eficacia del algoritmo GRASP propuesto, obteniendo soluciones factibles para 38 de las 60 instancias en un tiempo máximo de ejecución de 600 segundos, cumpliendo así con los requisitos operativos de la empresa. De la comparación con el modelo exacto resuelto por Gurobi se puede concluir que el constructivo GRASP resulta una alternativa eficiente en tiempo computacional y sin la dependencia de software comercial.

Si bien el algoritmo constructivo GRASP no garantiza la optimalidad global ni la factibilidad en todos los casos, representa un punto de partida sólido para futuras investigaciones en este campo. Como líneas de investigación futuras, se plantea el desarrollo e integración de fases de búsqueda local, la implementación de mecanismos de reparación, o el planteamiento de otros criterios voraces para el constructivo propuesto.

\begin{ack}
Esta investigación ha sido parcialmente financiada mediante subvenciones: PID2021-125709OA-C22, financiado por MCIN/AEI/10.13039/501100011033; ``Proyectos Impulso de la Universidad Rey Juan Carlos 2024'' con referencia 2024/SOLCON-135988; CIRMA-CM Ref. TEC-2024/COM-404 financiado por la Comunidad Autónoma de Madrid; TSI-100930-2023-3 (MCA07) financiado por Ministerio para la Transformación Digital y de la Función Pública. También, los autores quieren agradecer por haberles permitido realizar esta investigación y su difusión a \href{https://www.bettersolv.com/}{Better Business Analytics}, consultora con la que colaboran los autores. 


%Do {\bf not} include this section in the anonymized submission, only in the final paper. You can use the \texttt{ack} environment provided in the style file to automatically hide this section in the anonymized submission.
\end{ack}

\renewcommand{\bibfont}{\fontsize{9}{9}\selectfont}
\printbibliography




\end{document}