En la actualidad tenemos a nuestra disposición una gran variedad de software de cálculo numérico. Tenemos software libre (Octave, FreeMat, Scilab, Sage, Maxima, …), software comercial (Mathematica, Maple, MATLAB, …) y un número casi indeterminado de librerías de funciones numéricas (listado), pero es evidente que las hojas de cálculo están ganando la partida, básicamente por su comodidad y facilidad de uso.
Actualmente, es Excel quien domina el mercado, por desgracia no se diseñó pensando en cálculos de ingeniería, precisamente, y tiene grandes carencias en cuanto a funciones para análisis numérico, resueltas sólo en parte con el paquete de macros SOLVER, muy útil, si, pero no siempre válido.
Es decir, que si queremos tantear resultados o resolver ecuaciones no lineales complicadas con Excel, las opciones disponibles son:
- Usar soluciones abiertas tipo XNUMBERS (ya descatalogada, por desgracia).
- Utilizar soluciones comerciales cerradas, tipo «caja negra».
- Programar las funciones por nuestra cuenta… 🙁
Bien, pues si todavía conservas rutinas escritas en Fortran y quieres «llamarlas» desde Excel sin tener que «traducirlas» a VBA, en Newton Excel Bach, Not (Just) An Excel Blog explican cómo hacerlo en dos partes (1ª y 2ª).
El proceso consiste, básicamente, en crear una librería DLL compatible mediante el compilador Silverfrost Personal Fortran 95 (libre para uso personal), y definir después las funciones en VBA. Una vez hecho esto, se pueden usar las funciones de la librería DLL como si se tratara de las típicas funciones de Excel.
Es una lástima no haber encontrado antes este enlace (es de diciembre de 2008), porque ya tengo casi todos mis antiguos programas «reconvertidos» a VBA, pero puede ser un buen método para «resucitar» los listados en Fortran que aparecen en libros de geotecnia y mecánica de suelos de hace ya unos años.
En cuanto a la proverbial rapidez de Fortran, en el blog hacen un comentario al respecto también, pero en esta interesante presentación [pdf – 1,90 MB] sobre modelos constitutivos del Grupo de Investigación en Geotecnia de la Universidad de los Andes, en Colombia, se cita un texto en el que se afirma que, para determinados cálculos, 10 segundos de Fortran son equivalentes a 80 horas de Visual Basic… no está mal para un lenguaje de 1957.