<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Localización de instalaciones &#187; Ingenieria Industrial Online</title>
	<atom:link href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/feed/" rel="self" type="application/rss+xml" />
	<link>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/</link>
	<description>ingenieriaindustriaonline.com</description>
	<lastBuildDate>Sun, 24 Mar 2024 20:13:23 +0000</lastBuildDate>
	<language>es</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.8.3</generator>

<image>
	<url>https://ingenieriaindustrialonline.com/wp-content/uploads/2019/06/cropped-faVicon-32x32.png</url>
	<title>Localización de instalaciones &#187; Ingenieria Industrial Online</title>
	<link>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>Localización de varios almacenes mediante agrupación geoespacial</title>
		<link>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/</link>
					<comments>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/#respond</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Thu, 14 Oct 2021 19:54:29 +0000</pubDate>
				<category><![CDATA[Actualidad]]></category>
		<category><![CDATA[Análisis de datos]]></category>
		<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Gestión de almacenes]]></category>
		<category><![CDATA[Inteligencia artificial]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Logística]]></category>
		<category><![CDATA[Agrupación geoespacial]]></category>
		<category><![CDATA[Centro de masa]]></category>
		<category><![CDATA[Clustering]]></category>
		<category><![CDATA[Localización]]></category>
		<category><![CDATA[Machine learning]]></category>
		<category><![CDATA[Mapa de calor]]></category>
		<category><![CDATA[Mapas de calor]]></category>
		<category><![CDATA[Método del Centro de gravedad]]></category>
		<category><![CDATA[Métodos de localización]]></category>
		<category><![CDATA[Python]]></category>
		<guid isPermaLink="false">https://ingenieriaindustrialonline.com/?p=28444</guid>

					<description><![CDATA[<p>En un artículo anterior, desarrollamos un modelo capaz de determinar la localización de una instalación (almacén), de acuerdo a un conjunto de ubicaciones existentes (clientes); estas ubicaciones tenían una ponderación determinada (peso, por ejemplo demanda), y basamos nuestro desarrollo en el algoritmo de Centro de Gravedad. El valor agregado del modelo consistía en la integración &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/">Localización de varios almacenes mediante agrupación geoespacial</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[
		<div id="introduccion" data-title="Introducción" class="index-title"></div>
	
<p>En un artículo anterior, desarrollamos un modelo capaz de determinar la localización de una instalación (almacén), de acuerdo a un conjunto de ubicaciones existentes (clientes); estas ubicaciones tenían una ponderación determinada (peso, por ejemplo demanda), y basamos nuestro desarrollo en el algoritmo de Centro de Gravedad.</p>
<p>El valor agregado del modelo consistía en la integración de una capa de mapa de calor (para graficar la densidad), un proceso de geocodificación y el uso de un entorno geográfico real. El alcance de este modelo se encuentra determinado por la localización de una sola instalación (depósito, almacén, etc.), y en los casos en los que se requiera determinar múltiples localizaciones, el modelo no aplica.</p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Para ver el artículo: <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/" target="_blank" rel="noopener"><strong>Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</strong></a>
			</div>
		</div>
	
<p>La pregunta siguiente que nos hacemos es <em>¿Cómo determinar la localización de múltiples instalaciones?</em> En realidad, hay muchas respuestas para este interrogante, y gran parte de ellas conducen a la <strong>agrupación geoespacial</strong> (Clustering).</p>
<h2>¿Qué es la agrupación geoespacial (Clustering)?</h2>

		<div id="que-es-la-agrupacion-geoespacial-clustering" data-title="¿Qué es la agrupación geoespacial (Clustering)?" class="index-title"></div>
	
<p>La agrupación geoespacial es un método que se utiliza para asociar un conjunto de objetos espaciales en grupos denominados «<em>clusters</em>«. Los objetos que conforman cada grupo presentan un grado de similitud asociado a un atributo o varios atributos en particular.</p>
<p>El objetivo de la agrupación geoespacial, consiste en determinar una relación entre atributos espaciales (coordenadas, ubicación) y no espaciales (demanda, por ejemplo).</p>
<p>En la literatura encontraremos varios tipos de agrupación geoespacial, cada uno con un enfoque particular, y un campo de aplicación específico; entre los cuales podemos encontrar:</p>

		<div class="lightbulb tie-list-shortcode">
<ul>
<li>Agrupación de particiones</li>
<li>Agrupación jerárquica</li>
<li>Agrupación <em>Fuzzy</em></li>
<li>Agrupación basada en densidad</li>
</ul>

		</div>
	
<p>En nuestro caso, que pretendemos determinar la localización de varias instalaciones, considerando la ponderación y ubicación de los puntos existentes, requerimos de un modelo capaz de relacionar atributos espaciales (coordenadas) y no espaciales (peso de cada nodo). Que nos permita, primero agrupar los puntos dados (ubicaciones), y eventualmente, aplicar un algoritmo de <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/" target="_blank" rel="noopener"><strong>Centro de Gravedad</strong></a>, para determinar localizaciones potenciales.</p>
<p>Para tales efectos, vamos a utilizar la <strong>agrupación de particiones</strong>, que se caracteriza, entre otras, por:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li>Agrupar los puntos espaciales en subconjuntos</li>
<li>Cada punto agrupado pertenece solo a un subconjunto (clúster)</li>
<li>Cada subconjunto tiene al menos un punto</li>
</ul>

		</div>
	
<p>Vale la pena destacar que en cuanto a la agrupación de participaciones, en esta categoría encontraremos varios métodos de partición, y nosotros utilizaremos el método <em><strong>K-Means</strong></em>, un algoritmo de aprendizaje automático (Machine Learning) no supervisado. Para ello utilizaremos <em>Python</em>.</p>
<figure id="attachment_28445" aria-describedby="caption-attachment-28445" style="width: 299px" class="wp-caption aligncenter"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/clustering.png" alt="clustering" width="299" height="290" class=" wp-image-28445" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/clustering.png 471w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/clustering-300x291.png 300w" sizes="(max-width: 299px) 100vw, 299px" /><figcaption id="caption-attachment-28445" class="wp-caption-text">Agrupación por particiones</figcaption></figure>
<p>Para sintetizar, el objetivo de este artículo será el de emplear un algoritmo de aprendizaje automático capaz de agrupar nuestros nodos en <em>clusters</em>, de acuerdo a atributos espaciales (coordenadas) y no espaciales (ponderación); para luego, utilizar un algoritmo de Centro de Gravedad en cada <em>clúster</em> para determinar la localización de múltiples instalaciones (almacenes, depósitos, etc.).</p>
<p>En el desarrollo de este ejercicio emplearemos:</p>

		<div class="plus tie-list-shortcode">
<ul>
<li><em><strong>Colaboratory</strong>: </em>Este es un entorno de programación y ejecución virtual de Python desarrollado por Google. Nos permitirá no tener la necesidad de realizar ninguna instalación en nuestros equipos. Todo lo que desarrollemos lo ejecutaremos en un cuaderno virtual.</li>
<li><strong><em>Python</em></strong>: Este será el lenguaje de programación que vamos a utilizar, y advertimos: No es necesario tener conocimientos previos, y el objetivo del artículo no es convertirnos en programadores expertos. Utilizaremos fragmentos de códigos, librerías disponibles, y explicaremos lo necesario para configurar nuestro desarrollo de acuerdo a los objetivos específicos de nuestros modelos.</li>
<li><strong><em>SkLearn</em></strong>: Las librerías son a <em>Python</em>, lo que las <em>apps </em>son a un teléfono celular. Esta es quizá una de las características más a tractivas de este lenguaje: Casi que existe una librería para cada necesidad. En este caso, <em>SKLearn</em>, es una librería que integra un conjunto de métodos de aprendizaje automático y minería de datos.</li>
<li><em><strong>K-Means</strong>: </em>Este es un módulo de <em>SKLearn</em> que contiene el algoritmo de agrupación <em>KMeans,</em> el cual separa muestras en <em>n</em> grupos de varianza igual, minimizando un criterio conocido como inercia o suma de cuadrados dentro del grupo.</li>
<li><em><strong>Matplotlib</strong>: </em>Es una biblioteca completa para crear visualizaciones estáticas, animadas e interactivas en Python. Nos permitirá visualizar nuestros nodos y nuestras localizaciones solución.</li>
<li><strong><em>Pandas</em></strong>: <span>Es un paquete de Python que proporciona estructuras de datos rápidas, y flexibles, diseñadas para que el trabajo con datos estructurados (tabulares, multidimensionales, potencialmente heterogéneos) y de series de tiempo sea fácil e intuitivo.</span></li>
<li><em><strong>Numpy</strong>: </em>Es una librería que nos permitirá efectuar operaciones matriciales en Python.</li>
</ul>

		</div>
	
<hr />
<p>Para desarrollar estas herramientas, vamos a plantear un caso típico de localización de múltiples instalaciones a partir de la consideración de otros nodos (nodos de demanda, por ejemplo).</p>
<h2>Caso de aplicación</h2>

		<div id="caso-de-aplicacion" data-title="Caso de aplicación" class="index-title"></div>
	
<blockquote class=" quote-simple "><p>El Departamento de Desarrollo Sostenible de la ciudad de Cali se encuentra implementando una estrategia piloto de recolección de aceite de cocina usado. Ha articulado este proyecto con una Universidad, la cual desarrolló 4 contenedores inteligentes (BIN’s) para la disposición del bioresiduo.</p></blockquote>
<blockquote class=" quote-simple "><p>En investigaciones asociadas, la Universidad ha determinado que el reciclaje del aceite es un problema de densidad; esto quiere decir que es vital la ubicación de los contenedores (cobertura), para así mismo optimizar el proceso de disposición y recolección. El proyecto piloto piensa articular a las instituciones de educación como puntos potenciales de recolección. Por medio de las instituciones piensan socializar el programa con la comunidad. El primer reto del proyecto consiste en determinar la ubicación de los contenedores inteligentes (4 unidades). La información relacionada con las instituciones de educación que hacen parte del programa (ubicación geográfica / población estudiantil), se detalla a continuación:</p></blockquote>
<table width="611">
<tbody>
<tr>
<td width="80">Nodo</td>
<td width="224">Lugar (Colegios)</td>
<td width="127">Latitud</td>
<td width="100">Longitud</td>
<td width="80">Peso</td>
</tr>
<tr>
<td>0</td>
<td> Comfandi San Nicolás</td>
<td>3,453591118</td>
<td>-76,52254886</td>
<td>1494</td>
</tr>
<tr>
<td>1</td>
<td> Mayor de Santiago de Cali</td>
<td>3,451577758</td>
<td>-76,51023216</td>
<td>908</td>
</tr>
<tr>
<td>2</td>
<td> Municipal Comfandi</td>
<td>3,448107915</td>
<td>-76,51074714</td>
<td>697</td>
</tr>
<tr>
<td>3</td>
<td> Internado San Carlos</td>
<td>3,446994135</td>
<td>-76,51525325</td>
<td>1714</td>
</tr>
<tr>
<td>4</td>
<td> León de Greiff</td>
<td>3,447979402</td>
<td>-76,49993247</td>
<td>1731</td>
</tr>
<tr>
<td>5</td>
<td> Nuestra Señora de la Anunciación</td>
<td>3,445152112</td>
<td>-76,49641342</td>
<td>2297</td>
</tr>
<tr>
<td>6</td>
<td> Fernando de Aragón</td>
<td>3,437355603</td>
<td>-76,51383704</td>
<td>1265</td>
</tr>
<tr>
<td>7</td>
<td> Casa Evangélica</td>
<td>3,437955337</td>
<td>-76,52299947</td>
<td>1658</td>
</tr>
<tr>
<td>8</td>
<td> San Alberto Magno</td>
<td>3,433028941</td>
<td>-76,52707643</td>
<td>604</td>
</tr>
<tr>
<td>9</td>
<td> Santa María Goretty</td>
<td>3,433414486</td>
<td>-76,50720662</td>
<td>416</td>
</tr>
<tr>
<td>10</td>
<td> San Alberto Magno</td>
<td>3,433157456</td>
<td>-76,5267331</td>
<td>1584</td>
</tr>
<tr>
<td>11</td>
<td> San Ignacio de Loyola</td>
<td>3,431786629</td>
<td>-76,51733464</td>
<td>2350</td>
</tr>
<tr>
<td>12</td>
<td> Nuestro Futuro</td>
<td>3,430629992</td>
<td>-76,50360174</td>
<td>964</td>
</tr>
<tr>
<td>13</td>
<td> Sabio Caldas</td>
<td>3,429087807</td>
<td>-76,51660508</td>
<td>329</td>
</tr>
<tr>
<td>14</td>
<td> CREAD</td>
<td>3,425060978</td>
<td>-76,51488847</td>
<td>774</td>
</tr>
<tr>
<td>15</td>
<td> Licomtec</td>
<td>3,416664559</td>
<td>-76,51673383</td>
<td>1818</td>
</tr>
<tr>
<td>16</td>
<td>  Nuestra Señora De La Providencia</td>
<td>3,419534772</td>
<td>-76,49591989</td>
<td>1530</td>
</tr>
<tr>
<td>17</td>
<td> Real Suizo</td>
<td>3,415208029</td>
<td>-76,49323768</td>
<td>2106</td>
</tr>
<tr>
<td>18</td>
<td> Nuevo Edén</td>
<td>3,415722099</td>
<td>-76,53383559</td>
<td>330</td>
</tr>
<tr>
<td>19</td>
<td> Católico</td>
<td>3,413066071</td>
<td>-76,53984374</td>
<td>976</td>
</tr>
<tr>
<td>20</td>
<td> Santa María Stella</td>
<td>3,427031556</td>
<td>-76,55134505</td>
<td>1975</td>
</tr>
<tr>
<td>21</td>
<td> Santa Isabel</td>
<td>3,40805355</td>
<td>-76,50817223</td>
<td>936</td>
</tr>
<tr>
<td>22</td>
<td> Compartir</td>
<td>3,431957663</td>
<td>-76,47495575</td>
<td>1563</td>
</tr>
<tr>
<td>23</td>
<td> Lancaster</td>
<td>3,400770816</td>
<td>-76,55177421</td>
<td>1219</td>
</tr>
<tr>
<td>24</td>
<td> Parroquial Divino Salvador</td>
<td>3,397086588</td>
<td>-76,54259033</td>
<td>1954</td>
</tr>
<tr>
<td>25</td>
<td> Reyes Católicos</td>
<td>3,393316667</td>
<td>-76,53735466</td>
<td>399</td>
</tr>
<tr>
<td>26</td>
<td> Liceo Anglo del Valle</td>
<td>3,387318719</td>
<td>-76,51975937</td>
<td>1741</td>
</tr>
<tr>
<td>27</td>
<td> Laurence</td>
<td>3,383420238</td>
<td>-76,52078934</td>
<td>1111</td>
</tr>
<tr>
<td>28</td>
<td> Los Almendros</td>
<td>3,381278208</td>
<td>-76,52023144</td>
<td>1826</td>
</tr>
<tr>
<td>29</td>
<td> Bautista</td>
<td>3,37720834</td>
<td>-76,52327843</td>
<td>1772</td>
</tr>
<tr>
<td>30</td>
<td> Lacordaire</td>
<td>3,378150837</td>
<td>-76,54460736</td>
<td>1965</td>
</tr>
<tr>
<td>31</td>
<td> General José María Córdoba</td>
<td>3,393573314</td>
<td>-76,54932805</td>
<td>841</td>
</tr>
<tr>
<td>32</td>
<td> El Hogar</td>
<td>3,390745864</td>
<td>-76,5503151</td>
<td>770</td>
</tr>
<tr>
<td>33</td>
<td> Americano</td>
<td>3,379093255</td>
<td>-76,54688187</td>
<td>650</td>
</tr>
<tr>
<td>34</td>
<td> Santa Filomena</td>
<td>3,401969935</td>
<td>-76,51345082</td>
<td>1401</td>
</tr>
<tr>
<td>35</td>
<td> Tomás Vasconi</td>
<td>3,403040928</td>
<td>-76,5173132</td>
<td>1474</td>
</tr>
<tr>
<td>36</td>
<td> República del Salvador</td>
<td>3,404454636</td>
<td>-76,52143308</td>
<td>1926</td>
</tr>
<tr>
<td>37</td>
<td> Los Andes</td>
<td>3,429601077</td>
<td>-76,53761216</td>
<td>1566</td>
</tr>
<tr>
<td>38</td>
<td>Villacolombia</td>
<td>3,445493943</td>
<td>-76,50169202</td>
<td>2354</td>
</tr>
<tr>
<td>39</td>
<td>Las Américas</td>
<td>3,449220822</td>
<td>-76,50594064</td>
<td>2043</td>
</tr>
<tr>
<td>40</td>
<td>SantaFe</td>
<td>3,442238267</td>
<td>-76,50988885</td>
<td>2333</td>
</tr>
<tr>
<td>41</td>
<td>Evaristo García</td>
<td>3,440781776</td>
<td>-76,51752778</td>
<td>696</td>
</tr>
<tr>
<td>42</td>
<td>Alfredo Vasquez Cobo</td>
<td>3,435598366</td>
<td>-76,5164549</td>
<td>1073</td>
</tr>
<tr>
<td>43</td>
<td>Ciudad de Cali</td>
<td>3,431143181</td>
<td>-76,51272126</td>
<td>1275</td>
</tr>
<tr>
<td>44</td>
<td>INEM</td>
<td>3,482761991</td>
<td>-76,49976083</td>
<td>1485</td>
</tr>
<tr>
<td>45</td>
<td>Olaya Herrera</td>
<td>3,478178519</td>
<td>-76,51280709</td>
<td>1470</td>
</tr>
<tr>
<td>46</td>
<td>Guillermo Valencia</td>
<td>3,47449459</td>
<td>-76,5136654</td>
<td>1248</td>
</tr>
<tr>
<td>47</td>
<td>José Ignacio Rengifo</td>
<td>3,471624543</td>
<td>-76,5136654</td>
<td>2160</td>
</tr>
<tr>
<td>48</td>
<td>Santo Tomás</td>
<td>3,45830227</td>
<td>-76,5164549</td>
<td>1776</td>
</tr>
<tr>
<td>49</td>
<td>La Merced</td>
<td>3,46271449</td>
<td>-76,5024645</td>
<td>706</td>
</tr>
<tr>
<td>50</td>
<td>Pedro Antonio Molina</td>
<td>3,482804827</td>
<td>-76,48761579</td>
<td>2369</td>
</tr>
<tr>
<td>51</td>
<td>Santa Librada</td>
<td>3,46228612</td>
<td>-76,52302095</td>
<td>2498</td>
</tr>
<tr>
<td>52</td>
<td>República de Israel</td>
<td>3,463656904</td>
<td>-76,51053258</td>
<td>1510</td>
</tr>
<tr>
<td>53</td>
<td>San Vicente Paul</td>
<td>3,466227117</td>
<td>-76,50950261</td>
<td>2330</td>
</tr>
<tr>
<td>54</td>
<td>Manuel María Mallarino</td>
<td>3,456760129</td>
<td>-76,48851701</td>
<td>1464</td>
</tr>
<tr>
<td>55</td>
<td>Sebastían de Belalcazar</td>
<td>3,460229941</td>
<td>-76,48521253</td>
<td>628</td>
</tr>
<tr>
<td>56</td>
<td>Liceo Departamental</td>
<td>3,423860462</td>
<td>-76,5385563</td>
<td>364</td>
</tr>
<tr>
<td>57</td>
<td>Libardo Madrid</td>
<td>3,422061154</td>
<td>-76,54383489</td>
<td>2439</td>
</tr>
<tr>
<td>58</td>
<td>Metropolitano Santa Anita</td>
<td>3,401691038</td>
<td>-76,54218265</td>
<td>1815</td>
</tr>
<tr>
<td>59</td>
<td>San José</td>
<td>3,396935816</td>
<td>-76,55031511</td>
<td>2230</td>
</tr>
</tbody>
</table>
<hr />
<p>Para tales efectos, desarrollaremos un modelo que apoye el análisis preliminar y la localización de los múltiples contenedores. También, que tenga la capacidad de predecir el grupo (clúster) al que pertenecería un nodo nuevo.</p>
<hr />
<h3>Paso 1: Crear el entorno de trabajo en Colaboratory</h3>

		<div id="paso-1-crear-el-entorno-de-trabajo-en-colaboratory" data-title="Paso 1: Crear el entorno de trabajo en Colaboratory" class="index-title"></div>
	
<p><span>Lo primero que vamos a hacer consiste en crear un entorno de trabajo en <em>Google</em> </span><em>Colaboratory</em><span>, así que vayamos allá: </span><a href="https://colab.research.google.com/#create=true" target="_blank" rel="noopener"><em><strong>Abrir cuaderno nuevo</strong></em></a><span>.</span></p>
<p>Verán que tienen un lienzo para programar el modelo, así que en este cuaderno podemos ir generando las líneas de código que explicaremos en los pasos siguientes.</p>
<h3>Paso 2: Importar las librerías necesarias</h3>

		<div id="paso-2-importar-las-librerias-necesarias" data-title="Paso 2: Importar las librerías necesarias" class="index-title"></div>
	
<p>Respecto a las librerías, en la introducción del artículo hicimos una descripción de la funcionalidad de cada una, veamos como importarlas en nuestro entorno:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Importar las librerías necesarias
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
from sklearn.cluster import KMeans</code></pre>
</div>
<p>De esta manera, tenemos todo lo necesario para empezar a desarrollar nuestro código.</p>
<h3>Paso 3: Importar los datos desde Excel</h3>

		<div id="paso-3-importar-los-datos-desde-excel" data-title="Paso 3: Importar los datos desde Excel" class="index-title"></div>
	
<p>De acuerdo a las necesidades del modelo, podemos desarrollar un código que permita la entrada manual de la información, la captura de los datos desde entornos digitales (Internet, por ejemplo), o podemos, desde luego, alimentar nuestro modelo con información contenida en documentos externos, como es el caso de un archivo de Microsoft Excel.</p>
<p>Esta puede considerarse como una de las ventajas de utilizar <em>Python, </em>su capacidad de integrarse con cualquier fuente de datos. En nuestro caso, toda la información se encuentra contenida en un documento de Excel, el cual presenta el siguiente formato:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos_excel.png" alt="datos_excel" width="612" height="241" class="size-full wp-image-28446 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos_excel.png 612w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos_excel-300x118.png 300w" sizes="(max-width: 612px) 100vw, 612px" /></p>
<p>Ya veremos cómo, parte de estos datos son prescindibles y otros indispensables.</p>

		<div class="box download  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Puedes descargar el documento de Excel que utilizamos en este ejemplo: <a href="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/cluster.xlsx" target="_blank" rel="noopener"><strong>Base de datos</strong></a>
			</div>
		</div>
	
<p>En <em>Colaboratory</em>, el siguiente fragmento permitirá cargar un archivo al entorno de ejecución:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>from google.colab import files

uploaded = files.upload()

for fn in uploaded.keys():
  print('User uploaded file "{name}" with length {length} bytes'.format(
      name=fn, length=len(uploaded[fn])))</code></pre>
</div>
<p>Al ejecutar este fragmento de código, se abrirá una ventana emergente del explorador que permitirá cargar nuestra base de datos, en nuestro caso el archivo tienen el nombre de <em>cluster.xlsx.</em></p>
<p>La siguiente línea de código permitirá almacenar los datos contenidos en el documento en un <em>Dataframe</em> de nuestro entorno, dentro de la variable <em>data</em>.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Leer el documento de Excel y almacenar los datos en la variable data
data = pd.read_excel('cluster.xlsx')</code></pre>
</div>
<p>Podemos en cualquier momento confirmar si la carga de los datos se ha realizado correctamente, para eso imprimiremos las primeras cinco filas del  <em>DataFrame:</em></p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>data.head()</code></pre>
</div>
<p>Al ejecutar esta instrucción tenemos la siguiente salida:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head_cluster.png" alt="head_cluster" width="539" height="237" class="size-full wp-image-28448 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head_cluster.png 539w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head_cluster-300x132.png 300w" sizes="(max-width: 539px) 100vw, 539px" /></p>
<h3>Paso 4: Graficar los puntos dados iniciales (Nodos)</h3>

		<div id="paso-4-graficar-los-puntos-dados-iniciales-nodos" data-title="Paso 4: Graficar los puntos dados iniciales (Nodos)" class="index-title"></div>
	
<p>Nuestros puntos iniciales, o las ubicaciones de partida son las instituciones de educación que nos otorga el planteamiento del problema.</p>
<p>Para graficar estos puntos utilizamos el sistema de coordenadas disponible: Latitud y Longitud. Así entonces, debemos extraer estos datos de la hoja de cálculo (<em>DataFrame</em>) que hemos importado al modelo; convertir estas coordenadas en una matriz bidimensional (Latitud y Longitud) y graficar los puntos:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Graficar los nodos dados (ubicaciones)
Lat= data['Latitud']
Lon = data['Longitud']
Peso = data['Peso']
X = []
for i in range(len(data['Latitud'])):
    X.append(Lat[i])
    X.append(Lon[i])

X = np.array(X)

X = X.reshape(-1, 2,)


plt.scatter(Lat, Lon)
plt.show()</code></pre>
</div>
<p>Al ejecutar este fragmento de código, tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/ubicaciones-iniciales.png" alt="ubicaciones iniciales" width="393" height="248" class="size-full wp-image-28449 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/ubicaciones-iniciales.png 393w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/ubicaciones-iniciales-300x189.png 300w" sizes="(max-width: 393px) 100vw, 393px" /></p>
<p>Podemos apreciar cómo se encuentran dispersos los nodos iniciales, formando parte un mismo conjunto que es la población. Las coordenadas son latitud y longitud. Los nodos son, una vez más recordamos, las instituciones educativas, de acuerdo al caso de estudio.</p>
<h3>Paso 5: Agrupar los nodos geoespacialmente mediante Machine Learning</h3>

		<div id="paso-5-agrupar-los-nodos-geoespacialmente-mediante-machine-learning" data-title="Paso 5: Agrupar los nodos geoespacialmente mediante Machine Learning" class="index-title"></div>
	
<p>Cuando mencionamos Machine Learning, a menudo la primera consideración que tenemos es de complejidad. Pues bien, muchos de los algoritmos que hemos utilizado durante décadas son en realidad de aprendizaje automático, como por ejemplo la <a href="https://ingenieriaindustrialonline.com/pronostico-de-la-demanda/regresion-lineal-en-python/"><em><strong>regresión lineal</strong></em></a>. El algoritmo de <em>K-Means </em>que emplearemos de forma automatizada mediante <em>Python</em>, utiliza centroides que minimizan la inercia, o el criterio de suma de cuadrados de cada clúster:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/formula_cluster.png" alt="formula_cluster" width="203" height="65" class="size-full wp-image-28451 aligncenter" /></p>
<p>Me pareció conveniente explicar un poco la teoría, pero vayamos a la práctica. Toda vez que tenemos los nodos del modelo, lo siguiente que debemos indicar es la cantidad de agrupaciones que queremos (clúster). Ya que el problema plantea la disposición de 4 contenedores, vamos a dividir la población de nodos en 4 conjuntos.</p>
<p>Luego, correremos el algoritmo <em>K-Means, </em>veamos cómo:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Ejecutar el algoritmo KMeans
clusters = 4
KMean = KMeans(n_clusters=clusters)
KMean_g = KMean.fit_predict(X)
KMean.fit(X)</code></pre>
</div>
<p>Lo siguiente que haremos será establecer los centroides de cada clúster, es decir, la ubicación de nuestros contendores. En primer lugar, el modelo nos dará las coordenadas. Utilizaremos la siguiente línea de código:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Determinar los centroides de cada clúster
KMean.cluster_centers_</code></pre>
</div>
<p>Al ejecutarla tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides.png" alt="centroides" width="436" height="129" class="size-full wp-image-28452 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides.png 436w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides-300x89.png 300w" sizes="(max-width: 436px) 100vw, 436px" /></p>
<p>Estas son las coordenadas que indican el centro de cada uno de nuestros grupos de nodos. Y teóricamente ahí deberíamos disponer nuestros contenedores.</p>
<h3>Paso 6: Graficar los clusters y los centroides (Localizaciones múltiples)</h3>

		<div id="paso-6-graficar-los-clusters-y-los-centroides-localizaciones-multiples" data-title="Paso 6: Graficar los clusters y los centroides (Localizaciones múltiples)" class="index-title"></div>
	
<p>El siguiente paso consiste en graficar todas las coordenadas que ya tenemos: tantos los nodos iniciales, como los los centroides, o las localizaciones solución. Veamos cómo:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Graficar todas las coordenadas (Puntos y centroides)
plt.scatter(X[:,0], X[:,1], c=KMean_g) #Puntos iniciales

#Centroides
plt.scatter(KMean.cluster_centers_[0][0], KMean.cluster_centers_[0][1], s=50, c='r')
plt.scatter(KMean.cluster_centers_[1][0], KMean.cluster_centers_[1][1], s=50, c='r')
plt.scatter(KMean.cluster_centers_[2][0], KMean.cluster_centers_[2][1], s=50, c='r')
plt.scatter(KMean.cluster_centers_[3][0], KMean.cluster_centers_[3][1], s=50, c='r')</code></pre>
</div>
<p>Al ejecutar el fragmento tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_II.png" alt="centroides_II" width="393" height="248" class="size-full wp-image-28453 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_II.png 393w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_II-300x189.png 300w" sizes="(max-width: 393px) 100vw, 393px" /></p>
<p>Vemos cómo se han efectuado las agrupaciones de los nodos (colores), y los marcadores rojos indican los centroides. Este debería ser el final de nuestro desarrollo, sin embargo, no sé si lo han notado, siempre hemos hablado de centroides, nunca de centros de gravedad o centros de masa. Bien, no sé si también han identificado que en ningún momento hemos considerado el peso de cada nodo, en este caso la <em>población estudiantil </em>de cada institución.</p>
<p><em>¿Esto qué implica?</em> Implica que hemos desarrollado un modelo que tiene exclusivamente consideraciones espaciales. De hecho, visualmente puede observarse cómo, básicamente los centroides se ubican en lo que podría considerarse el medio de cada clúster, sin ninguna consideración adicional aparente, por lo menos a la vista.</p>
<p>Pues bien, vamos a solucionarlo, para ello debemos retocar algunos de los pasos anteriores:</p>
<h3>Paso 5 (Recargado): Agrupar los nodos geoespacialmente mediante Machine Learning (Considerando atributos espaciales y no espaciales)</h3>

		<div id="paso-5-recargado-agrupar-los-nodos-geoespacialmente-mediante-machine-learning-considerando-atributos-espaciales-y-no-espaciales" data-title="Paso 5 (Recargado): Agrupar los nodos geoespacialmente mediante Machine Learning (Considerando atributos espaciales y no espaciales)" class="index-title"></div>
	
<p>Dentro de nuestro marco de datos (<em>DataFrame</em>) tenemos la información relacionada al peso de cada nodo (<em>Población estudiantil</em>). Pues bien, vamos a considerarla al ejecutar el algoritmo <em>K-Means</em>.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Ejecutar el algoritmo KMeans (Considerando el peso de los nodos)
clusters = 4
KMean = KMeans(n_clusters=clusters)
KMean_g = KMean.fit_predict(X)
KMean.fit(X, sample_weight=Peso)</code></pre>
</div>
<p>Lo siguiente que haremos será establecer los centroides de cada clúster, que ahora sí serán Centros de Gravedad; es decir, la ubicación de nuestros contendores. En primer lugar, el modelo nos dará las coordenadas. Utilizaremos la siguiente línea de código:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Determinar los centroides de cada clúster
KMean.cluster_centers_</code></pre>
</div>
<p>Al ejecutarla tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_recargado.png" alt="centroides_recargado" width="436" height="129" class="size-full wp-image-28454 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_recargado.png 436w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_recargado-300x89.png 300w" sizes="(max-width: 436px) 100vw, 436px" /></p>
<p>Los centroides han cambiado, ahora son centros de gravedad afectados por el peso de cada nodo. Es posible que incluso haya cambiado la agrupación de los nodos (composición de los clusters).</p>
<h3>Paso 6 (Recargado): Graficar los clusters y los Centros de Gravedad (Localizaciones múltiples)</h3>

		<div id="paso-6-recargado-graficar-los-clusters-y-los-centros-de-gravedad-localizaciones-multiples" data-title="Paso 6 (Recargado): Graficar los clusters y los Centros de Gravedad (Localizaciones múltiples)" class="index-title"></div>
	
<p>El siguiente paso consiste en graficar todas las coordenadas que ya tenemos: tantos los nodos iniciales, como los los Centros de Gravedad, o las localizaciones solución. Veamos cómo:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Graficar todas las coordenadas (Puntos y centroides)
plt.scatter(X[:,0], X[:,1], c=KMean_g) #Puntos iniciales

#Centroides
plt.scatter(KMean.cluster_centers_[0][0], KMean.cluster_centers_[0][1], s=50, c='r')
plt.scatter(KMean.cluster_centers_[1][0], KMean.cluster_centers_[1][1], s=50, c='r')
plt.scatter(KMean.cluster_centers_[2][0], KMean.cluster_centers_[2][1], s=50, c='r')
plt.scatter(KMean.cluster_centers_[3][0], KMean.cluster_centers_[3][1], s=50, c='r')</code></pre>
</div>
<p>Al ejecutar el fragmento tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Centros-de-gravedad.png" alt="Centros de gravedad" width="393" height="248" class="size-full wp-image-28455 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Centros-de-gravedad.png 393w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Centros-de-gravedad-300x189.png 300w" sizes="(max-width: 393px) 100vw, 393px" /></p>
<p>El resultado respecto a los centroides es diferente. La consideración de un atributo no espacial, en este caso el peso de cada nodo (<em>población estudiantil de cada institución educativa</em>), ha incidido en la ubicación propuesta de las localizaciones solución. Y este debería ser el final de nuestro modelo.</p>
<p>Hemos logrado agrupar nuestros puntos iniciales en clusters, y luego hemos determinado los Centros de Gravedad de cada uno de los clusters.</p>
<p>Por último, veamos una característica de la librería <em>K-Means </em>Análisis predictivo de nodos en clusters, es decir, de acuerdo a unas coordenadas dadas, podemos estimar el grupo al que pertenecerá un nuevo nodo.</p>
<h3>Paso 7: Predicción de clusters</h3>

		<div id="paso-7-prediccion-de-clusters" data-title="Paso 7: Predicción de clusters" class="index-title"></div>
	
<p>En primer lugar ejecutaremos una línea que nos permite identificar a cada nodo dentro de un grupo. Ya que tenemos 4 grupos, estos se identificarán de la siguiente manera: 0, 1, 2, 3.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>KMean.labels_</code></pre>
</div>
<p>Al ejecutar esta línea tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/grupos_nodos.png" alt="grupos_nodos" width="622" height="111" class="size-full wp-image-28456 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/grupos_nodos.png 622w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/grupos_nodos-300x54.png 300w" sizes="(max-width: 622px) 100vw, 622px" /></p>
<p>Vemos como cada una de las 60 instituciones educativas (nodos), tienen un identificador de grupo dentro del modelo.</p>
<p>Ahor, dadas las coordenadas de un nuevo nodo, podemos predecir el grupo al cual pertenecerá:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>sample_test=np.array([-3.433,-76.22])
second_test=sample_test.reshape(1, -1)
KMean.predict(second_test)</code></pre>
</div>
<p>Al ejecutar este fragmento tendremos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/nodos_prediccion.png" alt="nodos_prediccion" width="483" height="118" class="size-full wp-image-28457 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/nodos_prediccion.png 483w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/nodos_prediccion-300x73.png 300w" sizes="(max-width: 483px) 100vw, 483px" /></p>
<p>Es decir, el algoritmo predice que de acuerdo a las coordenada dadas, el nuevo nodo formaría parte del clúster 0.</p>
<hr />
<p>Pudimos observar cómo varía el resultado dependiendo de la consideración de atributos netamente geoespaciales, y de atributos no espaciales, como la ponderación de cada nodo.</p>

		<div class="post-content-slideshow-outer">
			<div class="post-content-slideshow">

			<div class="loader-overlay"><div class="spinner-circle"></div></div>

				<div class="tie-slick-slider">

			<div class="slide post-content-slide">
				 Atributos geoespaciales |</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_II.png" alt="centroides_II" width="393" height="248" class="size-full wp-image-28453 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_II.png 393w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centroides_II-300x189.png 300w" sizes="(max-width: 393px) 100vw, 393px" /></p>

			</div><!-- post-content-slide -->
		

			<div class="slide post-content-slide">
				 Atributos geoespaciales y de ponderación |</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Centros-de-gravedad.png" alt="Centros de gravedad" width="393" height="248" class="size-full wp-image-28455 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Centros-de-gravedad.png 393w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Centros-de-gravedad-300x189.png 300w" sizes="(max-width: 393px) 100vw, 393px" /></p>

			</div><!-- post-content-slide -->
		


					<div class="slider-nav-wrapper">
						<ul class="tie-slider-nav"></ul>
					</div>
				</div><!-- tie-slick-slider -->
			</div><!-- post-content-slideshow -->
		</div><!-- post-content-slideshow-outer -->
	
<h2>Integración con mapas de calor y entornos geográficos reales</h2>
<p>Uno de los puntos negativos del modelo que acabamos de desarrollar es quizá que no nos permite visualizar gráficamente la densidad de los puntos. Si observamos las gráficas, todos los puntos parecen tener el mismo tamaño, y si bien esta no es una consideración para el funcionamiento del algoritmo; en el análisis preliminar quisiéramos tener esta herramienta. Otra consideración adicional sería la posibilidad de graficar todos nuestros puntos, y los centros de gravedad de cada (clúster) en un entorno geográfico real.</p>
<p>Pues bien, una de las ventajas fundamentales de <em>Python </em>consiste en que podemos integrar distintos desarrollos en nuestros modelos, tal es el caso del desarrollo que efectúanos en un artículo anterior (<a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/"><strong>Mapas de calor y Entornos geográficos reales</strong></a>); de tal manera que podamos complementar nuestro modelo.</p>
<p>No vamos a profundizar en la librerías, ni en la definición de las variables, para eso recomendamos leer el artículo. Veamos entonces, como complementamos este modelo:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>import folium
import statistics
from folium.plugins import HeatMap
mediaLong = statistics.mean(Lon)
mediaLat = statistics.mean(Lat)

# Crear un objeto de mapa base Map()
mapa = folium.Map(location=[mediaLat, mediaLong], zoom_start = 13)

# Crear una capa de mapa de calor
mapa_calor = HeatMap( list(zip(Lat, Lon, data["Peso"])),
                   min_opacity=0.2,
                   max_val=data["Peso"].max(),
                   radius=50, 
                   blur=50, 
                   max_zoom=1)

#Creamos el marcador de Centro de Gravedad
tooltip = 'Centro de gravedad'
folium.Marker([KMean.cluster_centers_[0][0], KMean.cluster_centers_[0][1]], popup="Centro", tooltip = tooltip).add_to(mapa)
folium.Marker([KMean.cluster_centers_[1][0], KMean.cluster_centers_[1][1]], popup="Centro", tooltip = tooltip).add_to(mapa)
folium.Marker([KMean.cluster_centers_[2][0], KMean.cluster_centers_[2][1]], popup="Centro", tooltip = tooltip).add_to(mapa)
folium.Marker([KMean.cluster_centers_[3][0], KMean.cluster_centers_[3][1]], popup="Centro", tooltip = tooltip).add_to(mapa)

# Adherimos la capa de mapa de calor al mapa principal
mapa_calor.add_to(mapa)
mapa</code></pre>
</div>
<p>Al ejecutar este fragmento tendremos el siguiente resultado:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Mapa-de-calorII.png" alt="Mapa de calorII" width="700" height="394" class="size-full wp-image-28492 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Mapa-de-calorII.png 700w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Mapa-de-calorII-300x169.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/Mapa-de-calorII-390x220.png 390w" sizes="(max-width: 700px) 100vw, 700px" /></p>
<p>Ahora tenemos un modelo capaz de <strong>agrupar nuestros nodos en clusters</strong> de acuerdo a atributos geoespaciales; capaz de <strong>determinar los centros de gravedad</strong> de cada cluster de acuerdo a atributos no espaciales (en nuestro caso la población de los nodos); capaz de complementarse con una capa de visualización de <strong>mapa de calor</strong> que nos permite apreciar la densidad y todo esto <strong>puede visualizarse en un entorno geográfico real</strong>.</p>
<h2>Consideraciones finales</h2>

		<div id="consideraciones-finales" data-title="Consideraciones finales" class="index-title"></div>
	
<p>Ya lo expresamos anteriormente, la base del algoritmo <em>K-Means </em>es la consideración y minimización de la inercia, y en espacios de muy altas dimensiones, las distancias suelen inflarse, ya que esta no es una medida normalizada.</p>
<p>Sin embargo, para los efectos que hemos empleado, el algoritmo suele arrojar resultados satisfactorios.</p>
<p>El código completo de este desarrollo lo puedes encontrar en nuestro cuaderno: <a href="https://colab.research.google.com/drive/1qboyfxT1kdjn9XiqXudZBf74dUtxwCkn?usp=sharing" target="_blank" rel="noopener"><em><strong>Localización de varias instalaciones mediante agrupación geoespacial y Centro de Gravedad (Python)</strong></em></a>.</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/">Localización de varios almacenes mediante agrupación geoespacial</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</title>
		<link>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/</link>
					<comments>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/#comments</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Wed, 13 Oct 2021 04:14:19 +0000</pubDate>
				<category><![CDATA[Actualidad]]></category>
		<category><![CDATA[Análisis de datos]]></category>
		<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Gestión de almacenes]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Logística]]></category>
		<category><![CDATA[Centro de masa]]></category>
		<category><![CDATA[Localización]]></category>
		<category><![CDATA[Localización de plantas]]></category>
		<category><![CDATA[Mapa de calor]]></category>
		<category><![CDATA[Mapas de calor]]></category>
		<category><![CDATA[Método del Centro de gravedad]]></category>
		<category><![CDATA[Métodos de localización]]></category>
		<category><![CDATA[Python]]></category>
		<guid isPermaLink="false">https://ingenieriaindustrialonline.com/?p=28400</guid>

					<description><![CDATA[<p>Ya en artículos anteriores hemos abordado el uso de tecnología como herramienta que permita desarrollar problemas de análisis preliminar y localización de instalaciones, con el objetivo de incrementar el nivel de aplicabilidad de estas herramientas, utilizando algunos entornos de programación, algunos sistemas de información geográfica, librerías de geocodificación; etc., que nos facilitan la adopción de &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/">Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[
		<div id="introduccion" data-title="Introducción" class="index-title"></div>
	
<p>Ya en artículos anteriores hemos abordado el uso de tecnología como herramienta que permita desarrollar problemas de análisis preliminar y localización de instalaciones, con el objetivo de incrementar el nivel de aplicabilidad de estas herramientas, utilizando algunos entornos de programación, algunos sistemas de información geográfica, librerías de geocodificación; etc., que nos facilitan la adopción de soluciones basadas en entornos reales.</p>
<p>Algunos de los artículos que hemos desarrollado al respecto son:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li><a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/" target="_blank" rel="noopener"><strong>Mapas de calor utilizando Google Maps (Javascript)</strong></a></li>
<li><a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/" target="_blank" rel="noopener"><strong>Método de Centro de Gravedad utilizando R</strong></a></li>
</ul>

		</div>
	
<p>En estos artículos mencionamos que los mapas de calor aplicados a la localización de instalaciones, <strong>son capas de visualización</strong> que no nos proporcionan como resultado una localización específica; <strong>sí nos proporcionan una visión de densidad basada en un factor de ponderación</strong> establecido (Peso). Sin embargo, al utilizar mapas de calor en entornos como por ejemplo <em>Python, </em>podemos integrar a esta herramienta, un método heurístico que nos proporcione una localización específica, como por ejemplo el <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/" target="_blank" rel="noopener"><strong>Centro de Gravedad</strong></a>.</p>
<p>El objetivo de este artículo será el de utilizar mapas de calor y el algoritmo de Centro de gravedad de manera simultánea a través de <em>Python</em>; como herramienta de análisis preliminar y de localización de una instalación.</p>
<p>En el desarrollo de este ejercicio emplearemos:</p>

		<div class="plus tie-list-shortcode">
<ul>
<li><em><strong>Colaboratory</strong>: </em>Este es un entorno de programación y ejecución virtual de Python desarrollado por Google. Nos permitirá no tener la necesidad de realizar ninguna instalación en nuestros equipos. Todo lo que desarrollemos lo ejecutaremos en un cuaderno virtual.</li>
<li><strong><em>Python</em></strong>: Este será el lenguaje de programación que vamos a utilizar, y advertimos: No es necesario tener conocimientos previos, y el objetivo del artículo no es convertirnos en programadores expertos. Utilizaremos fragmentos de códigos, librerías disponibles, y explicaremos lo necesario para configurar nuestro desarrollo de acuerdo a los objetivos específicos de nuestros modelos.</li>
<li><strong><em>Geopy</em></strong>: Las librerías son a <em>Python</em>, lo que las <em>apps </em>son a un teléfono celular. Esta es quizá una de las características más a tractivas de este lenguaje: Casi que existe una librería para cada necesidad. En este caso, <em>Geopy</em>, es una librería que nos permitirá geocodificar un conjunto de ubicaciones. Es decir, a partir de un listado de ciudades o direcciones, poder obtener sus coordenadas de latitud y longitud que nos permitan georeferenciar dichas ubicaciones.</li>
<li><em><strong>Statistics</strong>: </em>Esta es una librería con un conjunto de herramientas estadísticas que nos permitirán hallar algunas medidas centrales como soporte de los modelos.</li>
<li><em><strong>Folium</strong>: </em>Esta librería nos permitirá graficar sobre un sistema de geolocalización, emplear la capa de mapas de calor y georeferenciar el centro de gravedad del modelo.</li>
<li><strong><em>Pandas</em></strong>: <span>Es un paquete de Python que proporciona estructuras de datos rápidas, y flexibles, diseñadas para que el trabajo con datos estructurados (tabulares, multidimensionales, potencialmente heterogéneos) y de series de tiempo sea fácil e intuitivo.</span></li>
<li><em><strong>Numpy</strong>: </em>Es una librería que nos permitirá efectuar operaciones matriciales en Python.</li>
</ul>

		</div>
	
<hr />
<p>Para desarrollar estas herramientas, vamos a plantear un caso típico de localización de una instalación (por ejemplo un depósito) a partir de la consideración de otras instalaciones (nodos de demanda, por ejemplo).</p>
<h2>Caso de aplicación</h2>

		<div id="caso-de-aplicacion" data-title="Caso de aplicación" class="index-title"></div>
	
<blockquote class=" quote-simple "><p>La empresa Bio-Food está desarrollando un nuevo modelo de negocio en la ciudad de Cali, Colombia. Este consiste en abastecer de comida saludable a la comunidad por medio de Vending Machines (Máquinas expendedoras). En las etapas de formulación de negocio, algo quedó muy claro: El éxito de su modelo consiste en maximizar la disponibilidad de todos los SKUs en cantidades suficientes. Algunas de las referencias son productos perecederos, de manera que consideran que algunos de sus equipos requerirán visitas diarias de reposición, y otros quizá sean surtidos en más de dos ocasiones por día.</p></blockquote>
<blockquote class=" quote-simple "><p>La fase inicial de su proyecto consideró la instalación de 13 equipos expendedores en 13 instituciones de educación superior de la ciudad. La logística inicial de su proyecto fue caótica (en fase piloto), algunos equipos funcionaron como sub-bodegas; algunos equipos fueron abastecidos directamente por los proveedores; y consideran la instalación de una bodega principal desde la cual serán abastecidas todas las máquinas que tienen disponibles.</p></blockquote>
<blockquote class=" quote-simple "><p>La fase inicial del proyecto arrojó información alrededor del volumen de ventas de cada equipo. Por esta razón, el departamento de logística considera utilizar esta información para efectuar un análisis preliminar y establecer la localización de la bodega principal. A continuación, se relacionan los movimientos de los equipos (media de unidades vendidas por día):</p></blockquote>
<table width="664">
<tbody>
<tr>
<td width="80" style="text-align: center;"><strong>Máquina</strong></td>
<td width="459" style="text-align: center;"><strong>Institución / Lugar</strong></td>
<td width="125" style="text-align: center;"><strong>Unidades vendidas</strong></td>
</tr>
<tr>
<td style="text-align: center;">1</td>
<td style="text-align: center;">PONTIFICIA UNIVERSIDAD JAVERIANA</td>
<td style="text-align: center;">1800</td>
</tr>
<tr>
<td style="text-align: center;">2</td>
<td style="text-align: center;">UNIVERSIDAD DEL VALLE</td>
<td style="text-align: center;">1650</td>
</tr>
<tr>
<td style="text-align: center;">3</td>
<td style="text-align: center;">UNIVERSIDAD SAN BUENAVENTURA</td>
<td style="text-align: center;">1110</td>
</tr>
<tr>
<td style="text-align: center;">4</td>
<td style="text-align: center;">UNIVERSIDAD ICESI</td>
<td style="text-align: center;">1540</td>
</tr>
<tr>
<td style="text-align: center;">5</td>
<td style="text-align: center;">UNIVERSIDAD SANTIAGO DE CALI</td>
<td style="text-align: center;">820</td>
</tr>
<tr>
<td style="text-align: center;">6</td>
<td style="text-align: center;">UNIVERSIDAD AUTÓNOMA DE OCCIDENTE</td>
<td style="text-align: center;">1020</td>
</tr>
<tr>
<td style="text-align: center;">7</td>
<td style="text-align: center;">UNIVERSIDAD COOPERATIVA DE COLOMBIA</td>
<td style="text-align: center;">635</td>
</tr>
<tr>
<td style="text-align: center;">8</td>
<td style="text-align: center;">FUNDACIÓN UNIVERSITARIA SAN MARTÍN</td>
<td style="text-align: center;">420</td>
</tr>
<tr>
<td style="text-align: center;">9</td>
<td style="text-align: center;">UNIVERSIDAD LIBRE</td>
<td style="text-align: center;">569</td>
</tr>
<tr>
<td style="text-align: center;">10</td>
<td style="text-align: center;">UNIVERSIDAD ANTONIO NARIÑO</td>
<td style="text-align: center;">350</td>
</tr>
<tr>
<td style="text-align: center;">11</td>
<td style="text-align: center;">UNICATOLICA &#8211; FUNDACION UNIVERSITARIA CATÓLICA LUMEN GENTIUM</td>
<td style="text-align: center;">620</td>
</tr>
<tr>
<td style="text-align: center;">12</td>
<td style="text-align: center;">CECEP</td>
<td style="text-align: center;">800</td>
</tr>
<tr>
<td style="text-align: center;">13</td>
<td style="text-align: center;">UNIVERSIDAD OBRERA</td>
<td style="text-align: center;">250</td>
</tr>
</tbody>
</table>
<hr />
<p>Utilizar el algoritmo de Centro de Gravedad puede servir como referencia para establecer una ubicación tentativa. Sin embargo, las posibilidades de que las coordenadas solución correspondan con un espacio disponible para la ubicación de la instalación son, de verdad, muy pocas.</p>
<p>Por esta razón, es interesante complementar este modelo mediante una capa de visualización de mapas de calor, que consideren la densidad del volumen de ventas de los equipos. De esta manera, puede complementarse el análisis preliminar para la localización de la bodega principal.</p>
<hr />
<h3>Paso 1: Crear el entorno de trabajo en Colaboratory</h3>

		<div id="paso-1-crear-el-entorno-de-trabajo-en-colaboratory" data-title="Paso 1: Crear el entorno de trabajo en Colaboratory" class="index-title"></div>
	
<p><span>Lo primero que vamos a hacer consiste en crear un entorno de trabajo en <em>Google</em> </span><em>Colaboratory</em><span>, así que vayamos allá: </span><a href="https://colab.research.google.com/#create=true" target="_blank" rel="noopener"><em><strong>Abrir cuaderno nuevo</strong></em></a><span>.</span></p>
<p>Verán que tienen un lienzo para programar el modelo, así que en este cuaderno podemos ir generando las líneas de código que explicaremos en los pasos siguientes.</p>
<h3>Paso 2: Importar las librerías necesarias</h3>

		<div id="paso-2-importar-las-librerias-necesarias" data-title="Paso 2: Importar las librerías necesarias" class="index-title"></div>
	
<p>Respecto a las librerías, en la introducción del artículo hicimos una descripción de la funcionalidad de cada una, veamos como importarlas en nuestro entorno:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code># importar las librerías necesarias
import pandas as pd
import numpy as np
import folium
import statistics
from folium.plugins import HeatMap
import geopy
from geopy.extra.rate_limiter import RateLimiter</code></pre>
</div>
<p>De esta manera, tenemos todo lo necesario para empezar a desarrollar nuestro código.</p>
<h3>Paso 3: Importar los datos desde Excel</h3>

		<div id="paso-3-importar-los-datos-desde-excel" data-title="Paso 3: Importar los datos desde Excel" class="index-title"></div>
	
<p>De acuerdo a las necesidades del modelo, podemos desarrollar un código que permita la entrada manual de la información, la captura de los datos desde entornos digitales (Internet, por ejemplo), o podemos, desde luego, alimentar nuestro modelo con información contenida en documentos externos, como es el caso de un archivo de Microsoft Excel.</p>
<p>Esta puede considerarse como una de las ventajas de utilizar <em>Python, </em>su capacidad de integrarse con cualquier fuente de datos. En nuestro caso, toda la información se encuentra contenida en un documento de Excel, el cual presenta el siguiente formato:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos.png" alt="datos" width="730" height="241" class="wp-image-28403 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos.png 853w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos-300x99.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/datos-768x253.png 768w" sizes="(max-width: 730px) 100vw, 730px" /></p>

		<div class="box download  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Puedes descargar el documento de Excel que utilizamos en este ejemplo: <a href="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/vending_machines-1.xlsx" target="_blank" rel="noopener"><strong>Base de datos</strong></a>
			</div>
		</div>
	
<p>En <em>Colaboratory</em>, el siguiente fragmento permitirá cargar un archivo al entorno de ejecución:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>from google.colab import files

uploaded = files.upload()

for fn in uploaded.keys():
  print('User uploaded file "{name}" with length {length} bytes'.format(
      name=fn, length=len(uploaded[fn])))</code></pre>
</div>
<p>Al ejecutar este fragmento de código, se abrirá una ventana emergente del explorador que permitirá cargar nuestra base de datos, en nuestro caso el archivo tienen el nombre de <em>vending_machines.xlsx.</em></p>
<p>La siguiente línea de código permitirá almacenar los datos contenidos en el documento en un <em>Dataframe</em> de nuestro entorno, dentro de la variable <em>data</em>.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>#Leer el documento de Excel y almacenar los datos en la variable data
data = pd.read_excel('vending_machines.xlsx')</code></pre>
</div>
<h3>Paso 4: Geocodificar las ubicaciones</h3>

		<div id="paso-4-geocodificar-las-ubicaciones" data-title="Paso 4: Geocodificar las ubicaciones" class="index-title"></div>
	
<p>Nosotros podemos partir desde la disponibilidad de las coordenadas geográficas de los puntos disponibles (Equipos expendedores). En cuyo caso, geocodificar las ubicaciones no sería necesario. Sin embargo, en nuestro ejemplo, disponemos del nombre de cada institución donde se encuentran ubicados los equipos, así como la ciudad y el país (todos los equipos se encuentran en la misma ciudad); y es necesario geocodificar estos puntos para obtener las coordenadas de latitud y longitud de cada ubicación.</p>
<p>Para lograrlo, utilizaremos el servicio de la librería <em>Geopy (Llamado Nominatim)</em>, el cual puede geocodificar nuestras ubicaciones. El servicio funciona de una manera sencilla, recibe una cadena con la información de nuestra ubicación, por ejemplo: ciudad, país, nombre del lugar; y devuelve las coordenadas de latitud y longitud asociadas a cada cadena.</p>
<p>Las siguientes líneas en primer lugar construyen cada cadena por punto (dirección), es decir, concatenan los datos (país, ciudad y nombre del lugar), y luego son geocodificados por <em>Geopy</em>. Veamos:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code># fusionamos los datos país, ciudad y lugar en una misma cadena de dirección
geopy.geocoders.options.default_user_agent = "my-application"
data["direccion"] = data["pais"] + ", " + data["ciudad"] + ", " + data["Institución / Lugar"]
#Envíamos los datos a geocodificación
servicio = geopy.Nominatim()
data["coordenadas"] = data["direccion"].apply(RateLimiter(servicio.geocode,min_delay_seconds=1))</code></pre>
</div>
<p>Pueden apreciar que el código establece que tanto las cadenas con las direcciones concatenadas, como las respuestas en manera de coordenadas, queden dentro del mismo <em>DataFrame </em>donde se encuentran los datos de entrada del modelo. Podemos en cualquier momento confirmar si la geocodificación se ha realizado correctamente, para eso imprimiremos las primeras cinco filas del  <em>DataFrame:</em></p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>data.head()</code></pre>
</div>
<p>Al ejecutar esta instrucción tenemos la siguiente salida:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head.png" alt="head" width="1300" height="185" class="alignnone size-full wp-image-28405" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head.png 1300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head-300x43.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head-1024x146.png 1024w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/head-768x109.png 768w" sizes="(max-width: 1300px) 100vw, 1300px" /></p>
<p>Podemos observar cómo bajo la columna &#8216;<em>direccion&#8217; </em>se han concatenado las columnas <em>&#8216;pais&#8217;, &#8216;ciudad&#8217; e &#8216;Institución / Lugar&#8217;</em>, tal como lo establecimos previamente. Así mismo, podemos observar la respuesta de <em>Geopy </em> bajo la columna <em>&#8216;coordenadas&#8217;</em>.</p>
<h3>Paso 5: Calcular el Centro de Gravedad</h3>

		<div id="paso-5-calcular-el-centro-de-gravedad" data-title="Paso 5: Calcular el Centro de Gravedad" class="index-title"></div>
	
<p>El algoritmo de <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/" target="_blank" rel="noopener"><strong>Centro de Gravedad</strong></a> es relativamente sencillo, mucho más cuando se cuenta con los datos debidamente organizados. Las operaciones son sencillas, y en <em>Python</em>, se pueden desarrollar fácilmente mediante productos de matrices.</p>
<p>Ahora bien, la base del algoritmo son las coordenadas. En la respuesta obtenida desde <em>Geopy</em>, que se encuentra contenida en la columna <em>&#8216;coordenadas&#8217;</em> del <em>DataFrame &#8216;data&#8217;, </em>hay información adicional a las coordenadas necesarias. De hecho el servicio nos devuelve un nombre del lugar, una subregión, puede mostrarnos alguna nomenclatura y claro está, las coordenadas de latitud y longitud. Por tal razón, lo primero que debemos hacer es extraer las coordenadas de latitud y longitud, para eso utilizaremos las siguientes líneas:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code># Extraer las coordenadas de latitud y longitud en dos variables separadas (listas)
longs = [coord.longitude for coord in data["coordenadas"]]
lats = [coord.latitude for coord in data["coordenadas"]]</code></pre>
</div>
<p>Una vez que tengamos las coordenadas de todos los puntos en un par de variables separadas, procedemos a crear nuestro algoritmo de centro de gravedad:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>centro_gravedad = {}
centro_gravedad['longs'] = np.dot(longs, data['Unidades vendidas']) / np.sum(data['Unidades vendidas'])
centro_gravedad['lats'] = np.dot(lats, data['Unidades vendidas']) / np.sum(data['Unidades vendidas'])</code></pre>
</div>
<p>De esta manera, dentro del arreglo <em>&#8216;centro_gravedad&#8217; </em>deberán quedar las coordenadas solución. Recordemos que este algoritmo utiliza puntos ponderados, en este caso el peso que determina la ponderación está dado por el volumen de ventas de cada equipo (<em>&#8216;Unidades vendidas&#8217;</em>).</p>
<p>Podemos ver el resultado, imprimiendo la variable <em>&#8216;centro_gravedad&#8217;:</em></p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>print(centro_gravedad)</code></pre>
</div>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad.png" alt="centro_gravedad" width="618" height="85" class="size-full wp-image-28406 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad.png 618w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad-300x41.png 300w" sizes="(max-width: 618px) 100vw, 618px" /></p>
<p>Estas son las coordenadas solución del método de Centro de Gravedad. Sin embargo, recordemos que debemos complementar el desarrollo del modelo mediante un mapa de calor.</p>
<h3>Paso 6: Graficar la capa del mapa de calor y el marcador de Centro de Gravedad</h3>

		<div id="paso-6-graficar-la-capa-del-mapa-de-calor-y-el-marcador-de-centro-de-gravedad" data-title="Paso 6: Graficar la capa del mapa de calor y el marcador de Centro de Gravedad" class="index-title"></div>
	
<p>En este caso utilizaremos la librería <em>Folium </em>para ambos fines: la capa del mapa de calor, y el marcador de Centro de Gravedad.</p>
<p>Lo primero que haremos será calcular la media de las latitudes y las longitudes para centrar el mapa que obtendremos.</p>
<p>Lo segundo que haremos será crear nuestro mapa, el cual configuraremos con las medidas centrales y un zoom inicial que podemos modificar de acuerdo a nuestras necesidades.</p>
<p>Lo tercero que haremos será crear nuestra capa de mapa de calor, utilizaremos como peso las <em>&#8216;Unidades vendidas&#8217;</em> para ponderar cada punto del mapa (Vending Machines). Configuramos algunos parámetros a nuestro criterio como la <em>opacidad, la intensidad, el radio de cada punto</em>.</p>
<p>Por último crearemos el marcador de Centro de Gravedad, para ello utilizaremos las coordenadas solución que hallamos en el paso anterior.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code># Calcular la media de las latitudes y las longitudes para centrar el mapa
mediaLong = statistics.mean(longs)
mediaLat = statistics.mean(lats)

# Crear un objeto de mapa base Map()
mapa = folium.Map(location=[mediaLat, mediaLong], zoom_start = 12)

# Crear una capa de mapa de calor
mapa_calor = HeatMap( list(zip(lats, longs, data["Unidades vendidas"])),
                   min_opacity=0.2,
                   max_val=data["Unidades vendidas"].max(),
                   radius=50, 
                   blur=50, 
                   max_zoom=1)

#Creamos el marcador de Centro de Gravedad
tooltip = 'Centro de gravedad'
folium.Marker([centro_gravedad['lats'], centro_gravedad['longs']], popup="Centro", tooltip = tooltip).add_to(mapa)

# Adherimos la capa de mapa de calor al mapa principal
mapa_calor.add_to(mapa)
mapa</code></pre>
</div>
<p>Al ejecutar estas líneas tendremos el siguiente resultado:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor.png" alt="centro_gravedad_mapa_calor" width="1404" height="760" class="alignnone size-full wp-image-28407" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor.png 1404w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor-300x162.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor-1024x554.png 1024w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor-768x416.png 768w" sizes="(max-width: 1404px) 100vw, 1404px" /></p>
<p>Podemos utilizar el zoom para explorar diversas visualizaciones de densidad:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor_II.png" alt="centro_gravedad_mapa_calor_II" width="1351" height="747" class="alignnone size-full wp-image-28408" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor_II.png 1351w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor_II-300x166.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor_II-1024x566.png 1024w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro_gravedad_mapa_calor_II-768x425.png 768w" sizes="(max-width: 1351px) 100vw, 1351px" /></p>
<p>El código completo de este desarrollo lo puedes encontrar en nuestro cuaderno: <a href="https://colab.research.google.com/drive/1CWCVFeh6NibQGTg62zF0lg1A9Qow0rld?usp=sharing" target="_blank" rel="noopener"><em><strong>Mapas de Calor y Centro de Gravedad</strong></em></a>.</p>
<hr />
<p>En este caso, y a diferencia del artículo <em><strong><a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/" target="_blank" rel="noopener">mapas de calor utilizando Google Maps</a>, </strong></em>empleamos una capa de visualización de densidad de cada punto, y simultáneamente identificamos unas coordenadas solución de una localización de acuerdo al modelo de Centro de Gravedad (Centro de masa). De esta forma, construimos una herramienta un poco más robusta que permite soportar los procesos de análisis preliminar de localización de instalaciones, ambientada en un entorno geográfico real.</p>
<p>Así mismo, en el desarrollo de la herramienta empleamos algunas instrucciones que nos permiten automatizar procesos de georeferenciación, y de uso de datos a partir de fuentes diversas.</p>
<hr />
<p><span>El alcance de este modelo se encuentra determinado por la localización de una sola instalación (depósito, almacén, etc.), y en los casos en los que se requiera determinar múltiples localizaciones, el modelo no aplica.</span></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Para ver un modelo para varias localizaciones: <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/"><em><strong>Localización de varios almacenes mediante agrupación espacial</strong></em></a>
			</div>
		</div>
	
<p>La entrada <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/">Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/feed/</wfw:commentRss>
			<slash:comments>4</slash:comments>
		
		
			</item>
		<item>
		<title>Método del Centro de gravedad utilizando R</title>
		<link>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/</link>
					<comments>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/#comments</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Tue, 05 Oct 2021 00:17:12 +0000</pubDate>
				<category><![CDATA[Actualidad]]></category>
		<category><![CDATA[Análisis de datos]]></category>
		<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Logística]]></category>
		<category><![CDATA[Centro de masa]]></category>
		<category><![CDATA[Localización de Instalaciones]]></category>
		<category><![CDATA[Método del Centro de gravedad]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[R]]></category>
		<guid isPermaLink="false">https://ingenieriaindustrialonline.com/?p=28249</guid>

					<description><![CDATA[<p>Cuando escribí el artículo método del centro de gravedad hice esta anotación: «Recuerdo que cuando utilicé este algoritmo en la Universidad, utilizamos la copia de un mapa de la región, sobre ella trazamos un plano cartesiano, definimos las ubicaciones del caso, registramos las coordenadas y como resultado obtuvimos las coordenadas de la localización ideal. La dificultad subyace &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/">Método del Centro de gravedad utilizando R</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>Cuando escribí el artículo <strong><a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/">método del centro de gravedad</a> </strong>hice esta anotación: «<em>Recuerdo que cuando utilicé este algoritmo en la Universidad, utilizamos la copia de un mapa de la región, sobre ella trazamos un plano cartesiano, definimos las ubicaciones del caso, registramos las coordenadas y como resultado obtuvimos las coordenadas de la localización ideal. La dificultad subyace en la falta de practicidad».</em></p>
<p><span>El objetivo de este artículo es precisamente ese, apoyarnos en las nuevas herramientas que nos proporciona la tecnología, para abordar un problema de localización de una instalación aplicando el algoritmo de centro de gravedad de una manera práctica. Para ello utilizaremos R, de hecho, utilizaremos las librerías de R en un cuaderno virtual de <em>Python</em>.</span></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>R es un entorno y lenguaje de programación con un enfoque al análisis estadístico. 
			</div>
		</div>
	
<p>El resultado de nuestro código nos arrojará la localización, de acuerdo al sistema de coordenadas que empleemos, además de que graficará la misma, y los puntos ponderados del modelo (peso de acuerdo a su demanda, producción, capacidad, etc.).</p>
<div id="cc-m-5713476913" class="j-module n j-text ">
<h3><em>Ejemplo de aplicación del Centro de gravedad</em></h3>
<div class="cc-m-hgrid-column last">
<div id="cc-matrix-1350164513">
<div id="cc-m-5713479913" class="j-module n j-text ">
<p><img decoding="async" class="size-full wp-image-2067 alignleft" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-58.png" alt="" width="171" height="144" /></p>
<p>La empresa GASOL S.A desea ubicar una instalación intermedia que requiere de disponibilidad de gasolina, desea ubicar esta instalación entre la ciudad de Barrancabermeja y sus principales distribuidores. En el siguiente cuadro se relaciona la información acerca de las coordenadas y el aporte de galones de gasolina de cada distribuidor.</p>
</div>
</div>
</div>
<p><img decoding="async" class="aligncenter size-full wp-image-2068" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-59.png" alt="" width="419" height="148" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-59.png 419w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-59-300x106.png 300w" sizes="(max-width: 419px) 100vw, 419px" /></p>
<p><em>Ubicación de las puntos en el plano cartesiano:</em></p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano.png" alt="Método de gravedad" width="615" height="279" class="aligncenter wp-image-27319" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano.png 2560w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-300x136.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1024x464.png 1024w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-768x348.png 768w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1536x696.png 1536w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-2048x928.png 2048w" sizes="(max-width: 615px) 100vw, 615px" /></p>
<p>Los cálculos empleados en el algoritmo manual pueden ser consultados en: <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/"><strong>Modelo de Centro de Gravedad</strong></a>.</p>
</div>
<h2>Requerimientos para ejecutar el modelo</h2>
<p>En este caso sugerimos utilizar un entorno virtual de programación. Recomendamos el uso de <em><strong>Colaboratory de Google</strong></em>, un entorno que cuenta con todas las herramientas necesarias para nuestros desarrollos en <em>Python</em>. No tendremos que instalar nada en nuestro equipo, y aprovecharemos la potencia de las máquinas de Google, y su capacidad para ejecutar R.</p>
<h2>Programación del modelo de Centro de Gravedad en R</h2>
<p>Vamos a asumir que utilizarán el entorno virtual de <em>Colaboratory</em>, así que vayamos allá: <a href="https://colab.research.google.com/#create=true"><em><strong>Abrir cuaderno nuevo</strong></em></a>.</p>
<p>Ya que este entorno está desarrollado para escribir y ejecutar códigos en <em>Python</em>, lo primero que debemos hacer es ejecutar el siguiente comando en nuestro cuaderno, para así poder utilizar R en nuestro entorno:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>import rpy2
rpy2.__version__
import rpy2.robjects.conversion
%load_ext rpy2.ipython</code></pre>
</div>
<p>Después de eso, cada vez que desee usar R, agregue %%R al comienzo de cada celda. Veamos.</p>
<p>Lo primero que crearemos será a función del cálculo del Centro de Gravedad, la matemática detrás de esto no es nada especial, se trata de un <em>producto cruzado de matrices</em> para cada coordenada, para lo que utilizaremos <em>crossprod</em> de R.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>%%R 
centro_gravedad &lt;- function(x,y,w){
  c(crossprod(x,w)/sum(w),crossprod(y,w)/sum(w))
}</code></pre>
</div>
<p><em>x </em>= Coordenada en <em>x</em> (Que puede ser una coordenada cartesiana, latitud, etc.)</p>
<p><em>y </em>= Coordenada en <em>y</em> (Que puede ser una coordenada cartesiana, longitud, etc.)</p>
<p><em>w = </em>Representa el peso de cada punto dado (Que puede ser la demanda, la capacidad, la producción)</p>
<p>En nuestro caso, <strong><em>x</em></strong> y <strong><em>y</em></strong> serán coordenadas cartesianas, y <em><strong>w</strong></em> será la capacidad de suministro de gasolina de cada distribuidor. La función anterior calculará el centro de gravedad de acuerdo a los datos de entrada del modelo.</p>
<p>Ahora crearemos el marco de datos (<em>dataframe </em>al cual llamaremos <em>estaciones_df</em>) en el que se consignarán nuestros datos de entrada:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>%%R
estaciones_df &lt;- as.data.frame(matrix(nrow=5,ncol=3))
encabezados(estaciones_df) &lt;- c("x","y","galones")

estaciones_df$x &lt;- c(58.7, 26.2, 32.9, 42.5, 36.4)
estaciones_df$y &lt;- c(4.4, 5.2, 3.8, 4.1, 6.2)
estaciones_df$galones &lt;- c(3800, 2700, 310, 420, 250)</code></pre>
</div>
<p>El código anterior crea un marco de datos (<em>matrix</em>) de 5 filas y 3 columnas. Las filas representan el número de estaciones de gasolina que nos da el ejemplo, y las columnas servirán para consignar 3 valores: <em>coordenada en x, coordenada en y y el suministro de gasolina en galones de cada estación</em>.</p>
<p>Consignaremos los datos de entrada del ejemplo cuidando el orden estricto en el que registramos la información. Al finalizar tendremos toda la información consignada en nuestro marco de datos; para comprobarlo ejecutaremos el siguiente código:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>%%R
(estaciones_df)</code></pre>
</div>
<p>Al ejecutarlo, tendremos la siguiente salida:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/gravedad_1.png" alt="gravedad_1" width="343" height="125" class="size-full wp-image-28250 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/gravedad_1.png 343w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/gravedad_1-300x109.png 300w" sizes="(max-width: 343px) 100vw, 343px" /></p>
<p>Podemos corroborar que la información se ha consignado adecuadamente.</p>
<p>El siguiente paso consiste en calcular el centro de gravedad del modelo, para eso asignaremos los datos de entrada a la función inicial de centro de gravedad:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>%%R
centro_gravedad(estaciones_df$x,estaciones_df$y,estaciones_df$galones)</code></pre>
</div>
<p>Recordemos que de acuerdo a la función inicial, esta necesita 3 argumentos: <em><strong>x</strong></em>, <em><strong>y</strong></em>, <em><strong>w</strong></em> (coordenada en <em>x</em>, coordenada en <em>y</em>, peso). Esta información se encuentra en el marco de datos de entrada (<em>estaciones_df</em>).</p>
<p>Al ejecutarlo, tendremos la siguiente salida:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/gravedad_2.png" alt="gravedad_2" width="464" height="43" class="size-full wp-image-28251 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/gravedad_2.png 464w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/gravedad_2-300x28.png 300w" sizes="(max-width: 464px) 100vw, 464px" /></p>
<p><span>Esto quiere decir que en el sistema de coordenadas utilizado para establecer las ubicaciones propuestas en el ejercicio, la instalación óptima se ubicaría en las coordenadas </span><em><strong>X = 44,2</strong></em><span> – </span><em><strong>Y = 4,7. </strong></em>podemos confirmar que son las mismas coordenadas obtenidas mediante el <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/"><strong>modelo matemático original de Centro de Gravedad</strong></a>.</p>
<p>Tanto el resultado obtenido, como las ubicaciones de entrada (estaciones) pueden graficarse para una mayor comprensión del modelo. Utilizaremos un gráfico utilizando la librería <em>ggplot2</em> que nos muestre las instalaciones con un marcador de acuerdo a su ponderación. Veamos:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-python" data-lang="Python"><code>%%R
library(ggplot2)
grafico_df &lt;- rbind(estaciones_df,c(centro_gravedad(estaciones_df$x,estaciones_df$y,estaciones_df$galones),2500))
grafico_df$tipo &lt;- c(rep(x="distribuidores",times=5),"instalacion")
ggplot(data=grafico_df) + geom_point(mapping=aes(x=x,y=y,size=galones,color=tipo))</code></pre>
</div>
<p>Al ejecutar tendremos el siguiente resultado:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro-de-gravedad.png" alt="centro de gravedad" width="480" height="480" class="size-full wp-image-28252 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro-de-gravedad.png 480w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro-de-gravedad-300x300.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/10/centro-de-gravedad-150x150.png 150w" sizes="(max-width: 480px) 100vw, 480px" /></p>
<p>El marcador azul representa la ubicación sugerida por el modelo, de acuerdo a la ubicación del suministro de acuerdo a las estaciones. Podemos ver como el tamaño de las estaciones varía de acuerdo a su capacidad de suministro. Esta forma de desarrollar el modelo de Centro de Gravedad puede complementarse con diversas fuentes de datos, <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/"><strong>mapas de calor</strong></a>, tipos de coordenadas, etc.</p>
<hr />
<p>Puedes ver el cuaderno de este módulo en nuestro <em>Colaboratory: <a href="https://colab.research.google.com/drive/1wSSla3U6NuJJHX6t-eetFiUSTvDpENUF?usp=sharing"><strong>Problema de localización de instalaciones mediante Centro de Gravedad</strong></a>.</em></p>
<h2>Consideraciones finales</h2>
<p><span>El alcance de este modelo se encuentra determinado por la localización de una sola instalación (depósito, almacén, etc.), y en los casos en los que se requiera determinar múltiples localizaciones, el modelo no aplica.</span></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Para ver un modelo para varias localizaciones: <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/"><em><strong>Localización de varios almacenes mediante agrupación espacial</strong></em></a>
			</div>
		</div>
	
<hr />

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Lo invitamos a leer: <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/"><em><strong>Método de localización de instalaciones utilizando mapas de calor</strong></em></a> y <em><a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/" target="_blank" rel="noopener"><strong>Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</strong></a></em>
			</div>
		</div>
	
<p>La entrada <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/">Método del Centro de gravedad utilizando R</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/feed/</wfw:commentRss>
			<slash:comments>2</slash:comments>
		
		
			</item>
		<item>
		<title>Método de localización de instalaciones utilizando mapas de calor (Google Maps + Javascript)</title>
		<link>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/</link>
					<comments>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/#respond</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Mon, 23 Aug 2021 03:45:35 +0000</pubDate>
				<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Gestión de almacenes]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Localización]]></category>
		<category><![CDATA[Localización de plantas]]></category>
		<category><![CDATA[Mapa de calor]]></category>
		<category><![CDATA[Mapas de calor]]></category>
		<category><![CDATA[Métodos de localización]]></category>
		<guid isPermaLink="false">https://ingenieriaindustrialonline.com/?p=27593</guid>

					<description><![CDATA[<p>Mucho se ha desarrollado en la literatura académica acerca de los métodos o algoritmos de localización de instalaciones. En el estudio de localización se pueden abordar dos grandes aspectos: macrolocalización y microlocalización. En ambos casos el procedimiento de análisis de localización abordará las fases de: Análisis preliminar Búsqueda de alternativas de localización Evaluación de alternativas &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/">Método de localización de instalaciones utilizando mapas de calor (Google Maps + Javascript)</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>Mucho se ha desarrollado en la literatura académica acerca de los <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/"><strong>métodos o algoritmos de localización</strong></a> de instalaciones. En el estudio de localización se pueden abordar dos grandes aspectos: <em><strong>macrolocalización</strong></em> y <em><strong>microlocalización</strong></em>. En ambos casos el procedimiento de análisis de localización abordará las fases de:</p>
<ul>
<li>Análisis preliminar</li>
<li>Búsqueda de alternativas de localización</li>
<li>Evaluación de alternativas</li>
<li>Selección de localización</li>
</ul>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span><strong>Macrolocalización</strong>: Es decir, la selección de la región o zona más adecuada, evaluando las regiones que preliminarmente presenten ciertos atractivos para la industria que se trate.</p>
<p><strong> Microlocalización</strong>: Es decir, la selección específica del sitio o terreno que se encuentra en la región que ha sido evaluada como la más conveniente.
			</div>
		</div>
	
<p>Algunos de los algoritmos que apoyan las fases del procedimiento de localización, presentan dificultades propias del contexto operacional real que se pretende abordar. Por ejemplo, el <strong><a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/">Método de Centro de Gravedad</a></strong>, requiere de la consideración de un conjunto de instalaciones existentes, y su objetivo es el de establecer la ubicación de un punto de <em>servicio / atención / suministro</em> para los puntos dados. Requiere para ello de la existencia de un sistema de coordenadas con un punto de origen.</p>
<p>Recuerdo que cuando utilicé este algoritmo en la <em>Universidad </em>utilizamos la copia de un mapa de la región, sobre ella trazamos un plano cartesiano, definimos las ubicaciones del caso, registramos las coordenadas y como resultado obtuvimos las coordenadas de la localización ideal. La dificultad subyace en la falta de practicidad.</p>
<p>Otro método, como el <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-heuristico-de-ardalan/"><strong>Heurístico de Ardalan</strong></a>, utiliza un conjunto de instalaciones existentes, y un conjunto de localizaciones tentativas. Toma como base una matriz de distancias y el objetivo consiste en optimizar la cobertura. Sin embargo, obtener la información requiere del levantamiento de mínimo una matriz <em>n * m.</em> En la medida en la que el número de ubicaciones aumenta el algoritmo se convierte en complejo.</p>
<hr />
<p>Desde hace algunos años, la disponibilidad de servidores de aplicaciones de mapas, los sistemas de posicionamiento satelital, los sistemas de información geográfica, entre otros; han facilitado la adopción de soluciones basadas en entornos reales, como herramientas que apoyen algunas de las fases del procedimiento de localización de ubicaciones.</p>
<p>En este artículo utilizaremos mapas de calor y servidores de aplicaciones de mapas, como herramienta visual de soporte en los procesos de selección de localizaciones.</p>
<h2>¿Qué es un mapa de calor?</h2>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/heatmap.svg" alt="mapa de calor" class="wp-image-27617 alignright" width="178" height="178" />En este contexto, un mapa de calor es una capa de visualización que se utiliza para representar la intensidad de los datos en puntos geográficos (ubicaciones). Cuando la capa de mapa de calor se encuentra habilitada, aparecerá una superposición de color en la parte superior del mapa. De forma predeterminada (es un estándar), las áreas de mayor intensidad se colorearán en rojo y las áreas de menor intensidad aparecerán en verde.</p>
<p>La intensidad de los datos de una región en particular puede aumentar dada la concentración de ubicaciones en una zona específica. Del mismo modo, pueden utilizarse <em>puntos de datos ponderados</em>, es decir, que un punto geográfico en particular puede tener un peso que hará que el punto se represente con mayor intensidad.</p>
<p>Un ejemplo de aplicación práctica de los puntos de datos ponderados, puede ser la cantidad de individuos que vivan en un punto específico. En este caso, los puntos ponderados ayudarán a representar densidad poblacional.</p>
<hr />
<h2>Mapas de calor + Google Maps</h2>
<p>El servidor de aplicaciones de mapas más popular del mundo: <em>Google Maps</em>, cuenta con una librería de visualización que nos permite el uso de mapas de calor con puntos normales o ponderados. Evaluaremos su uso por medio de un caso práctico.</p>
<blockquote class=" quote-simple "><p>El Departamento de Desarrollo Sostenible de la ciudad de Cali se encuentra implementando una estrategia piloto de recolección de aceite de cocina usado. Ha articulado este proyecto con una Universidad, la cual desarrolló 4 contenedores inteligentes (BIN&#8217;s) para la disposición del bioresiduo. En investigaciones asociadas, la Universidad ha determinado que el reciclaje del aceite es un problema de densidad; esto quiere decir que es vital la ubicación de los contenedores (cobertura), para así mismo optimizar el proceso de disposición y recolección. El proyecto piloto piensa articular a las instituciones de educación como puntos potenciales de recolección. Por medio de las instituciones piensan socializar el programa con la comunidad. El primer reto del proyecto consiste en determinar la ubicación de los contenedores inteligentes (4 unidades). La información relacionada con las instituciones de educación que hacen parte del programa (<em>ubicación geográfica / población estudiantil</em>), se detalla a continuación:</p></blockquote>
<p>&nbsp;</p>
<table width="716">
<tbody>
<tr>
<td width="269" style="text-align: center;"><strong>Establecimiento</strong></td>
<td width="282" style="text-align: center;"><strong>Latitud / Longitud</strong></td>
<td width="165" style="text-align: center;"><strong>Número de estudiantes</strong></td>
</tr>
<tr>
<td> Comfandi San Nicolás</td>
<td>3.4535911182,  -76.522548858</td>
<td>1494</td>
</tr>
<tr>
<td> Mayor de Santiago de Cali</td>
<td>3.4515777580,  -76.510232156</td>
<td>908</td>
</tr>
<tr>
<td> Municipal Comfandi</td>
<td>3.4481079145, -76.510747140</td>
<td>697</td>
</tr>
<tr>
<td> Internado San Carlos</td>
<td>3.4469941349, -76.515253250</td>
<td>1714</td>
</tr>
<tr>
<td> León de Greiff</td>
<td>3.4479794015, -76.499932474</td>
<td>1731</td>
</tr>
<tr>
<td> Nuestra Señora de la Anunciación</td>
<td>3.4451521118, -76.496413416</td>
<td>2297</td>
</tr>
<tr>
<td> Fernando de Aragón</td>
<td>3.4373556029, -76.513837044</td>
<td>1265</td>
</tr>
<tr>
<td> Casa Evangélica</td>
<td>3.4379553366, -76.522999470</td>
<td>1658</td>
</tr>
<tr>
<td> San Alberto Magno</td>
<td>3.4330289411, -76.527076427</td>
<td>604</td>
</tr>
<tr>
<td> Santa María Goretty</td>
<td>3.4334144860, -76.507206624</td>
<td>416</td>
</tr>
<tr>
<td> San Alberto Magno</td>
<td>3.4331574561,  -76.526733104</td>
<td>1584</td>
</tr>
<tr>
<td> San Ignacio de Loyola</td>
<td>3.4317866287,  -76.517334644</td>
<td>2350</td>
</tr>
<tr>
<td> Nuestro Futuro</td>
<td>3.4306299916, -76.503601735</td>
<td>964</td>
</tr>
<tr>
<td> Sabio Caldas</td>
<td>3.4290878065, -76.516605083</td>
<td>329</td>
</tr>
<tr>
<td> CREAD</td>
<td>3.4250609784, -76.514888470</td>
<td>774</td>
</tr>
<tr>
<td> Licomtec</td>
<td>3.4166645586, -76.516733829</td>
<td>1818</td>
</tr>
<tr>
<td>  Nuestra Señora De La Providencia</td>
<td>3.4195347715,  -76.495919889</td>
<td>1530</td>
</tr>
<tr>
<td> Real Suizo</td>
<td>3.4152080294, -76.493237680</td>
<td>2106</td>
</tr>
<tr>
<td> Nuevo Edén</td>
<td>3.4157220988, -76.533835594</td>
<td>330</td>
</tr>
<tr>
<td> Católico</td>
<td>3.4130660706, -76.539843742</td>
<td>976</td>
</tr>
<tr>
<td> Santa María Stella</td>
<td>3.4270315559,  -76.551345054</td>
<td>1975</td>
</tr>
<tr>
<td> Santa Isabel</td>
<td>3.4080535495,  -76.508172225</td>
<td>936</td>
</tr>
<tr>
<td> Compartir</td>
<td>3.4319576632,  -76.474955752</td>
<td>1563</td>
</tr>
<tr>
<td> Lancaster</td>
<td>3.4007708157,  -76.551774213</td>
<td>1219</td>
</tr>
<tr>
<td> Parroquial Divino Salvador</td>
<td>3.3970865884, -76.542590328</td>
<td>1954</td>
</tr>
<tr>
<td> Reyes Católicos</td>
<td>3.3933166668,  -76.537354656</td>
<td>399</td>
</tr>
<tr>
<td> Liceo Anglo del Valle</td>
<td>3.3873187189,  -76.519759374</td>
<td>1741</td>
</tr>
<tr>
<td> Laurence</td>
<td>3.3834202377, -76.520789343</td>
<td>1111</td>
</tr>
<tr>
<td> Los Almendros</td>
<td>3.3812782083,  -76.520231443</td>
<td>1826</td>
</tr>
<tr>
<td> Bautista</td>
<td>3.3772083395,  -76.523278432</td>
<td>1772</td>
</tr>
<tr>
<td> Lacordaire</td>
<td>3.3781508370,  -76.544607357</td>
<td>1965</td>
</tr>
<tr>
<td> General José María Córdoba</td>
<td>3.3935733137, -76.549328047</td>
<td>841</td>
</tr>
<tr>
<td> El Hogar</td>
<td>3.3907458636,  -76.550315100</td>
<td>770</td>
</tr>
<tr>
<td> Americano</td>
<td>3.3790932549, -76.546881873</td>
<td>650</td>
</tr>
<tr>
<td> Santa Filomena</td>
<td>3.4019699352, -76.513450821</td>
<td>1401</td>
</tr>
<tr>
<td> Tomás Vasconi</td>
<td>3.4030409276, -76.517313202</td>
<td>1474</td>
</tr>
<tr>
<td> República del Salvador</td>
<td>3.4044546356, -76.521433075</td>
<td>1926</td>
</tr>
<tr>
<td> Los Andes</td>
<td>3.4296010767,  -76.537612160</td>
<td>1566</td>
</tr>
<tr>
<td>Villacolombia</td>
<td>3.4454939428, -76.501692020</td>
<td>2354</td>
</tr>
<tr>
<td>Las Américas</td>
<td>3.4492208216, -76.505940638</td>
<td>2043</td>
</tr>
<tr>
<td>Santa Fe</td>
<td>3.4422382667, -76.509888850</td>
<td>2333</td>
</tr>
<tr>
<td>Evaristo García</td>
<td>3.4407817764, -76.517527780</td>
<td>696</td>
</tr>
<tr>
<td>Alfredo Vásquez Cobo</td>
<td>3.4355983661,  -76.516454898</td>
<td>1073</td>
</tr>
<tr>
<td>Ciudad de Cali</td>
<td>3.4311431813,  -76.512721263</td>
<td>1275</td>
</tr>
<tr>
<td>INEM</td>
<td>3.4827619907, -76.4997608303</td>
<td>1485</td>
</tr>
<tr>
<td>Olaya Herrera</td>
<td>3.4781785185, -76.512807093</td>
<td>1470</td>
</tr>
<tr>
<td>Guillermo Valencia</td>
<td>3.4744945902,  -76.513665400</td>
<td>1248</td>
</tr>
<tr>
<td>José Ignacio Rengifo</td>
<td>3.4716245430, -76.513665400</td>
<td>2160</td>
</tr>
<tr>
<td>Santo Tomás</td>
<td>3.4583022697,  -76.516454898</td>
<td>1776</td>
</tr>
<tr>
<td>La Merced</td>
<td>3.4627144903, -76.502464496</td>
<td>706</td>
</tr>
<tr>
<td>Pedro Antonio Molina</td>
<td>3.4828048267, -76.487615789</td>
<td>2369</td>
</tr>
<tr>
<td>Santa Librada</td>
<td>3.4622861203, -76.523020945</td>
<td>2498</td>
</tr>
<tr>
<td>República de Israel</td>
<td>3.4636569037, -76.510532580</td>
<td>1510</td>
</tr>
<tr>
<td>San Vicente Paul</td>
<td>3.4662271172, -76.509502612</td>
<td>2330</td>
</tr>
<tr>
<td>Manuel María Mallarino</td>
<td>3.4567601292, -76.488517010</td>
<td>1464</td>
</tr>
<tr>
<td>Sebastián de Belalcázar</td>
<td>3.4602299411,  -76.485212529</td>
<td>628</td>
</tr>
<tr>
<td>Liceo Departamental</td>
<td>3.4238604624,  -76.538556302</td>
<td>364</td>
</tr>
<tr>
<td>Libardo Madrid</td>
<td>3.4220611537,  -76.543834890</td>
<td>2439</td>
</tr>
<tr>
<td>Metropolitano Santa Anita</td>
<td>3.4016910381, -76.542182651</td>
<td>1815</td>
</tr>
<tr>
<td>San José</td>
<td>3.3969358164,  -76.550315108</td>
<td>2230</td>
</tr>
</tbody>
</table>
<p>De acuerdo a la información disponible, es posible utilizar un mapa de calor como herramienta de análisis preliminar y búsqueda de alternativas de localización. Veamos.</p>
<h3><i>Agregar una capa de mapa de calor</i></h3>
<p>La API de Google Maps puede utilizarse de la misma manera en la que un sitio web incorpora un mapa tradicional a su plataforma (<em>Javascript</em>). También pueden utilizarse plataformas externas para su visualización como <a href="https://jsfiddle.net/"><em><strong>JSFiddle</strong></em></a>.</p>
<p>Lo primero que haremos es configurar el mapa sobre el cual se ubicarán los puntos:</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-js" data-lang="JavaScript"><code>let map, heatmap;

function initMap() {
  map = new google.maps.Map(document.getElementById("map"), {
    zoom: 13,
    center: { lat: 3.43, lng: -76.51 },
    mapTypeId: "satellite",
  });
  heatmap = new google.maps.visualization.HeatmapLayer({
    data: getPoints(),
    map: map,
  });
  document
    .getElementById("toggle-heatmap")
    .addEventListener("click", toggleHeatmap);
  document
    .getElementById("change-gradient")
    .addEventListener("click", changeGradient);
  document
    .getElementById("change-opacity")
    .addEventListener("click", changeOpacity);
  document
    .getElementById("change-radius")
    .addEventListener("click", changeRadius);
}</code></pre>
</div>
<p><em><strong>zoom: </strong></em>Indicará el nivel de cercanía inicial del mapa de acuerdo a su centro. De igual forma, como usuarios podemos utilizar los controles para acercar o alejar una vez tengamos la visualización.</p>
<p><em><strong>center: </strong></em>Indicará las coordenadas centrales del mapa (latitud y longitud). En nuestro ejemplo hemos adicionado las coordenadas de la ciudad de Cali (lat: 3.43, lng: -76.51).</p>
<p><em><strong>mapTypeId: </strong></em>Tipo de mapa a utilizar. Podemos elegir un mapa tipo <em>relieve </em>o un mapa <em>satelital </em>(<em>satellite</em>).</p>
<p>En este mapa utilizaremos algunas funciones que nos permitirán cambiar algunos atributos de visualización: <em>degradado, opacidad, radio de calor. </em></p>
<p><strong>gradient: </strong>Corresponde al degradado de color del mapa de calor, de manera predeterminada degradará desde el rojo (máxima intensidad) hacia el verde. Sin embargo, usted puede configurar la matriz de colores del degradado. En nuestro ejemplo, permitiremos que el usuario haga un cambio en la configuración del degradado con un clic.</p>
<p><strong>opacity</strong>: La opacidad corresponde a la transparencia de la capa del mapa de calor, expresada como un número entre 0 y 1. En nuestro ejemplo, permitiremos que el usuario haga un cambio en la configuración de la opacidad con un clic.</p>
<p><strong>radius</strong>: Corresponde al radio de influencia de cada punto de datos, en píxeles. Este es uno de los atributos más importantes del mapa de calor, ya que a partir de su valor podremos visualizar mejor o no, la data correspondiente. En nuestro ejemplo, permitiremos que el usuario haga un cambio en la configuración del radio con un clic.</p>
<h3><em>Cambio de atributos</em></h3>
<p>Las siguientes líneas permitirán cambiar los atributos ya mencionados con un solo clic. A continuación se establecen los valores opcionales de cada atributo.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-js" data-lang="JavaScript"><code>function toggleHeatmap() {
  heatmap.setMap(heatmap.getMap() ? null : map);
}

function changeGradient() {
  const gradient = [
    "rgba(0, 255, 255, 0)",
    "rgba(0, 255, 255, 1)",
    "rgba(0, 191, 255, 1)",
    "rgba(0, 127, 255, 1)",
    "rgba(0, 63, 255, 1)",
    "rgba(0, 0, 255, 1)",
    "rgba(0, 0, 223, 1)",
    "rgba(0, 0, 191, 1)",
    "rgba(0, 0, 159, 1)",
    "rgba(0, 0, 127, 1)",
    "rgba(63, 0, 91, 1)",
    "rgba(127, 0, 63, 1)",
    "rgba(191, 0, 31, 1)",
    "rgba(255, 0, 0, 1)",
  ];
  heatmap.set("gradient", heatmap.get("gradient") ? null : gradient);
}

function changeRadius() {
  heatmap.set("radius", heatmap.get("radius") ? null : 20);
}

function changeOpacity() {
  heatmap.set("opacity", heatmap.get("opacity") ? null : 5);
}</code></pre>
</div>
<h3><em>Data de entrada: Ubicaciones</em></h3>
<p>A continuación se ingresarán las 50 ubicaciones de nuestro caso de ejemplo. Utilizaremos puntos ponderados, con coordenadas de latitud y longitud, y un peso determinado por la población estudiantil de cada punto.</p>
<div class="hcb_wrap">
<pre class="prism line-numbers lang-js" data-lang="JavaScript"><code>function getPoints() {
  return [
    {location: new google.maps.LatLng(3.453591118286918, -76.52254885881977), weight: 1494},
    {location: new google.maps.LatLng(3.451577758085148, -76.51023215602375), weight: 908},
    {location: new google.maps.LatLng(3.4481079145332427, -76.51074714011278), weight: 697},
    {location: new google.maps.LatLng(3.4469941349057063, -76.51525325089182), weight: 1714},
    {location: new google.maps.LatLng(3.4479794015658674, -76.49993247424311), weight: 1731},
    {location: new google.maps.LatLng(3.4451521118907227, -76.49641341630138), weight: 2297},
    {location: new google.maps.LatLng(3.4373556029276764, -76.51383704461735), weight: 1265},
    {location: new google.maps.LatLng(3.4379553366684252, -76.52299947000571), weight: 1658},
    {location: new google.maps.LatLng(3.4330289411959662, -76.52707642704613), weight: 604},
    {location: new google.maps.LatLng(3.4334144860421287, -76.50720662416609), weight: 416},
    {location: new google.maps.LatLng(3.433157456127054, -76.52673310420856), weight: 1584},
    {location: new google.maps.LatLng(3.431786628745183, -76.51733464458373), weight: 2350},
    {location: new google.maps.LatLng(3.4306299916118603, -76.50360173554287), weight: 964},
    {location: new google.maps.LatLng(3.4290878065901618, -76.51660508379094), weight: 329},
    {location: new google.maps.LatLng(3.4250609784210844, -76.51488847016083), weight: 774},
    {location: new google.maps.LatLng(3.4166645586142086, -76.51673382932174), weight: 1818},
    {location: new google.maps.LatLng(3.419534771537968, -76.49591988905668), weight: 1530},
    {location: new google.maps.LatLng(3.41520802942298, -76.493237680305), weight: 2106},
    {location: new google.maps.LatLng(3.4157220988351096, -76.53383559476927), weight: 330},
    {location: new google.maps.LatLng(3.4130660706512925, -76.53984374247463), weight: 976},
    {location: new google.maps.LatLng(3.427031555952873, -76.55134505496746), weight: 1975},
    {location: new google.maps.LatLng(3.408053549563415, -76.50817222583817), weight: 936},
    {location: new google.maps.LatLng(3.431957663249241, -76.47495575209557), weight: 1563},
    {location: new google.maps.LatLng(3.400770815705138, -76.55177421321405), weight: 1219},
    {location: new google.maps.LatLng(3.3970865884759056, -76.54259032842468), weight: 1954},
    {location: new google.maps.LatLng(3.393316666803048, -76.53735465673438), weight: 399},
    {location: new google.maps.LatLng(3.387318718983735, -76.5197593748766), weight: 1741},
    {location: new google.maps.LatLng(3.3834202377137204, -76.52078934305466), weight: 1111},
    {location: new google.maps.LatLng(3.381278208361199, -76.52023144362487), weight: 1826},
    {location: new google.maps.LatLng(3.377208339558826, -76.52327843281832), weight: 1772},
    {location: new google.maps.LatLng(3.378150837005705, -76.54460735730136), weight: 1965},
    {location: new google.maps.LatLng(3.3935733137749238, -76.54932804783431), weight: 841},
    {location: new google.maps.LatLng(3.390745863684127, -76.55031510067163), weight: 770},
    {location: new google.maps.LatLng(3.3790932549330677, -76.54688187341141), weight: 650},
    {location: new google.maps.LatLng(3.4019699352880104, -76.51345082175563), weight: 1401},
    {location: new google.maps.LatLng(3.4030409276299833, -76.51731320242338), weight: 1474},
    {location: new google.maps.LatLng(3.4044546356985284, -76.52143307513562), weight: 1926},
    {location: new google.maps.LatLng(3.429601076750566, -76.53761216054455), weight: 1566},
    {location: new google.maps.LatLng(3.4454939428890783, -76.5016920200071), weight: 2354},
    {location: new google.maps.LatLng(3.4492208216317457, -76.50594063874162), weight: 2043},
    {location: new google.maps.LatLng(3.4422382667554077, -76.50988885009086), weight: 2333},
    {location: new google.maps.LatLng(3.4407817764607853, -76.51752778074483), weight: 696},
    {location: new google.maps.LatLng(3.435598366122187, -76.51645489840418), weight: 1073},
    {location: new google.maps.LatLng(3.431143181324255, -76.51272126375868), weight: 1275},
    {location: new google.maps.LatLng(3.48276199070547, -76.49976083030087), weight: 1485},
    {location: new google.maps.LatLng(3.4781785185724408, -76.51280709388969), weight: 1470},
    {location: new google.maps.LatLng(3.474494590235007, -76.51366540070475), weight: 1248},
    {location: new google.maps.LatLng(3.47162454307462, -76.51366540070475), weight: 2160},
    {location: new google.maps.LatLng(3.458302269741842, -76.51645489800703), weight: 1776},
    {location: new google.maps.LatLng(3.4627144903470133, -76.50246449692165), weight: 706},
    {location: new google.maps.LatLng(3.4828048267502214, -76.48761578902122), weight: 2369},
    {location: new google.maps.LatLng(3.4622861203152, -76.52302094514219), weight: 2498},
    {location: new google.maps.LatLng(3.4636569037348472, -76.51053258098315), weight: 1510},
    {location: new google.maps.LatLng(3.4662271172959103, -76.5095026128051), weight: 2330},
    {location: new google.maps.LatLng(3.4567601292443983, -76.4885170108912), weight: 1464},
    {location: new google.maps.LatLng(3.460229941169211, -76.48521252965324), weight: 628},
    {location: new google.maps.LatLng(3.423860462402868, -76.53855630259389), weight: 364},
    {location: new google.maps.LatLng(3.422061153775949, -76.54383489070575), weight: 2439},
    {location: new google.maps.LatLng(3.4016910381681438, -76.54218265181241), weight: 1815},
    {location: new google.maps.LatLng(3.396935816423716, -76.55031510890593), weight: 2230},
   
  ];
}</code></pre>
</div>
<hr />
<p>A partir de estas configuraciones y data de entrada, podemos obtener un mapa de calor soportado en Google Maps. Podemos ver este ejemplo en: <a href="https://jsfiddle.net/2p1xh4L6/"><strong>Mapa de calor Google Maps Ejemplo</strong></a>.</p>
<p>El resultado será:</p>
<p><iframe loading="lazy" width="100%" height="480" src="//jsfiddle.net/2p1xh4L6/embedded/result/" allowfullscreen="allowfullscreen" allowpaymentrequest="" frameborder="0"><span data-mce-type="bookmark" style="display: inline-block; width: 0px; overflow: hidden; line-height: 0;" class="mce_SELRES_start">﻿</span></iframe></p>
<p>Podemos ocultar o visualizar la capa del mapa de calor; cambiar los colores del degradado; cambar el radio de intensidad de cada punto ponderado; y por último, cambiar la transparencia de la capa.</p>
<p>Así mismo, podemos considerar, por ejemplo, que la representación visual se encuentra muy dispersa y no nos permite tener una idea concluyente. Podemos intentar ampliando el radio (<em>radius</em>) de cada punto (en el código directamente), es decir, su influencia. De manera que nos permita una visualización con mayor densidad. Ampliando a 70 píxeles el radio del código anterior, tendríamos:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali4.jpg" alt="mapas de calor" width="654" height="371" class="aligncenter wp-image-27610 size-full" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali4.jpg 654w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali4-300x170.jpg 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali4-390x220.jpg 390w" sizes="(max-width: 654px) 100vw, 654px" /></p>
<p>A partir de esta imagen los <em>tomadores de decisiones </em>pueden tener una idea aproximada respecto a las zonas geográficas de mayor densidad poblacional. Al contrario de los algoritmos tradicionales, no obtendremos una coordenada específica (que probablemente conduzca a un lugar inhabitable o no disponible); tendremos zonas de densidad basadas en la ponderación deseada.</p>
<p>Podemos ampliar el <em>zoom</em> sobre una zona deseada y conocer los puntos específicos (con su intensidad respectiva):</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali5.jpg" alt="mapas de calor" width="654" height="371" class="aligncenter wp-image-27611 size-full" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali5.jpg 654w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali5-300x170.jpg 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali5-390x220.jpg 390w" sizes="(max-width: 654px) 100vw, 654px" /></p>
<p>Aquí podemos ver con claridad la diferencia del peso ponderado de los puntos; aquellos puntos más intensos serán aquellas instituciones educativas con mayor población estudiantil (de acuerdo a nuestro caso). Podemos incluso, haciendo uso del registro de imágenes en campo de Google, revisar un sector en específico; revisar el estado de las vías, revisar si existen unidades habitables, entre otros:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali6.jpg" alt="" width="654" height="371" class="size-full wp-image-27612 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali6.jpg 654w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali6-300x170.jpg 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2021/08/mapa_calor_cali6-390x220.jpg 390w" sizes="(max-width: 654px) 100vw, 654px" /></p>
<hr />
<p>Tal como lo hemos mencionado, los mapas de calor son no nos proporcionan como resultado una localización específica; nos proporcionan una visión de densidad basada en un factor de ponderación establecido. Además, es una herramienta dinámica, la cual puede integrarse con fuentes de datos diversas, que puede manipularse en un entorno geográfico real.</p>
<p>Es una herramienta que recomendamos para el análisis preliminar y la búsqueda de zonas de localización.</p>
<p>Sin embargo, al utilizar mapas de calor en entornos como por ejemplo <em>Python, </em>podemos integrar a esta herramienta, un método heurístico que nos proporcione una localización específica. Si quieres conocer un modelo que integra ambas herramientas, te invitamos a leer: <em><a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/" target="_blank" rel="noopener"><strong>Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</strong></a></em>.</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/">Método de localización de instalaciones utilizando mapas de calor (Google Maps + Javascript)</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Método heurístico de Ardalan</title>
		<link>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-heuristico-de-ardalan/</link>
					<comments>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-heuristico-de-ardalan/#comments</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Tue, 03 Sep 2019 19:39:20 +0000</pubDate>
				<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Diseño de planta]]></category>
		<category><![CDATA[Distribución en planta]]></category>
		<category><![CDATA[Localización de plantas]]></category>
		<category><![CDATA[Método de Ardalan]]></category>
		<guid isPermaLink="false">http://contentlab.co/ingenieria/?p=1846</guid>

					<description><![CDATA[<p>El método heurístico de Ardalan  es uno de los algoritmos más utilizados para la localización de servicios. Su objetivo es establecer la ubicación de un punto de servicio en un área geográfica, teniendo en cuenta una optimización en términos de distancia, cobertura y algún factor de ponderación que refleje una importancia relativa de atención de algún punto. &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-heuristico-de-ardalan/">Método heurístico de Ardalan</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>El <strong>método heurístico de Ardalan </strong> es uno de los <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/"><strong>algoritmos más utilizados para la localización</strong></a> de servicios. Su objetivo es establecer la ubicación de un punto de servicio en un área geográfica, teniendo en cuenta una optimización en términos de distancia, cobertura y algún factor de ponderación que refleje una importancia relativa de atención de algún punto.</p>
<div id="cc-m-5723096813" class="j-module n j-hgrid ">
<div class="cc-m-hgrid-column last">
<div id="cc-matrix-1294518413">
<div id="cc-m-5713483113" class="j-module n j-text ">
<p>El algoritmo es bastante práctico y lo analizaremos a continuación con un ejemplo:</p>
<p><em>Se desea ubicar dos centros de atención médica para los habitantes de cuatro barrios de una capital. Se están evaluando cuatro alternativas de localización, cada una de ellas ubicadas en cada uno de los barrios objetivo.</em></p>
</div>
</div>
</div>
</div>
<div id="cc-m-5723096913" class="j-module n j-text ">
<p><em>Las distancias entre las ubicaciones alternativas y los barrios objetivo, así como la población de los barrios y la ponderación relativa de atención se establecen en el siguiente tabulado:</em></p>
<p><img decoding="async" class="aligncenter size-full wp-image-2058" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-52.png" alt="" width="413" height="148" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-52.png 413w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-52-300x108.png 300w" sizes="(max-width: 413px) 100vw, 413px" /></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span><strong>Paso 1:</strong> El primer paso consiste en construir un tabulado de ponderación &#8211; población &#8211; distancia, determinado por el producto de estos factores:
			</div>
		</div>
	
<p><img decoding="async" class="aligncenter size-full wp-image-2059" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-53.png" alt="" width="377" height="128" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-53.png 377w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-53-300x102.png 300w" sizes="(max-width: 377px) 100vw, 377px" /></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span><strong>Paso 2:</strong> El segundo paso consiste en efectuar la sumatoria de cada una de las alternativas y elegir la menor, de ésta manera obtendríamos la primera ubicación.
			</div>
		</div>
	
<p><img decoding="async" class="aligncenter size-full wp-image-2060" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-54.png" alt="" width="379" height="146" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-54.png 379w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-54-300x116.png 300w" sizes="(max-width: 379px) 100vw, 379px" /></p>
<p><em>En éste caso la primera ubicación óptima sería la alternativa A.</em></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span><strong>Paso 3:</strong> Éste paso se utiliza sí como en nuestro caso se precisa de dos o más ubicaciones, puesto que para seleccionar las ubicaciones siguientes se utiliza el siguiente método: Comparar el valor de la ubicación ya seleccionada ( en éste caso A) con las alternativas restantes, en el caso de que el valor de la alternativa sea menor que el valor de la ubicación ya seleccionada se debe dejar éste tal como se encuentre, y en el caso en que sea mayor se debe reducir e igualarlo al valor de la ubicación ya seleccionada, por ejemplo:
			</div>
		</div>
	
<p><img decoding="async" class="aligncenter size-full wp-image-2062" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-55.png" alt="" width="376" height="146" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-55.png 376w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-55-300x116.png 300w" sizes="(max-width: 376px) 100vw, 376px" /></p>
<p>Podemos observar entonces cómo los valores se ajustaron según fueron comparados con la ubicación ya seleccionada A. Se vuelven a totalizar los valores de cada una de las alternativas y se selecciona la siguiente ubicación según el menor valor de los totales, en éste caso la alternativa C. De ésta manera hemos seleccionado las dos ubicaciones óptimas según el algoritmo heurístico para nuestro ejemplo de instalaciones médicas. En éste caso las alternativas óptimas serán entonces A y C.</p>
</div>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-heuristico-de-ardalan/">Método heurístico de Ardalan</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-heuristico-de-ardalan/feed/</wfw:commentRss>
			<slash:comments>1</slash:comments>
		
		
			</item>
		<item>
		<title>Método del Centro de gravedad</title>
		<link>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/</link>
					<comments>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/#respond</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Tue, 03 Sep 2019 19:29:12 +0000</pubDate>
				<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Diseño de planta]]></category>
		<category><![CDATA[Distribución en planta]]></category>
		<category><![CDATA[Método del Centro de gravedad]]></category>
		<guid isPermaLink="false">http://contentlab.co/ingenieria/?p=1841</guid>

					<description><![CDATA[<p>El método del centro de gravedad consiste en un algoritmo de localización de una instalación considerando otras existentes. Esta es una técnica muy sencilla y suele utilizarse para determinar la ubicación de bodegas intermedias y puntos de distribución teniendo en cuenta las distancias que las separan y el aporte (en términos de utilidad, producción o capacidad) de &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/">Método del Centro de gravedad</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>El <strong>método del centro de gravedad </strong>consiste en un <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/"><strong>algoritmo de localización</strong></a> de una instalación considerando otras existentes. Esta es una técnica muy sencilla y suele utilizarse para determinar la ubicación de bodegas intermedias y puntos de distribución teniendo en cuenta las distancias que las separan y el aporte (en términos de utilidad, producción o capacidad) de cada instalación.</p>
<p>Este método se trabaja con un sistema de coordenadas. A continuación se presentan diferentes referencias de sistemas geográficos basados en coordenadas:</p>

		<div class="checklist tie-list-shortcode">
<div class="cc-m-hgrid-column last">
<div id="cc-matrix-1294518013">
<div id="cc-m-5713476413" class="j-module n j-text ">
<ul>
<li>Coordenadas geográficas (latitud &#8211; longitud).</li>
<li>Coordenadas cartesianas.</li>
<li>Coordenadas de un municipio.</li>
</ul>
</div>
</div>
</div>

		</div>
	
<p>Las coordenadas utilizadas en el método deben tener como referencia a un punto de origen, y las fórmulas a utilizar para encontrar las coordenadas óptimas de la nueva localización son:</p>
<p><img decoding="async" class="aligncenter size-full wp-image-2064" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-56.png" alt="" width="497" height="96" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-56.png 497w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-56-300x58.png 300w" sizes="(max-width: 497px) 100vw, 497px" /></p>
<div id="cc-m-5713476913" class="j-module n j-text ">
<p><em>Donde:</em></p>
<p><img decoding="async" class="aligncenter size-full wp-image-2065" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-57.png" alt="" width="630" height="584" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-57.png 630w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-57-300x278.png 300w" sizes="(max-width: 630px) 100vw, 630px" /></p>
<h3><em>Ejemplo de aplicación del Centro de gravedad</em></h3>
<div class="cc-m-hgrid-column last">
<div id="cc-matrix-1350164513">
<div id="cc-m-5713479913" class="j-module n j-text ">
<p><img decoding="async" class="size-full wp-image-2067 alignleft" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-58.png" alt="" width="171" height="144" /></p>
<p>La empresa GASOL S.A desea ubicar una instalación intermedia que requiere de disponibilidad de gasolina, desea ubicar esta instalación entre la ciudad de Barrancabermeja y sus principales distribuidores. En el siguiente cuadro se relaciona la información acerca de las coordenadas y el aporte de galones de gasolina de cada distribuidor.</p>
</div>
</div>
</div>
<p><img decoding="async" class="aligncenter size-full wp-image-2068" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-59.png" alt="" width="419" height="148" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-59.png 419w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-59-300x106.png 300w" sizes="(max-width: 419px) 100vw, 419px" /></p>
<p><em>Ubicación de las puntos en el plano cartesiano:</em></p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano.png" alt="Método de gravedad" width="615" height="279" class="aligncenter wp-image-27319" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano.png 2560w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-300x136.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1024x464.png 1024w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-768x348.png 768w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1536x696.png 1536w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-2048x928.png 2048w" sizes="(max-width: 615px) 100vw, 615px" /></p>
<div id="cc-m-5713480113" class="j-module n j-text ">
<p>La formulación requiere de la sumatoria de los productos entre las distancias en términos de cada coordenada y el aporte de gasolina, esta información se relaciona en el siguiente tabulado:</p>
</div>
<div id="cc-m-5713480213" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" class="aligncenter size-full wp-image-2069" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-60.png" alt="" width="483" height="167" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-60.png 483w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-60-300x104.png 300w" sizes="(max-width: 483px) 100vw, 483px" /></figure>
<div class="cc-clear"></div>
</div>
<div id="cc-m-5713480313" class="j-module n j-text ">
<p>Aplicando la formulación del algoritmo tendríamos las siguientes coordenadas:</p>
</div>
<div id="cc-m-5713480413" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" class="aligncenter size-full wp-image-2070" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Sin-título-61.png" alt="" width="255" height="148" /></figure>
<p>Esto quiere decir que en el sistema de coordenadas utilizado para establecer las ubicaciones propuestas en el ejercicio, la instalación óptima se ubicaría en las coordenadas <em><strong>X = 44,2</strong></em> &#8211; <em><strong>Y = 4,7.</strong></em></p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1.png" alt="Método de gravedad" width="2560" height="1160" class="aligncenter size-full wp-image-27320" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1.png 2560w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1-300x136.png 300w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1-1024x464.png 1024w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1-768x348.png 768w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1-1536x696.png 1536w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/09/Plano-Cartesiano-1-2048x928.png 2048w" sizes="(max-width: 2560px) 100vw, 2560px" /></p>
<hr />
<h2>Otras herramientas</h2>
<p><span>Recuerdo que cuando utilicé este algoritmo en la </span><em>Universidad </em><span>utilizamos la copia de un mapa de la región, sobre ella trazamos un plano cartesiano, definimos las ubicaciones del caso, registramos las coordenadas y como resultado obtuvimos las coordenadas de la localización ideal. La dificultad subyace en la falta de practicidad.</span></p>
<p>En este sentido, l<span>a disponibilidad de servidores de aplicaciones de mapas, entornos de programación, los sistemas de posicionamiento satelital, los sistemas de información geográfica, entre otros; han facilitado la adopción de soluciones basadas en entornos reales, como herramientas que apoyen algunas de las fases del procedimiento de localización de ubicaciones.</span></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Lo invitamos a leer: <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/" target="_blank" rel="noopener"><em><strong>Método del Centro de gravedad utilizando R</strong></em></a>. Un artículo en el cual utilizaremos un entorno de programación para hallar y graficar la ubicación de una instalación utilizando el algoritmo de Centro de Gravedad
			</div>
		</div>
	
<p>También:</p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Lo invitamos a leer: <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/" target="_blank" rel="noopener"><em><strong>Método de localización de instalaciones utilizando mapas de calor</strong></em></a>
			</div>
		</div>
	
<p>Y por último, un modelo más robusta que incorpora ambas herramientas en un mismo desarrollo:</p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Ver: <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/" target="_blank" rel="noopener"><em><strong>Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</strong></em></a>
			</div>
		</div>
	
<h2>Consideraciones finales</h2>
<p><span>El alcance de este modelo se encuentra determinado por la localización de una sola instalación (depósito, almacén, etc.), y en los casos en los que se requiera determinar múltiples localizaciones, el modelo no aplica.</span></p>

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Para ver un modelo para varias localizaciones: <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/"><em><strong>Localización de varios almacenes mediante agrupación espacial</strong></em></a>
			</div>
		</div>
	
</div>
</div>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/">Método del Centro de gravedad</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-del-centro-de-gravedad/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Métodos de localización de planta</title>
		<link>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/</link>
					<comments>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/#comments</comments>
		
		<dc:creator><![CDATA[Bryan Salazar López]]></dc:creator>
		<pubDate>Fri, 30 Aug 2019 22:21:54 +0000</pubDate>
				<category><![CDATA[Diseño y distribución en planta]]></category>
		<category><![CDATA[Localización de instalaciones]]></category>
		<category><![CDATA[Diseño de planta]]></category>
		<category><![CDATA[Distribución en planta]]></category>
		<category><![CDATA[Localización de plantas]]></category>
		<category><![CDATA[Método sinérgico]]></category>
		<guid isPermaLink="false">http://contentlab.co/ingenieria/?p=1834</guid>

					<description><![CDATA[<p>Las decisiones relacionados con la localización de la planta son del orden estratégico, y por lo tanto comprometen al staff gerencial de la organización, dado que éstas son cruciales al comprometer a la misma con costos por largos períodos, empleos y patrones de mercado. Las alternativas de localización deben ser revisadas bajo las condiciones de servicios &#8230;</p>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/">Métodos de localización de planta</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p><span style="line-height: 19.2000007629395px;">Las decisiones relacionados con la localización de la planta son del orden estratégico, y por lo tanto comprometen al <em>staff</em> gerencial de la organización, dado que éstas son cruciales al comprometer a la</span><span style="line-height: 19.2000007629395px;"> </span><span style="line-height: 19.2000007629395px;">misma con costos por largos períodos, empleos y patrones de mercado. Las alternativas de localización deben ser revisadas bajo las condiciones de servicios básicos, mano de obra, fuentes de materias primas e insumos, demanda del mercado, acceso etc., siguiendo regularmente para su determinación óptima un proceso de selección basado en el método científico.</span></p>
<h2 id="cc-m-header-5712480313" class="">Definición de actividades y alcance de un proyecto de localización de planta</h2>
<div id="cc-m-5723095913" class="j-module n j-hgrid ">
<div class="cc-m-hgrid-column last">
<div id="cc-matrix-1294517513">
<div id="cc-m-5723096013" class="j-module n j-text ">
<p style="text-align: justify;">Las decisiones de orden estratégico deben ser abordadas por las organizaciones desde un enfoque sistémico, que parte en éste caso, por la conformación de un grupo interdisciplinar encargado del proyecto de localización.</p>
<p style="text-align: justify;">Este grupo <em>interdisciplinar</em> deberá tener las competencias para abordar el proyecto con el alcance propio de los siguientes tópicos:</p>

		<div class="checklist tie-list-shortcode">
<div id="cc-m-5712480813" class="j-module n j-textWithImage ">
<div>
<div id="cc-m-textwithimage-5712480813" class="cc-m-textwithimage-inline-rte" data-name="text" data-action="text">
<ul>
<li>Conformación de los elementos críticos de mercados: Volumen, localización geográfica, precios, competencia, calidad requerida, y el análisis, evaluación y selección de la tecnología apropiada.</li>
<li>Desarrollo de la logística del proyecto, estimación de capital, elementos de costos, distribución, fletes, costo de mano de obra, servicios.</li>
<li>Análisis y selección de localización, en función de aspectos técnicos de mercado.</li>
<li>Evaluación económica y justificación del proyecto.</li>
<li>Definición de actividades, programas para la organización del proyecto y su ejecución.</li>
<li>Ingeniería de proceso, Ingeniería de detalle, compra de equipo, construcción e instalación, pruebas mecánicas, arranque.</li>
<li>Planeación de actividades acordes con la filosofía de mejoramiento continuo.</li>
</ul>
</div>
</div>
</div>
<div id="cc-m-5712481213" class="j-module n j-text "></div>

		</div>
	
<h2>¿Macro o micro-localización?</h2>
<p>En el estudio de localización se involucran dos aspectos diferentes:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li><strong>Macrolocalización</strong>: Es decir, la selección de la región o zona más adecuada, evaluando las regiones que preliminarmente presenten ciertos atractivos para la industria que se trate.</li>
<li><strong>Microlocalización: </strong>Es decir, la selección específica del sitio o terreno que se encuentra en la región que ha sido evaluada como la más conveniente.</li>
</ul>

		</div>
	
<p>En ambos casos el procedimiento de análisis de localización abordará las fases de:</p>
<ol>
<li><em>Análisis preliminar.</em></li>
<li><em>Búsqueda de alternativas de localización.</em></li>
<li><em>Evaluación de alternativas.</em></li>
<li><em>Selección de localización.</em></li>
</ol>

		<div class="clearfix"></div>
		<hr style="margin-top:20px; margin-bottom:20px;" class="divider divider-solid">
	
<h2 id="cc-m-header-5712485413" class="">Factores utilizados en estudio de localización de plantas</h2>
<p>En el proceso de evaluación de alternativas de localización, sin importar el método de selección que se utilice existen una serie de factores y subfactores que comúnmente son considerados como trascendentales para la determinación óptima de la ubicación macro o micro. La siguiente lista es de carácter enunciativo y no limitativa, por ende, podrán considerarse otros factores y excluir algunos de los listados, dependiendo del caso específico y el criterio del evaluador.</p>

		<div class="box download  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Factores en estudios de localización de plantas. <a href="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/Factores-en-estudios-de-localización-de-plantas.pdf">Descargar</a>
			</div>
		</div>
	

		<div class="clearfix"></div>
		<hr style="margin-top:20px; margin-bottom:20px;" class="divider divider-solid">
	
<h2 id="cc-m-header-5712485913" class="">Método sinérgico de localización de plantas (Brown y Gibson)</h2>
<div id="cc-m-5712486013" class="j-module n j-textWithImage ">
<div>
<div id="cc-m-textwithimage-5712486013" class="cc-m-textwithimage-inline-rte" data-name="text" data-action="text">
<p>El Método Sinérgico o Método de Gibson y Brown es un algoritmo cuantitativo de localización de plantas que tiene como objetivo evaluar entre diversas opciones, que sitio ofrece las mejores condiciones para instalar una planta, basándose en tres tipos de factores: críticos, objetivos y subjetivos. La aplicación del modelo en cada una de sus etapas lleva a desarrollar la secuencia de cálculo:</p>
</div>
</div>
</div>
<div id="cc-m-5712486213" class="j-module n j-text ">
<p><strong><em>Factores críticos:</em> </strong>Son factores claves para el funcionamiento de organización. Su calificación es binaria, es decir, 1 o 0 y se clasifican en:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li>Energía eléctrica</li>
<li>Mano de obra</li>
<li>Materia prima</li>
<li>Seguridad</li>
</ul>

		</div>
	
<div id="cc-m-5712486213" class="j-module n j-text ">
<p>El Factor crítico de una zona se determina como el producto de las calificaciones de los subfactores, pej:</p>
<p style="text-align: center;">FC = Energía * Mano de Obra * Materia Prima * Seguridad</p>
<p>En caso de que uno de los subfactores sea calificado como 0 el resultado del factor crítico total de la zona será igual a 0.</p>
</div>
<div id="cc-m-5712513613" class="j-module n j-text ">
<p><em><strong>Factores Objetivos</strong></em>: Son los costos mensuales o anuales más importantes ocasionados al establecerse una industria y se clasifican en:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li>Costo del lote</li>
<li>Costo de mantenimiento</li>
<li>Costo de construcción</li>
<li>Costo de materia prima</li>
</ul>

		</div>
	
<p><strong><em>Factores Subjetivos</em>: </strong>Estos son los factores de tipo cualitativo, pero que afectan significativamente el funcionamiento de la empresa. Su calificación se da en porcentaje (%) y se clasifican en:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li>Impacto ambiental</li>
<li>Clima social</li>
<li>Servicios comunitarios
<ul>
<li>Hospitales</li>
<li>Bomberos</li>
<li>Policía</li>
<li>Zonas de recreación</li>
<li>Instituciones educativas</li>
</ul>
</li>
<li>Transporte</li>
<li>Competencia</li>
<li>Actitud de la comunidad</li>
</ul>

		</div>
	
<h3><em>Etapas del método sinérgico</em></h3>
<p>El método consta de las siguientes etapas:</p>

		<div class="checklist tie-list-shortcode">
<ul>
<li>Asignar el valor binario a los factores críticos.</li>
<li>Asignar un valor relativo a cada factor objetivo (FO) para cada localización alternativa.</li>
<li>Estimar un valor relativo de cada factor subjetivo (FS) para cada localización alternativa.</li>
<li>Combinar los factores objetivos, subjetivos y críticos mediante la fórmula del algoritmo sinérgico.</li>
<li>Seleccionar la ubicación que tenga la máxima medida de preferencia de localización (MPL o IL).</li>
</ul>

		</div>
	
<h3><em>Ejemplo de aplicación del método sinérgico</em></h3>
<p>En un proyecto se han identificado 4 localizaciones tentativas, en todas ellas los costos del lote, mantenimiento, materia prima y construcción son diferentes. Además se han identificado como factores críticos para la continuidad de los procesos la disponibilidad de Energía eléctrica y la Materia prima. El siguiente tabulado representa los costos asociados y la calificación de los factores críticos según un estudio previo:</p>
<p><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_0.png" alt="" width="465" height="159" class="size-full wp-image-35694 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_0.png 465w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_0-300x103.png 300w" sizes="(max-width: 465px) 100vw, 465px" /></p>
<div id="cc-m-5713460613" class="j-module n j-text ">
<p>El primer paso corresponde a calcular el valor relativo a cada factor objetivo mediante la siguiente formulación:</p>
</div>
<div id="cc-m-5713460913" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_1.png" alt="" width="194" height="136" class="size-full wp-image-35695 aligncenter" /></figure>
<div class="cc-clear"></div>
</div>
<div id="cc-m-5713461013" class="j-module n j-text ">
<p>Es decir, para calcular el Factor Objetivo de la ciudad A, deberá calcularse de la siguiente manera:</p>
</div>
<div id="cc-m-5713461113" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_2.png" alt="" width="505" height="83" class="size-full wp-image-35696 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_2.png 505w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_2-300x49.png 300w" sizes="(max-width: 505px) 100vw, 505px" /></figure>
<p>El siguiente tabulado nos muestra los Factores Objetivo de las ciudades restantes:</p>
</div>
<div id="cc-m-5713461213" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_3.png" alt="" width="434" height="160" class="size-full wp-image-35697 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_3.png 434w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_3-300x111.png 300w" sizes="(max-width: 434px) 100vw, 434px" /></figure>
</div>
<div id="cc-m-5713461513" class="j-module n j-imageSubtitle ">
<div class="cc-clear"></div>
</div>
<div id="cc-m-5713461713" class="j-module n j-text ">
<p>Al ser siempre la suma de los FO igual a 1, el valor que asume cada uno de ellos es siempre un término relativo entre las distintas alternativas de localización.</p>
</div>
<div id="cc-m-5713461813" class="j-module n j-text ">
<p>El siguiente paso corresponde a la determinación de los Factores subjetivos. El carácter subjetivo de los factores de orden cualitativo hace necesario asignar una medida de comparación que valore los distintos factores. Por ejemplo:</p>
</div>
<div id="cc-m-5713463413" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_4.png" alt="" width="492" height="140" class="size-full wp-image-35698 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_4.png 492w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_4-300x85.png 300w" sizes="(max-width: 492px) 100vw, 492px" /></figure>
<div class="cc-clear"></div>
</div>
<div id="cc-m-5713463513" class="j-module n j-text ">
<p>En el caso de que la disponibilidad de la mano de obra de la ciudad A sea «buena» su ponderación será del 15%, en el caso de que sea «excelente» será del 30% y de ésta manera se determinan el resto de factores según su ponderación y para las ciudades restantes. Para nuestro ejemplo las ponderaciones se asignaron así:</p>
</div>
<div id="cc-m-5713463613" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/sinergico_1.png" alt="" width="499" height="140" class="size-full wp-image-35702 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/sinergico_1.png 499w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/sinergico_1-300x84.png 300w" sizes="(max-width: 499px) 100vw, 499px" /></figure>
<div class="cc-clear"></div>
</div>
<div id="cc-m-5713463713" class="j-module n j-text ">
<p>El siguiente paso corresponde a la combinación de los factores críticos, objetivos y subjetivos mediante la fórmula del algoritmo sinérgico:</p>
</div>
<div id="cc-m-5713464013" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_5.png" alt="" width="369" height="42" class="size-full wp-image-35699 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_5.png 369w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_5-300x34.png 300w" sizes="(max-width: 369px) 100vw, 369px" /></figure>
<div class="cc-clear"></div>
</div>
<div id="cc-m-5713464113" class="j-module n j-text ">
<p>Donde alfa equivale al nivel de confiabilidad, en nuestro ejemplo será del 80%, es decir que alfa equivale a 0,8.</p>
<p>El índice de localización para la ciudad A se calculará entonces así:</p>
</div>
<div id="cc-m-5713465113" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_6.png" alt="" width="504" height="32" class="size-full wp-image-35700 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_6.png 504w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/metodo_sinergico_6-300x19.png 300w" sizes="(max-width: 504px) 100vw, 504px" /></figure>
<div id="cc-m-5713465213" class="j-module n j-text ">
<p>El siguiente tabulado muestra los índices de localización de todas las ciudades, podemos observar que la ciudad C tiene un índice de localización equivalente a 0,0000 esto motivado por el factor crítico Materia Prima, mientras la ciudad que tiene el mayor índice de localización y sería la mejor opción sería la ciudad D.</p>
</div>
<div id="cc-m-5713465013" class="j-module n j-imageSubtitle ">
<figure class="cc-imagewrapper cc-m-image-align-3"><img decoding="async" src="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/sinergico_1.png" alt="" width="499" height="140" class="size-full wp-image-35702 aligncenter" srcset="https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/sinergico_1.png 499w, https://ingenieriaindustrialonline.com/wp-content/uploads/2019/08/sinergico_1-300x84.png 300w" sizes="(max-width: 499px) 100vw, 499px" /></figure>
<hr />

		<div class="box info  ">
			<div class="box-inner-block">
				<span class="fa tie-shortcode-boxicon"></span>Lo invitamos a leer: <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodo-de-localizacion-de-instalaciones-utilizando-mapas-de-calor/" target="_blank" rel="noopener"><em><strong>Método de localización de instalaciones utilizando mapas de calor</strong></em></a>, <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/metodo-del-centro-de-gravedad-utilizando-r/" target="_blank" rel="noopener"><em><strong>Método de Centro de Gravedad utilizando R</strong></em></a> , <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/mapas-de-calor-y-algoritmo-de-centro-de-gravedad-utilizando-python/" target="_blank" rel="noopener"><em><strong>Mapas de calor y Algoritmo de Centro de Gravedad utilizando Python</strong></em></a>, y <a href="https://ingenieriaindustrialonline.com/localizacion-de-instalaciones/localizacion-de-varios-almacenes-mediante-agrupacion-geoespacial/"><em><strong>Localización de varios almacenes mediante agrupación espacial</strong></em></a>
			</div>
		</div>
	
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<p>La entrada <a href="https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/">Métodos de localización de planta</a> se publicó primero en <a href="https://ingenieriaindustrialonline.com">Ingenieria Industrial Online</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ingenieriaindustrialonline.com/diseno-y-distribucion-en-planta/metodos-de-localizacion-de-planta/feed/</wfw:commentRss>
			<slash:comments>5</slash:comments>
		
		
			</item>
	</channel>
</rss>
