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


% 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{babel}[spanish]
\usepackage{amsmath}
\usepackage{graphicx} 
\usepackage{algorithmic}
\usepackage[linesnumbered,norelsize,ruled,vlined]{algorithm2e}


\title{Un enfoque matheurístico para el problema de la \textit{p}-mediana inducida con mejora}


% 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 Salazar \\
  Dpto. de Informática y Estadística\\
  Universidad Rey Juan Carlos\\
  Madrid, Móstoles, 28933 \\  \texttt{sergio.salazar@urjc.es} \\
  \And
  J. Manuel Colmenar \\
  Dpto. de Informática y Estadística\\
  Universidad Rey Juan Carlos\\
  Madrid, Móstoles, 28933 \\  \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}
  Los problemas de ubicación de instalaciones (FLPs por sus siglas en inglés) son una familia de problemas de optimización con gran impacto social. En concreto, el problema de la \textit{p}-mediana inducida con mejora (\textit{Induced p-median Problem with Upgrading}, IpMU) es una variación del problema clásico de la \textit{p}-mediana, donde se separan los conceptos de coste de transporte y distancia en dos grafos distintos. Además, se añaden un conjunto de variables de decisión para relajar el grafo de costes, de manera que las aristas entre nodos pueden ser reducidas para mejorar las rutas asociadas entre las medianas elegidas y los clientes. En este trabajo se propone un algoritmo matheurístico donde se establece un esquema de resolución en dos fases, estudiando el problema de medianas y el problema de mejora de manera independiente. En esta aproximación se obtienen resultados prometedores en comparación con el estado del arte, basado completamente en modelos matemáticos, pero con amplio margen de mejora para el trabajo futuro.
\end{abstract}


\section{Introducción}
La familia de problemas relacionados con la ubicación de instalaciones, conocidos en inglés como \textit{Facility Location Problems} (FLPs), ha despertado un gran interés en la comunidad de investigación operativa. Estos problemas se centran en determinar la ubicación óptima de un conjunto de elementos en diversos entornos, como espacios industriales, redes de infraestructura físicas como carreteras, e incluso redes informáticas \cite{hale2003location} \cite{farahani2012covering}.

Los problemas de ubicación de instalaciones se clasifican según el dominio del problema. En su vertiente continua no existe un conjunto candidato para las ubicaciones, sino que se considera una zona acotada del plano. En este grupo se pueden encontrar algunos problemas clásicos, como el Problema de Weber \cite{cooper1981weber}, y aproximaciones más recientes, como el problema de ubicación de múltiples instalaciones desagradables (\textit{Multiple Obnoxious Facilities Location Problem}, MOFLP) \cite{drezner2019planar} \cite{locatelli2024new}.

En su variante combinatoria, los problemas de ubicación identifican un conjunto de candidatos donde colocar las instalaciones. Normalmente, este conjunto se define como un subconjunto de nodos en un grafo, donde las aristas representan comunicaciones, que pueden estar ponderadas atendiendo a diferentes métricas como las distancias o los costes. Un ejemplo clásico es el problema de la \textit{p}-mediana \cite{daskin2015p}, que busca seleccionar $p$ nodos de forma que se minimice la distancia del resto al conjunto de medianas. Por otro lado, existen variantes alternativas como el problema de la \textit{p}-mediana desagradable (\textit{obnoxious p-median}) donde se busca maximizar la mínima distancia de cada nodo al conjunto de medianas \cite{herran2020parallel}, o el problema de la \textit{p}-mediana ponderada (\textit{weighted p-median}) donde, además de seleccionar la localización, se debe cumplir la demanda de los nodos clientes \cite{berman2010network}.

Entre estas variantes combinatorias destaca el problema de la \textit{p}-mediana inducida con mejora (\textit{Induced p-Median Problem With Upgradings}, IpMU) \cite{espejo2023p}. Esta variante del problema de la \textit{p}-mediana busca minimizar el coste de comunicar el conjunto de nodos del grafo con el conjunto de medianas seleccionadas. Sin embargo, separa los conceptos de tiempo de transporte (distancia) y coste; de esa manera, las aristas del grafo de la instancia estarán ponderadas por dos valores, representando ambas métricas. Los nodos serán asignados según el tiempo de transporte, tomando siempre el camino más corto del conjunto de medianas al nodo, pero el coste será calculado mediante el segundo valor. Esta versión del problema se acerca más a un escenario real donde los valores de tiempo de transporte (distancia) y coste no tienen por qué estar siempre relacionados.
%imagínese el lector una empresa de reparto que asiste a las poblaciones de la Península Ibérica, conectadas por tierra utilizando camiones lentos, pero baratos; y a las islas de España, donde puede utilizar medios mucho más rápidos como aviones, pero menos económicos. 
Además de esta característica, el problema añade una variable de presupuesto que permite relajar los valores de coste asociados a las aristas, compensando el coste. De esta manera, se pueden obtener mejores valores en la función objetivo del problema \cite{espejo2023p}.

Para la resolución de este problema se ha optado por el diseño de un algoritmo matheurístico que combina la aplicación de modelos matemáticos con una metodología metaheurística basada en el procedimiento de búsqueda adaptativo aleatorizado y voraz (\textit{Greedy Randomized Adaptative Search Procedure}, GRASP)\cite{feo1995greedy}. En este trabajo se opta por una resolución en dos fases donde se separan el problema de ubicación del problema de relajación de aristas. En la primera fase se utilizará un algoritmo GRASP para la selección de medianas del problema, mientras que en la segunda fase se utiliza un modelo matemático para obtener la relajación óptima del grafo. En la comparación con el estado del arte, la propuesta matheurística obtiene todos los valores óptimos salvo uno, empleando un 33\% menos de tiempo en las instancias más complejas.


%El estado del arte del IpMU consiste en tres modelos matemáticos que certifican la optimalidad de las 960 instancias estudiadas. Estas instancias se componen por diferente número de nodos del grafo ($n\in\{20,40,60,80\}$), diferente número de medianas a colocar ($p\in\{2,3,4,5\}$) y por la existencia o no de correlación entre la métrica de coste y de tiempo de transporte.

El resto del artículo se organiza de la siguiente manera: en la Sección \ref{sec:Definición} se describe formalmente la modelización del problema; en la Sección \ref{sec:PropuestaAlgoritmica} se desarrolla la propuesta de este trabajo para la resolución del problema IpMU; en la Sección \ref{sec:Resultados} se hace una descripción del estado del arte y de la experimentación realizada, así como una comparativa sobre las instancias estudiadas; finalmente, en la Sección \ref{sec:Conclusiones} se describen las conclusiones del trabajo y se apuntan vías de mejora.


\section{Definición formal del problema}
\label{sec:Definición}
Para mayor completitud del artículo, se propone en esta sección una formalización detallada del problema a partir de la propuesta del estado del arte \cite{espejo2023p}. Sea $G=(V,A)$ un grafo dirigido, se considera que todos los nodos $V=\{1,...,n\}$ representan clientes del problema. Cada cliente $i \in V$ tiene asignada una demanda $\omega_i \geq 0$. Sean $c^1$ y $c^2$ el conjunto de costes asociado al conjunto de aristas del grafo, para cierta arista $a \in A$ se denomina $c_a^1 \geq 0$ al tiempo de transporte por $a$ y a $c_a^2\geq 0$ el coste de transporte por unidad de $a$.

Siguiendo la modelización original, se define el conjunto de nodos $V$ como el conjunto de candidatos para ser seleccionados como medianas, de las que deben ser escogidas $1\leq p < n$ de ellas. Una vez el conjunto $S=\{s_1,...,s_p\}$ de medianas es establecido, cada usuario debe ser servido por la mediana con menor tiempo de transporte. Más formalmente, sea $FP(i,j) \subset A$ el camino más corto desde el nodo $j\in V$ al nodo $i\in V$ según la medida $c^1$, la longitud de $FP(i,j)$ se define como $C_{i,j}^1$. Por tanto, cada cliente $i\in V$ será servido por la mediana $s\in S$ tal que $C_{s,i}^1\leq C_{s',i}^1 \;\forall s' \in S$. Además se define el coste de transporte por unidad $C^2_{i,j}$ entre $i\in V$ y $j\in V$ como la suma de los costes $c^2$ asociados a $FP(i,j)$, es decir, $C^2_{i,j} = \sum\limits_{a\in FP(i,j)} c^2_a$.

%Siguiendo estas definiciones y considerando $X\subset V$, se define $FP(i,X) \subset A$ el conjunto de aristas del grafo que componen los caminos más cortos a $i$ desde cualquier nodo $j$: $FP(i,X) = \bigcup\limits_{j\in X}FP(i,j)$. 

Finalmente, se define el presupuesto $B>0$ como el valor que puede ser utilizado para reducir el coste de transporte asociado a las aristas. La relajación para cada arco $a\in A$ del grafo está limitada por $u_a$.

El IpMU consiste en identificar $p$ medianas y distribuir el presupuesto $B$ entre los arcos del grafo de forma que se minimice la suma del coste de transporte de las medianas a sus correspondientes clientes, ponderados por la demanda solicitada.

La formulación del problema se muestra en la Ecuación \eqref{eq:obj}, para la que se necesitan definir las siguientes variables:
\begin{itemize}
    \item $x_{jj} \in \{0,1\}$: Si el nodo $j$ es elegido como mediana.
    \item $x_{ij} \in \{0,1\}$: Si el nodo $j$ es la mediana más cercana de $i$.
    \item $b_a \in [0,u_a]$ : La reducción del coste de transporte aplicada a la arista $a\in A$
\end{itemize}

\begin{equation} \label{eq:obj}
\begin{array}{lll}
\min &   \sum\limits_{i\in V} \omega_i \sum\limits_{j\in V} (C^2_{i,j} - \sum\limits_{a\in FP(i,j)} b_a)x_{ij}    & \\
\mbox{s.t.}&   &       \\
    &  x_{ij} \leq x_{jj}, & \forall i \neq j \in V ,\\
    & \sum\limits_{j\in V} x_{ij} = 1, & \forall i \in V,\\
    & \sum\limits_{j\in V} x_{jj} = p, & \\
    & x_{jj} + \sum\limits_{\substack{ s\in V:\\ C^1_{is} > C^1_{ij} }} x_{is} \leq 1, & \forall i,j\in V,\\
    & \sum\limits_{a\in A} b_a \leq B, & \\
    & b_a \leq u_a, & \forall a \in A \\
    & b_a \geq 0, & \forall a \in A \\
    & x_{ij} \in \{0,1\},& \forall i,j \in V.
\end{array}
\end{equation}

En la Figura \ref{fig:ejemplo} se presenta una instancia de ejemplo para el IpMU donde se muestran los dos valores de cada arista duplicando el grafo. En este caso, se considera un presupuesto $B=2$, una capacidad máxima de mejora para cada arista dada por $u_a=c^2_a$  y una demanda uniforme $\omega_i = 1$ para todos los clientes. La cantidad de medianas a colocar es $p=2$. Aunque el modelo supone que los nodos del grafo están numerados de 1 a $n$, para facilitar la comprensión del ejemplo, se han etiquetado con las letras de la $A$ a la $E$.
\begin{figure}[h]
    \centering
    \includegraphics[width=0.60\linewidth]{Figuras/EjemploIpMU.drawio.pdf}
    \caption{Ejemplo instancia IpMU. Se asume un presupuesto de $B=2$, una capacidad de mejora $u_a=c^2_a$, una demanda $\omega_i=1$ y una cantidad de medianas a colocar $p=2$.}
    \label{fig:ejemplo}
\end{figure}

En este caso, la solución óptima para esta instancia, ilustrada en la Figura \ref{fig:sol_ejemplo}, consiste en ubicar las medianas en los nodos $A$ y $E$. El nodo $A$ atenderá a los nodos $B$ y $C$, ya que es su mediana más cercana. Por otro lado, el nodo $D$ será atendido por la mediana $E$ mediante la arista que los conecta. En cuanto a la asignación de presupuesto de mejora, se destinan las dos unidades a reducir el coste de la arista $A-B$, aprovechando que esta aparece en los caminos  $FP(A,B)$ y $FP(A,C)$. El valor final de la función objetivo, calculada según el coste de transporte, es de 8 unidades: 6 unidades en el camino $FP(A,C)$, 0 unidades en el camino $FP(A,B)$ y 2 unidades en el camino $FP(E,D)$. 

\begin{figure}
    \centering
    \includegraphics[width=0.60\linewidth]{Figuras/solution.drawio (1).pdf}
    \caption{Representación de la solución óptima para la instancia de la Figura \ref{fig:ejemplo}.}
    \label{fig:sol_ejemplo}
\end{figure}




\section{Propuesta algorítmica}
\label{sec:PropuestaAlgoritmica}
El enfoque seguido por el estado del arte es la linealización del modelo observado en la Ecuación \eqref{eq:obj}. En ese trabajo se proponen 3 modelos lineales distintos, de los cuales uno de ellos (\textit{FL1} en \cite{espejo2023p}) obtiene los mejores resultados en tiempo de ejecución. 

La propuesta de este trabajo es un algoritmo matheurístico \cite{ngoo2024survey}. Estos algoritmos están caracterizados por aunar una propuesta metaheurística con modelos exactos. En este caso, el esquema principal del algoritmo está basado en la metodología GRASP \cite{feo1995greedy} donde se combina una construcción voraz aleatorizada con una fase de mejora en un esquema multiarranque. En cada construcción del algoritmo GRASP se seleccionarán las medianas que formarán parte de una solución. Para su evaluación, es necesario identificar las aristas del grafo de costes que serán relajadas. Este conjunto de aristas se determina mediante la resolución de un modelo matemático, que obtiene el conjunto óptimo de aristas relajadas en función de las medianas escogidas.

\subsection{Resolución del subproblema de relajación de aristas.}
En primer lugar, se define la solución del subproblema de relajación, ya que este se incorpora en el cuerpo del algoritmo de resolución del IpMU. En distintas fases del algoritmo se partirá de una solución total o parcial, que consiste en un conjunto de nodos seleccionados como medianas. Con este conjunto se ejecutará un modelo que obtiene la relajación del grafo de costes que minimiza la función objetivo.

Sea $S' = \{s_1,...,s_q\}$ el conjunto de medianas seleccionadas, tal que $q\leq p$. En el caso de que se deba evaluar una solución parcial para el problema ($q<p$) su calidad vendrá definida por la calidad de esa solución en el problema restringido a $q$ medianas. %, es decir, la misma instancia del problema, pero asumiendo que se requiere un número de medianas menor a escoger. 
En esta situación, véase que siguiendo la formulación del modelo en la Ecuación \eqref{eq:obj}, las variables $x_{jj}$ y $x_{ij}$ toman el valor correspondiente según las medianas seleccionadas, mientras que aún falta por asignar las variables $b_a$.

En estas condiciones, los valores $FP(i,j), C^1_{ij}$ y $C^2_{ij}$ son constantes, ya que únicamente dependen de la selección de medianas. Siguiendo esta idea, se define el modelo del problema IpMU supeditado a $S'$ en la Ecuación \eqref{eq:obj_givenmeds}. La solución de este modelo utiliza los valores anteriormente mencionados, que son constantes en la instancia, y la eliminación de restricciones no relacionadas con $b_a$. Nótese que el modelo de la Ecuación \eqref{eq:obj_givenmeds} no depende en ningún caso del valor $p$ por lo que se puede obtener la relajación para una solución completa o parcial.
%De esta forma se puede obtener el modelo del problema supeditado a un conjunto de medianas en la Ecuación \eqref{eq:obj_givenmeds}, obtenido precalculando estos valores y eliminando las restricciones que no presenten relación con $b_a$
\begin{equation} \label{eq:obj_givenmeds}
\begin{array}{lll}
\max &   \sum\limits_{i\in V}  \sum\limits_{\substack{j\in V : \\ x_{ij}=1}}  \sum\limits_{a\in FP(i,j)} \omega_ib_a   & \\
\mbox{s.t.}&   &       \\
    
    & \sum\limits_{a\in A} b_a \leq B, & \\
    & b_a \leq u_a, & \forall a \in A \\
    & b_a \geq 0, & \forall a \in A \\
\end{array}
\end{equation}

%Véase que la transformación se ha obtenido eliminando los valores constantes de la función objetivo y  transformándolo en un problema de maximización (por limpieza en la formulación); por otro lado, se han eliminado todas las restricciones asociadas a las medianas, que ya no son variables de decisión del problema.

El modelo propuesto consiste en un problema lineal con $|A|$ variables y $2|A|+1$ restricciones, lo que implica una gran simplificación respecto al modelo inicial. Para cada construcción de una solución en las distintas fases del algoritmo se lanzará la resolución del modelo, obteniendo así la relajación del grafo de costes y permitiendo el cálculo de la función objetivo (denotada como $\mathcal{F}$) para la solución total o parcial estudiada ($S$), siguiendo el esquema que se muestra en el Algoritmo \ref{alg:evaluate}. En el paso \ref{alg:evaluate:s0} del algoritmo se inicializa la matriz $x$ de asignaciones a 0. Posteriormente, por cada mediana $j$ escogida se establece la variable $x_{jj}$ a 1 y se imponen las variables $x_{ij}$ de forma que la mediana $j$ sea la más cercana al nodo $i$ (pasos \ref{alg:evaluate:xjj} a \ref{alg:evaluate:endfor}). En el paso \ref{alg:evaluate:b} se establece el vector de valores reales $b$, donde $b_a$ representa la relajación impuesta a la arista $a$ del grafo de costes. Este valor se obtiene ejecutando el modelo de la Ecuación \eqref{eq:obj_givenmeds}, representado por la función \textit{relaxEdges}. Finalmente, una vez todas las variables han sido establecidas, se devuelve el valor de la función objetivo. 


\begin{algorithm}[!htp]
\begin{algorithmic}[1]
    %\STATE $x \gets \{x_{11},x_{12},...,x_{nn}\}$
    \STATE $x \gets \{0\}_{n\times n}$ \label{alg:evaluate:s0}
    %\STATE $x_{ij} \gets 0 \; \forall i,j \in V$
    \STATE $x_{jj} \gets 1 \; \forall j \in S$ \label{alg:evaluate:xjj}
    \FOR{$j \in S$} \label{alg:evaluate:for}
        \STATE $x_{ij} \gets 1\; \forall i \in \{i\in V : C^1_{i,j} \leq C^1_{i,k}\;  \forall k \in S\}$
    \ENDFOR \label{alg:evaluate:endfor}
    \STATE $b \gets relaxEdges(x)$ \label{alg:evaluate:b}
    \RETURN $\sum\limits_{i\in V} \omega_i \sum\limits_{j\in V} (C^2_{i,j} - \sum\limits_{a\in FP(i,j)} b_a)x_{ij} $
\end{algorithmic}
\caption{$\mathcal{F}(S)$}
\label{alg:evaluate}
\end{algorithm}

 

Véase que la propuesta de separar el conjunto de aristas, a través de una resolución óptima dado el conjunto $S$, aligera en gran medida la combinatoria con la que el algoritmo metaheurístico debe trabajar. De este modo, únicamente deberá escoger $p$ medianas sobre un total de $n$ nodos, es decir, hay un total de $\binom{n}{p}$ soluciones, que aunque sigue un comportamiento factorial, es mucho menor que incluir las aristas del grafo que toma valores continuos, ya que $b_a$ es un valor no discreto.


\subsection{Algoritmo para la selección de medianas}
La propuesta para la resolución del IpMU está basada en un algoritmo GRASP \cite{feo1995greedy}. Este algoritmo consta de una fase de construcción aleatorizada y una fase de mejora que ha sido implementada a través de una búsqueda local.

\subsubsection*{Fase constructiva}
El Algoritmo \ref{alg:GRASP_build} muestra el pseudocódigo de selección de medianas para el problema IpMU. En el primer paso se inicializa una solución vacía, a la que se irán añadiendo las medianas elegidas por el algoritmo. Seguidamente, en el paso \ref{GRASP_build:CL0}, se inicializa la lista de candidatos ($CL$) que incluye todos los nodos del grafo. Posteriormente se comienza el bucle principal del algoritmo. Se identifican $f_{max}$ y $f_{min}$ como los valores máximo y mínimo tras evaluar la inclusión de todos los nodos candidatos a la solución $S$ (pasos \ref{alg:GRASP_Buildfmax} y \ref{alg:GRASP_Buildfmin}). Con estos valores y el parámetro $\alpha$, recibido como entrada, se establece un valor umbral $th$ (paso \ref{alg:GRASP:th}) para construir la lista de candidatos restringida ($RCL$), que incluye aquellos nodos cuya evaluación está por debajo del umbral $th$ al añadirse a la solución (paso \ref{alg:GRASP_BuildRCL}). Entre estos elementos se escoge uno de manera aleatoria, se añade a la solución y se elimina de $CL$ (pasos \ref{alg:GRASP:rnd} hasta \ref{alg:GRASP:minus}). Una vez la solución alcanza $p$ medianas escogidas, el bucle principal termina y se devuelve la solución.


\begin{algorithm}[!htp]
\begin{algorithmic}[1]
    \STATE $S \gets \emptyset$
    \STATE$CL \gets V$  \label{GRASP_build:CL0}
    \WHILE{$|S| < p$}
        \STATE $f_{max} \gets \max\limits_{i \in CL} \mathcal{F}(S\cup \{i\})$ \label{alg:GRASP_Buildfmax}
        \STATE $f_{min} \gets \min\limits_{i \in CL} \mathcal{F}(S\cup \{i\})$ \label{alg:GRASP_Buildfmin}
        \STATE$th \gets f_{max} + \alpha \cdot (f_{min} - f_{max})$  \label{alg:GRASP:th}
        \STATE$RCL \gets \{i \in CL: \mathcal{F}(S\cup \{i\}) \leq th\}$  \label{alg:GRASP_BuildRCL}
        \STATE$s \gets random(RCL)$ \label{alg:GRASP:rnd}
        \STATE$S \gets S \cup \{s\}$
        \STATE$CL \gets CL\setminus\{s\}$ \label{alg:GRASP:minus}
    \ENDWHILE
    \RETURN $S$
 \end{algorithmic}
 \caption{$GRASPBuild(\alpha, V)$}
 \label{alg:GRASP_build}
\end{algorithm}



\subsubsection*{Fase de mejora}
La fase de mejora del algoritmo GRASP está implementada a través de una búsqueda local definida por un movimiento de intercambio en el conjunto de medianas. Este movimiento consiste en eliminar un nodo $i\in S$ e introducir un nuevo nodo $j\in V\setminus S$.

%Como se puede observar en el modelo del IpMU en la Ecuación \eqref{eq:obj}, no existe ninguna restricción de factibilidad entre las medianas, es decir, la presencia de un nodo en el conjunto $S$ no implica la imposibilidad de introducir cualquier otro del grafo. Esto implica que la cantidad de movimientos posibles en cada iteración de la búsqueda local, es decir el tamaño del vecindario, siempre sea el mismo: $|S| \cdot (|V| - |S|) = p \cdot (n-p)$.


En el Algoritmo \ref{alg:SWAP_LS} se muestra el pseudocódigo de este procedimiento. Véase que la estrategia de búsqueda implementada es \textit{Best Improvement} \cite{hansen2006first}, es decir, se explora todo el vecindario en busca del mejor movimiento posible. En el primer paso se establece una solución $S_{best}$ que almacenará la mejor solución encontrada por el algoritmo.  Seguidamente se inicia un bucle que finalizará al encontrar un mínimo local.
En cada iteración del bucle se busca el movimiento que suponga la mayor mejora de calidad de la solución actual, que será almacenada en $S'$, inicializada, a su vez, en el paso \ref{alg:SWAP_LS:s'}. Para identificar el movimiento se itera entre las medianas y los nodos clientes, construyendo una solución candidata resultado del intercambio de ambos elementos (pasos \ref{alg:SWAP_LS:fori} hasta \ref{alg:SWAP_LS:sp}). En el paso \ref{alg:SWAP_LS:IF} se comprueba si la nueva solución es mejor, en cuyo caso se almacena en $S'$, es decir, se ha encontrado una mejora en el vecindario actual. En ese caso, la nueva solución se almacena en $S_{best}$ y se cambia la variable $mejora$ para repetir la búsqueda en el vecindario de la nueva solución (pasos \ref{alg:SWAP_LS:ifml} hasta \ref{alg:SWAP_LS:endifml}). Finalmente, se devuelve la mejor solución encontrada. Este método se puede adaptar de manera sencilla a la estrategia \textit{First Improvement}, donde se cambia de solución cuando se encuentra un movimiento que mejora la calidad de la solución actual.

\begin{algorithm}[!htp]
\begin{algorithmic}[1]
\STATE $S_{best} \gets S$
\STATE $mejora \gets true$
\WHILE{$mejora$}
    \STATE $mejora \gets false$
    \STATE $S' \gets S_{best}$ \label{alg:SWAP_LS:s'}
    \FOR{$j \in S_{best}$} \label{alg:SWAP_LS:fori}
        \FOR{$i \in V\setminus S_{best}$}
            \STATE $S'' \gets S'\cup\{{i}\} \setminus \{j\}$ \label{alg:SWAP_LS:sp}
            \IF{$\mathcal{F}(S'') < \mathcal{F}(S')$} \label{alg:SWAP_LS:IF}
                \STATE $S' \gets S'' $
            \ENDIF
        \ENDFOR
    \ENDFOR    

    \IF{$\mathcal{F}(S') < \mathcal{F}(S_{best})$}\label{alg:SWAP_LS:ifml}
        \STATE$mejora \gets true$
        \STATE $S_{best} \gets S'$
    \ENDIF\label{alg:SWAP_LS:endifml}
    
\ENDWHILE

\RETURN $S_{best}$
\end{algorithmic}
\caption{$SwapLS(S)$}
\label{alg:SWAP_LS}
\end{algorithm}



\subsubsection*{Propuesta final}
El algoritmo de selección de medianas propuesto sigue un esquema GRASP multiarranque. En el Algoritmo \ref{alg:GRASP} se muestra el pseudocódigo del algoritmo completo. El procedimiento comienza con una solución $S_{best}$ que irá almacenando la mejor solución conocida. Posteriormente, en el paso \ref{alg:GRASP:for} se inicia el bucle característico de los algoritmos multiarranque. En cada una de las iteraciones se construirá una solución a través del método \textit{GRASPBuild} (línea \ref{alg:GRASP:build}) y se mejorará  con la búsqueda local \textit{SwapLS} hasta encontrar un mínimo local (línea \ref{alg:GRASP:mejora}). En el caso de que se encuentre una solución mejor, esta es almacenada. Una vez se alcanza el número de iteraciones del algoritmo, se devuelve la mejor solución identificada.

\begin{algorithm}[!htp]
\begin{algorithmic}[1]
\STATE $S_{best} \gets \emptyset$
\FOR{$1$ \textbf{to} $iters$} \label{alg:GRASP:for}
    \STATE $S \gets GRASPBuild(\alpha,V)$ \label{alg:GRASP:build}
    \STATE $S \gets SwapLS(S)$ \label{alg:GRASP:mejora}    
    \IF{$\mathcal{F}(S) < \mathcal{F}(S_{best})$}
        \STATE $S_{best} \gets S$
    \ENDIF
\ENDFOR
\RETURN $S_{best}$
\end{algorithmic}
\caption{$MAT-GRASP(\alpha,V,iters)$}
\label{alg:GRASP}
\end{algorithm}



\section{Resultados experimentales}
\label{sec:Resultados}
En esta sección se describen los resultados experimentales obtenidos al aplicar el algoritmo diseñado para el IpMU. Los experimentos se han ejecutado en una maquina virtual equipada con un porcesador AMD EPYC 7282 16-core con 16GB de RAM. El código se ha desarrollado en \texttt{Java 21.0.1} utilizando el framework MORK\footnote{\url{https://github.com/mork-optimization/mork}} versión 0.20 \cite{MORK2}. Finalmente se ha utilizado \texttt{Gurobi 11.0} para la resolución del problema de relajación de aristas descrito en la Sección \ref{sec:PropuestaAlgoritmica}.

%El desarrollo de este algoritmo ha sido impulsado a través del Metaheuristic Optimization framewoRK  Este framework asiste al desarrollador con un marco básico para la implementación de algoritmos metaheurísticos con la posibilidad de creación de elementos a bajo nivel. Se redirige al lector al enlace del pie de página para más información.

Durante la experimentación se ha utilizado el conjunto de instancias presentadas en el artículo previo \cite{espejo2023p}. Las instancias se dividen en 2 grupos principales según las características del grafo de costes. El primer grupo denominado ``Instancias P'' genera el grafo de costes de manera que exista una correlación entre los valores de las aristas con el grafo de tiempo de transporte. Más específicamente, $c^2_a = c^1_a +U$, donde $U \sim (1,1.5)$; mientras que en el segundo grupo, denominado ``Instancias R'', todos los costes son establecidos de manera aleatoria e independiente. 

Para ambos conjuntos, el resto de parámetros se toman de los siguientes conjuntos: $n\in\{20,40,60,80\}$, $m\in[100,500]$, $p\in\{2,3,4,5\}$ y $B\in\{50,100\}$. Por cada combinación se han construido un total de 5 instancias. Por último, la demanda de cada nodo es $w_i\in[0,40]$ y el límite de relajación de las aristas es la mitad de su coste total, es decir, $u_a = 0.5 \cdot c_a^2$. Resumiendo, se generan 480 instancias por conjunto, obteniendo un total de 960 instancias donde el algoritmo matheurístico ha sido ejecutado y comparado con el estado del arte.

\subsection{Selección de parámetros}
\label{sub:ParamSelec}
Para el desarrollo de la propuesta final se realizó una experimentación preliminar para determinar el valor de dos parámetros del experimento:
\begin{itemize}
    \item El parámetro $\alpha$, que determina el grado de voracidad de la construcción GRASP. En este caso se probaron 5 valores distintos: $\{0.00,0.25,0.50,0.75,1.00\}$
    \item La estrategia de búsqueda local, que puede ser \textit{First Improvement} o \textit{Best Improvement} \cite{hansen2006first}.
\end{itemize}

Por otro lado, el número de iteraciones del algoritmo ha sido establecido de manera experimental tratando de mantener un equilibrio entre la calidad de las soluciones encontradas y el tiempo de ejecución empleado. En este caso se ha establecido un total de 100 iteraciones para el procedimiento multiarranque.

La combinatoria obtiene, por tanto, un total de $10$ configuraciones distintas que fueron probadas en un subconjunto aleatorio de 200 instancias, que representan el $20.8\%$ de las instancias totales estudiadas en el trabajo. Este subconjunto fue obtenido con el propósito de evitar un sobreajuste de los resultados en el conjunto total de instancias\cite{nguyen2021influence}.

La Tabla \ref{tab:config} muestra los resultados de las 10 configuraciones de parámetros en las 200 instancias de prueba. La primera columna (\textit{Configuración}) muestra la configuración  de parámetros estudiada, la segunda columna (\textit{Avg. F(S)}) muestra el promedio del valor de la función objetivo, la tercera columna (\textit{Tiempo(s)}) muestra el promedio del tiempo de ejecución del algoritmo, la cuarta columna (\textit{Dev (\%)}) muestra el porcentaje promedio de la desviación del valor obtenido por la configuración respecto al mejor valor obtenido en cada instancia, y finalmente, la quinta columna (\textit{Bests}) muestra la cantidad de veces que el algoritmo alcanza el mejor valor obtenido en términos de la función objetivo.

\begin{table}[!ht]
    \centering
    
    \caption{Resultados de las 10 configuraciones del algoritmo en un subconjunto aleatorio de 200 instancias.\newline}
    \label{tab:config}
    \begin{tabular}{lrrrr}
        \toprule
        Configuración & \multicolumn{1}{l}{Avg. F(S)} & \multicolumn{1}{l}{Tiempo (s)} & \multicolumn{1}{l}{Dev. (\%)} &  \multicolumn{1}{l}{Bests} \\ \midrule
        \textit{Best Improvement}, $\alpha=0.00$ \hspace{5mm} & 56862.072 & 28.0 & 2.70\% & 168 \\ 
        \textit{Best Improvement}, $\alpha=0.25$  & \textbf{55367.159} & 27.8 & \textbf{0.00\%} & \textbf{200 }\\ 
        \textit{Best Improvement}, $\alpha=0.50$  & \textbf{55367.159} & \textbf{27.6} & \textbf{0.00\%} &\textbf{ 200} \\ 
        \textit{Best Improvement}, $\alpha=0.75$  & 55987.270 & 27.7 & 1.12\% & 187 \\ 
        \textit{Best Improvement}, $\alpha=1.00$  & 55926.367 & 27.7 & 1.01\% & 188 \\ \midrule
        \textit{First Improvement}, $\alpha=0.00$  & 56994.953 & 25.4 & 2.94\% & 165 \\ 
        \textit{First Improvement}, $\alpha=0.25$ & 56164.446 & 26.0 & 1.44\% & 185 \\ 
        \textit{First Improvement}, $\alpha=0.50$ & 55610.774 & 27.7 & 0.44\% & 195 \\ 
        \textit{First Improvement}, $\alpha=0.75$ & 56491.112 & 27.9 & 2.03\% & 174 \\ 
        \textit{First Improvement}, $\alpha=1.00$ & 56491.112 & 27.9 & 2.03\% & 174 \\ \bottomrule
    \end{tabular}
\end{table}

Como se puede observar, apenas existen diferencias en términos de tiempo de ejecución entre las distintas propuestas, solo existiendo una pequeña mejora en los valores de $\alpha$ menores en la estrategia \textit{First Improvement}. Sin embargo, la calidad obtenida con estas configuraciones es bastante inferior al resto.

Al analizar las métricas de calidad se observa que los mejores valores son obtenidos por las configuraciones con estrategia \textit{Best Improvement}, que siempre superan a su análogo respecto al parámetro $\alpha$. Entre ellas destacan los valores de 0.25 y 0.50, que siempre alcanzan el mejor valor conocido en todo el conjunto de instancias. Aunque la diferencia de tiempos es ínfima, la configuración seleccionada como propuesta final es \textit{Best Improvement} con $\alpha = 0.50$ debido a su menor tiempo de ejecución frente a $\alpha=0.25$.

\subsection{Comparativa con el estado del arte.}
La propuesta matheurística basada en GRASP, denominada MAT-GRASP, con la parametrización obtenida en la sección \ref{sub:ParamSelec}, se compara en este apartado con el estado del arte conformado por el modelo \textit{FL1} del trabajo \cite{espejo2023p}. Véase que, aunque este trabajo muestra dos modelos adicionales (\textit{FL2} y \textit{FL3}), los tres certifican la optimalidad de los resultados y el primero es objetivamente superior en términos de tiempo de ejecución.

La comparativa se muestra dividida en dos tablas de resultados que siguen el mismo esquema que la Tabla \ref{tab:config}. En la Tabla \ref{tab:InstP} se muestran los resultados obtenidos en la ejecución del conjunto denominado \textit{Instancias P}, es decir, donde existe una correlación entre los valores del tiempo de transporte y su coste. La Tabla \ref{tab:InstR} muestra los resultados del conjunto de \textit{Instancias R}, es decir, donde no existe correlación entre ambos valores. Cabe mencionar que, dado que el Modelo \textit{FL1} certifica la optimalidad de sus resultados, la cantidad de mejores resultados obtenidos coincide con la cantidad de soluciones óptimas que los algoritmos alcanzan.


\begin{table}[!ht]
    \centering
    \caption{Comparativa de resultados en el conjunto de 
    \textit{Instancias P}}
    \label{tab:InstP}
    \begin{tabular}{lrrrr}
    \toprule
        Algoritmo & \multicolumn{1}{l}{Avg. F(S)} & \multicolumn{1}{l}{Tiempo (s)} & \multicolumn{1}{l}{Dev. (\%)} &  \multicolumn{1}{l}{Bests} \\ \midrule
        MAT-GRASP & \textbf{41457.448} & 27.8 & \textbf{0.00\%} & \textbf{480} \\ 
        Modelo \textit{FL1} \hspace{7mm} & \textbf{41457.448} & \textbf{4.1} & \textbf{0.00\% }& \textbf{480} \\ \bottomrule
    \end{tabular}
\end{table}

\begin{table}[!ht]
    \centering
    
    \caption{Comparativa de resultados en el conjunto de \textit{Instancias R}}
    \label{tab:InstR}
    \begin{tabular}{lrrrr}
    \toprule
        Algoritmo & \multicolumn{1}{l}{Avg. F(S)} & \multicolumn{1}{l}{Tiempo (s)} & \multicolumn{1}{l}{Dev. (\%)} &  \multicolumn{1}{l}{Bests} \\ \midrule
        MAT-GRASP & 69277.884 & \textbf{28.1} & 0.00\% & 479 \\ 
        Modelo \textit{FL1} \hspace{7mm} & \textbf{69276.869} & 42.5 & \textbf{0.00\% }& \textbf{480} \\ \bottomrule
    \end{tabular}
\end{table}

En la Tabla \ref{tab:InstP} se observa que el algoritmo matheurístico obtiene la solución óptima en esas 480 instancias, obteniendo las mismas métricas de calidad en términos de valores promedio, desviación y mejores resultados alcanzados que el modelo matemático. Sin embargo, se observa que el algoritmo tarda más que el modelo en obtener estos resultados, de 4.1 segundos a 27.8 segundos.

En la Tabla \ref{tab:InstR} se observa que en el caso del conjunto \textit{Instancias R}, de nuevo el algoritmo propuesto obtiene resultados de muy alta calidad, obteniendo el resultado óptimo en 479 instancias del total de 480. Cabe destacar que el resultado en la instancia que no llega al óptimo se queda a un $0.51\%$ de su valor. Además, en comparación con el conjunto de \textit{Instancias P}, el tiempo de ejecución de MAT-GRASP se mantiene prácticamente invariante, obteniendo un promedio de $28.1$ segundos, mientras que en el caso del modelo, cuando se elimina la característica de correlación entre los valores de las aristas, el tiempo de ejecución asciende a 42.5 segundos, por encima de la propuesta de este trabajo.

La Figura \ref{fig:tiempos} muestra un análisis de los tiempos de ejecución del algoritmo en comparación con el tamaño del problema, es decir, el número de nodos del grafo. Como se puede observar, el modelo previo varía su comportamiento según las características de la instancia, mientras que para la propuesta matheurística la dependencia de ambas variables es irrelevante. En el caso de las instancias que presentan correlación entre el tiempo y el coste de transporte el modelo es más rápido que la propuesta de este trabajo, mientras que en el caso contrario el modelo muestra un comportamiento exponencial que supera por mucho el tiempo del algoritmo propuesto.

\begin{figure}
    \centering
    \includegraphics[width=0.60\linewidth]{Figuras/TiemposMAEB.pdf}
    \caption{Comparativa de tiempos del algoritmo en comparación al tamaño de la entrada.}
    \label{fig:tiempos}
\end{figure}


\section{Conclusiones y Trabajo Futuro}
\label{sec:Conclusiones}
El IpMU es una variante del problema de la \textit{p}-mediana que generaliza los conceptos de tiempo y coste de transporte. En este trabajo se ha propuesto un algoritmo matheurístico que une una propuesta metaheurística basada en el algoritmo GRASP con un proceso de resolución exacta.

El algoritmo se ha comparado con la resolución del mejor modelo del estado del arte en los dos conjuntos de instancias del trabajo previo, en un total de 960 instancias.
En el caso del conjunto de instancias donde las variables son dependientes, a igualdad de calidad, el modelo previo consigue mejores tiempos de ejecución que el algoritmo propuesto. Sin embargo, en el caso de que estas variables sean independientes se verifica el comportamiento opuesto, obteniendo una mejora sustancial en tiempo con el algoritmo propuesto.

Actualmente se sigue trabajando en el desarrollo de la propuesta para este problema. En primer lugar, se está realizando un análisis profundo del subproblema de relajación de aristas, de manera que no se necesiten utilizar herramientas de resolución exacta, previendo una mejora en el tiempo de ejecución del algoritmo.

Por otro lado, se está realizando un análisis del espacio de búsqueda de las instancias en relación a la dependencia de las variables de tiempo y coste, de forma que se pueda ajustar la construcción de soluciones y el tiempo de cómputo, aumentando la eficiencia del algoritmo.

Además se tiene pendiente un ajuste de parámetros más robusto, donde se utilicen herramientas automáticas basadas en test estadísticos, como \texttt{irace} \cite{lopez2016irace}.


\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.


\bibliographystyle{unsrt} 
\bibliography{bibliografia}

\end{document}