VOLVER

Share

LA HORMIGA, UNA GRAN ALIADA DEL SOFTWARE


01 de junio de 2012

Fuente: Universidad de Málaga (UMA).

 

Los algoritmos basados en colonias de hormigas encuentran los defectos del software eficientemente.Vivimos en un mundo rodeado de software, programas que controlan no sólo el ordenador, sino los teléfonos móviles, los coches, los televisores e incluso los frigoríficos. Cuando alguno de estos programas falla, los mencionados ingenios tecnológicos dejan de funcionar adecuadamente (el ordenador no responde, el coche deja de marcar la velocidad, el teléfono se apaga, etc). Por este motivo las empresas desarrolladoras de software gastan gran cantidad de recursos (hasta el 50%) en pruebas de software que permitan asegurar con una alta probabilidad que no se han cometido errores.

 

La cifra se puede elevar aún más en el caso del desarrollo de software crítico, como el que controla centrales nucleares, vehículos espaciales, aviones, instrumentación médica o sistemas financieros, entre otros. Son muchas las historias de defectos en el software que provocaron populares fracasos, como el fallo en el lanzamiento del Ariane 5 en 1996 que provocó su autodestrucción a los 40 segundos del despegue.

Pero, ¿por qué es tan difícil encontrar los defectos de los programas? La gestación de grandes aplicaciones informáticas es compleja, requiere un gran esfuerzo intelectual e involucra a una gran cantidad de personas que deben ponerse de acuerdo en la forma en que se va a desarrollar el sistema. Componentes software desarrollados por distintas personas (que posiblemente no se conozcan) deben funcionar de forma cooperativa a la perfección. La probabilidad de cometer errores es muy alta.

 

Muchos de estos defectos se descubren durante el desarrollo y otros tantos en la fase de pruebas, pero aún así el software llega a manos de los usuarios finales con defectos sutiles que no han sido detectados en las pruebas. Es posible imaginar un sistema software como un gran pajar en el que se esconden algunas agujas que nadie ha visto por ser demasiado pequeñas y que, en el momento menos esperado, se clavan en uno de los usuarios finales. Es en este gran pajar que constituye el sistema software donde las hormigas tienen algo que aportar para descubrir las agujas.

Existen especies de hormigas que al caminar depositan una sustancia química, denominada feromona, que sirve de guía a otras hormigas y que se va evaporando con el paso del tiempo. El comportamiento de estas hormigas es relativamente simple. Si una hormiga encuentra rastros de feromona en el suelo los sigue, en caso contrario avanza de manera más o menos aleatoria o guiada por otros estímulos, como puede ser la presencia de comida. En el caso en que una hormiga encuentre varios rastros de feromona, normalmente seguirá con mayor probabilidad aquel en el que la cantidad de feromona es mayor.

 

Este comportamiento simple en apariencia da lugar a una propiedad emergente en las colonias de hormigas: son capaces de encontrar el camino más corto de su nido a la comida. La razón es que las hormigas que sigan el camino más corto tardarán menos tiempo en hacer el recorrido del nido a la fuente de comida, aumentando de esta manera la densidad de feromona en dicho camino. Este aumento de feromona invitará al resto del grupo a seguir el camino más corto, lo cual tendrá como efecto el incremento aún más rápido de la densidad de esta sustancia química en dicho camino.

El comportamiento de las hormigas ha servido de inspiración para crear algoritmos basados en colonias de hormigas (en inglés Ant Colony Optimization, ACO) capaces de resolver en un ordenador problemas relacionados con la búsqueda del camino más corto entre dos puntos.

 

Dentro del Grupo de Ingeniería del Software de la Universidad de Málaga (GISUM) se han utilizado estos algoritmos para buscar la secuencia de pasos más corta que hace que un programa falle. Las hormigas artificiales, es decir, los agentes que simulan a una hormiga real en el ordenador, deben buscar el error como si fuera la comida, guiadas por feromonas artificiales y por información adicional que el propio programa proporciona para ayudarlas a llegar a su objetivo.

Los resultados obtenidos sobre un gran conjunto de programas muestran que las hormigas artificiales son capaces de encontrar los defectos en el software con mayor eficacia y usando menos recursos (memoria y tiempo) que otras técnicas diseñadas para la misma labor, ahorrando así recursos de los proyectos software sin reducir, sino más bien aumentando, la fiabilidad del producto final.

 

Entre los programas que han sido testados con esta técnica se encuentran protocolos de comunicaciones, algoritmos distribuidos y software de ascensores. El uso de estas técnicas en el tejido industrial puede suponer un ahorro importante a las empresas de desarrollo software. En el futuro los investigadores pretenden ser capaz no solo de descubrir los defectos que existen, sino también de asegurar con certeza que no queda ninguno.

 

Más información: uciencia.uma.es/


Share

Últimas publicaciones

Descubre organizará más de 300 Cafés con Ciencia en Andalucía en los próximos 12 meses para acercar la investigación a la ciudadanía
Andalucía | 26 de julio de 2024

En su 15ª edición, esta actividad de divulgación científica contará con encuentros sobre salud mental, Cafés dedicados al colectivo LGTBI y un Café con Ciencia para conmemorar el Año Cajal dedicado a Ramón y Cajal. La organización de los Cafés con Ciencia se puede solicitar por correo electrónico cafeconciencia@fundaciondescubre.es hasta el 15 mayo de 2025.

Sigue leyendo
Patentan pastillas de soja biodegradables para el abono controlado de cultivos
Huelva, Sevilla | 25 de julio de 2024

Un equipo de investigación de las universidades de Sevilla y Huelva ha creado unas tabletas a partir de proteínas de soja que liberan progresivamente nutrientes a las plantas. El nuevo producto permite un crecimiento saludable, optimiza la producción agrícola y evita la contaminación de suelos y aguas subterráneas.

Sigue leyendo
Muestran la escasa importancia del mosquito tigre en la transmisión de la malaria aviar
Sevilla | 25 de julio de 2024

El equipo científico, formado por expertos de la Estación Biológica de Doñana (EBD-CSIC), del Consejo Superior de Investigaciones Científicas (CSIC); la Universidad de Granada y el Nature Research Centre de Lituania ha analizado el papel de este díptero como vector de patógenos de la malaria aviar. El estudio apunta a la preferencia del mosquito tigre por alimentarse de mamíferos como una de las posibles causas de la baja relevancia en la dispersión de la enfermedad.

Sigue leyendo

#CienciaDirecta

Tu fuente de noticias sobre ciencia andaluza

Más información Suscríbete

Ir al contenido