- Fortran
-
Fortran Basisdaten Paradigmen: prozedural, imperativ, strukturiert, objektorientiert Erscheinungsjahr: 1957 Entwickler: John W. Backus, IBM Aktuelle Version: Fortran 2008 (ISO/IEC 1539-1:2010) (2010) Typisierung: statisch, stark wichtige Implementierungen: GNU Fortran, g95, Open Watcom, XL Fortran, Intel und andere Beeinflusste: Algol 58, PL/I, BASIC Fortran ist eine prozedurale und in ihrer neuesten Version zusätzlich eine objektorientierte Programmiersprache, die insbesondere für numerische Berechnungen eingesetzt wird. Der Name entstand aus FORmula TRANslation und wurde bis zur Version FORTRAN 77 mit Großbuchstaben geschrieben.
Inhaltsverzeichnis
Geschichte
Fortran gilt als die erste jemals tatsächlich realisierte höhere Programmiersprache. Sie geht zurück auf einen Vorschlag, den John W. Backus, Programmierer bei IBM, 1953 seinen Vorgesetzten unterbreitete.
Dem Entwurf der Sprache folgte die Entwicklung eines Compilers durch ein IBM-Team unter Leitung von John W. Backus. Das Projekt begann 1954 und war ursprünglich auf sechs Monate ausgelegt. Tatsächlich konnte Harlan Herrick, der Erfinder der später heftig kritisierten Goto-Anweisung, am 20. September 1954 das erste Fortran-Programm ausführen. Doch erst 1957 wurde der Compiler für marktreif befunden und mit jedem IBM-704-System ausgeliefert. Backus hatte darauf bestanden, den Compiler von Anfang an mit der Fähigkeit zu Optimierungen auszustatten: Er sah voraus, dass sich Fortran nur dann durchsetzen würde, wenn ähnliche Ausführungsgeschwindigkeiten wie mit bisherigen Assembler-Programmen erzielt würden.
Versionen
Fortran wurde mehrmals erweitert. Viele neue Sprachelemente wurden zunächst von einem einzelnen Hersteller eingeführt und später in den internationalen Standard übernommen. Als Versionen folgten aufeinander FORTRAN I, FORTRAN II, FORTRAN IV, FORTRAN-66, FORTRAN-77, Fortran 90, Fortran 95, Fortran 2000, Fortran 2003, Fortran 2008 und zuletzt Fortran 2010. Ab FORTRAN-66 ist Fortran durch die ISO standardisiert. Die Fortschreibung der Standards ist ein komplizierter Prozess, der oft wesentlich länger dauert als zunächst angestrebt: Der Nachfolger des 1978 erschienenen Standards FORTRAN-77, der als Fortran 8x bezeichnet wurde, war ursprünglich für das Jahr 1982 geplant, später dann für das Jahr 1985, und wurde schließlich unter der Bezeichnung Fortran90 erst am 11. April 1991 als neuer Standard und Nachfolger von FORTRAN-77 angenommen.[1]
Im Laufe dieser Erweiterungen wurden zahlreiche Sprachelemente aus später entstandenen Programmiersprachen übernommen. Beruhte früher Fortran-Stil noch ganz auf Goto-Anweisungen, kann man seit FORTRAN 77 uneingeschränkt strukturiert programmieren. Mit Fortran 90 wurde neben dem aus der Lochkartenzeit stammenden festen Zeilenformat ein von späteren Programmiersprachen verwendetes freieres Format erlaubt. Ab Fortran 90 werden interessante Elemente eingeführt, die auch beispielsweise in Ada vorhanden sind, beispielsweise optionale Parameter und die Möglichkeit, Prozedurparameter nicht nur über die Position in der Parameterliste zu identifizieren, sondern auch über ihren Namen. Seit Fortran 2003 werden auch polymorphe Datentypen und Vererbung unterstützt, so dass man objektorientiert programmieren kann. Und seit Fortran 2008 ist mit Coarray Fortran eine Parallelisierung in die Sprache eingebaut, die dem PGAS-Schema folgt.
Beispiel:
SUBROUTINE test( Argument1, Argument2, Argument3 ) REAL, INTENT(IN) :: Argument1 CHARACTER(LEN= *), INTENT(IN) :: Argument2 INTEGER, INTENT(IN), OPTIONAL :: Argument3 ! Hier was sinnvolles. END SUBROUTINE
Mögliche Aufrufe sind dann z. B.:
CALL test( 1.0, 'Tach' ) CALL test( Argument1= 1.0, Argument2= 'Tach auch' ) CALL test( Argument2= 'Tach Auch', Argument1= 1.0 ) CALL test( Argument3= 3, Argument1= 1.0, Argument2= 'Tach auch' )
Während beim ersten Aufruf die Parameterassoziation über die Reihenfolge der Parameter erfolgt, so werden bei den anderen Beispielen die Parameter mittels der Namen identifiziert. Bei letzteren spielt die Reihenfolge dann keine Rolle mehr.
Varianten
Einige von Fortran abgeleitete Programmiersprachen sind Ratfor, F und HPF (High Performance Fortran).
Eigenschaften
Fortran war und ist für numerische Berechnungen vorgesehen und optimiert. Von Anfang an hatte Fortran den Potenz-Operator
**
– der in vielen anderen Hochsprachen nicht vorhanden ist – und einen Datentyp für komplexe Zahlen. Mit Fortran 90 wurden Vektor- und Matrix-Operationen standardisiert.Ein Fortran-Programm kann leichter optimiert werden als beispielsweise ein C-Programm, da Fortran restriktiver ist. Beispielsweise ist es nicht erlaubt, innerhalb einer Iterationsschleife die Iterationsvariable zu verändern. Unter anderem ist deshalb beim Eintritt in die Schleife die Maximalzahl der Durchläufe bekannt.
! iFunc() sei eine Funktion, die einen INTEGER-Wert berechnet. ! Der Compiler muss nur einen Aufruf von iFunc erzeugen. DO i = 1, iFunc(4711) !.. sinnvolles hier. ! Innerhalb dieser Schleife darf i nicht verändert werden. ENDDO
In C sieht eine solche Iteration so aus:
for (i = 1; i <= iFunc(4711); i++) { /* Sinnvolles hier */ /* Es ist hier erlaubt, i zu verändern */ }
Die for-Schleife in C ist keine einfache Zählschleife wie in Fortran. Das zweite Argument (hier
i <= iFunc(4711)
) ist ein logischer Ausdruck. Die Schleife läuft, solange dieser Ausdruck wahr ist. Andererseits kann deshalb dort nicht einfach der maximale Wert als Funktionsergebnis stehen, da nicht sichergestellt werden kann, dass iFunc keine Nebenwirkungen hat, ungeachtet dessen, dass es stets das gleiche Ergebnis für 4711 liefert.Insbesondere für wissenschaftliche und numerische Berechnungen gibt es in FORTRAN umfangreiche Bibliotheken, die immer noch weit verbreitet sind, auch wenn eine zunehmende Menge an Funktionalität inzwischen nach C und C++ portiert wurde.
Implizite Variablendeklaration
In Anlehnung an mathematischen Notationsgebrauch sind Variablen in Fortran standardmäßig über ihren Anfangsbuchstaben deklariert: Bezeichner, die mit einem der Buchstaben i, j, k, l, m, n beginnen, stehen für eine INTEGER-Variable oder einen INTEGER-Funktionswert, alle übrigen Bezeichner stehen für REAL-Werte. Diese impliziten Typenvereinbarung von Variablen kann durch die Deklaration einzelner Variablen überschrieben werden, sie kann durch eine Zeile wie
! Alle nichtdeklarierten Bezeichner, deren erster Buchstabe c oder z ist, bezeichnen komplexe Zahlen. IMPLICIT COMPLEX (c, z)
verändert werden, und die implizite Vereinbarung kann durch den Befehl
IMPLICIT NONE
ganz aufgehoben werden. In diesem Fall löst die Verwendung eines nichtdeklarierten Bezeichners einen Fehler während der Übersetzung aus. Dadurch vereinfacht sich die Fehlersuche erheblich.
Übergabe von Parametern
In alten Versionen von Fortran (FORTRAN 77 und früher) brauchten Unterprogramme vor ihrer Verwendung nicht deklariert zu werden. Es konnte durch eine Deklaration allenfalls der Typ des Rückgabewerts festgelegt werden. Der Compiler überprüfte normalerweise nicht, ob ein Unterprogrammaufruf mit typrichtigen Parametern erfolgt. Die Übergabe von Parametern an Unterprogramme (SUBROUTINE oder FUNCTION) erfolgt üblicherweise per Adresse. Vor Fortran-90 konnten grundsätzlich alle Aktualparameter von einer SUBROUTINE oder FUNCTION verändert werden. Deshalb müssen alle Parameter z. B. durch Adressübergabe übergeben werden. Eine automatische Typumwandlung kann deshalb auch nicht stattfinden.
Die meisten Fortran-Systeme führen auch keine Typüberprüfung zur Laufzeit durch.
Das ist eine häufige Fehlerquelle. Programmbeispiel 1:
... CALL DruckeZahl(3.14) ... SUBROUTINE DruckeZahl(meineZahl) ...
Im Unterprogramm DruckeZahl ist meineZahl, weil mit m beginnend, implizit als INTEGER deklariert. Zur Laufzeit erfolgt ein Aufruf mit dem REAL Argument 3.14. Dann wird die INTEGER-Variable meineZahl mit den Bits der Gleitkommadarstellung von 3.14 aufgefüllt – was auf beliebig abwegige numerische Ergebnisse führt.
Viele Fortran-Compiler übergeben Parameter per Referenz. Das führt zu teilweise amüsanten Ergebnissen, beispielsweise folgendes Programmbeispiel 2:
call bar(3) print *,3 end subroutine bar(i) i = 42 end
Dieses würde bei manchen Compilern die Zahl 42 ausgeben. Das Programm ist allerdings so nicht korrekt.
Programmierwerkzeuge wie ftnchek ermöglichen allerdings eine separate Prüfung der Übereinstimmung von Argumentlisten und würden in diesen Fällen warnen.
In Fortran 90 und nachfolgenden Versionen besteht die Möglichkeit, die Parametertypen der Unterprogramme anhand von Schnittstellen (INTERFACE) und Modulen (MODULE) zu definieren. Der Compiler kann somit überprüfen, ob der übergebene Parametertyp und der erwartete Typ übereinstimmen. Diese Bekanntgabe ist allerdings nicht zwingend, wie das in anderen Programmiersprachen – beispielsweise Ada – der Fall ist. Die von Fortran-95 abgeleitete Programmiersprache F erzwingt dieses, in F sind nur Aufrufe von Unterprogrammen erlaubt, deren Parameterliste beispielsweise durch USE-Anweisungen bekannt gemacht sind. In einem Unterprogramm kann auch festgelegt werden, ob ein Parameter Eingabeparameter (INTENT(IN)), Ausgabeparameter (INTENT(OUT)) oder beides (INTENT(INOUT)) ist. In Fortran 90 deklariert man das Unterprogramm bar folgendermaßen:
subroutine bar(i) integer, intent(in):: i [...] end subroutine
Falls das Unterprogramm versuchen sollte, den Wert des Aktualparameter i zu verändern, würde der Compiler einen Fehler anzeigen.
Dynamische Speicherallokation
Unter dynamischer Speicherallokation versteht man die Möglichkeit, Speicher (insbesondere für Felder wie z. B. für Matrizen) erst zur Laufzeit des Programms anzufordern, das heißt, dass die Größe von Arrays nicht bereits zum Zeitpunkt des Übersetzen des Programms festgelegt zu sein braucht. Bis Fortran 77 ist eine dynamische Speicherallokation nicht oder nur über nicht standardisierte Erweiterungen der Compilerhersteller möglich. Ab Fortran 90 ist die dynamische Speicherverwaltung im Sprachstandard enthalten.
Ein Beispiel für dynamische Speicherreservierung: Anlegen und Bearbeiten einer verketteten Liste:
TYPE tElement TYPE (tElement), POINTER :: Naechstes REAL :: Datum END TYPE tElement TYPE (tElement), POINTER, SAVE :: Liste=> NULL() ! -- NULL(): Fortran-95 TYPE (tElement), POINTER :: Element ! Anlegen eines Elements und Eintragen am Anfang der Liste ALLOCATE( Element ) Element% Datum = 4711.0 Element% Naechstes=> Liste Liste=> Element ! Durchlaufen der Liste: Element=> Liste DO WHILE (ASSOCIATED(Element)) CALL Bearbeiten( Element% Datum ) Element=> Element% Naechstes ENDDO
Compiler
Fortran-Compiler gibt es für praktisch alle Computer, von Arbeitsplatzrechnern bis zu Supercomputern.
Proprietäre Software
Kommerzielle Anbieter von Fortran-Compilern sind entweder Computerhersteller wie z. B. IBM, SUN, HP, Intel oder aber spezialisierte Softwarehersteller wie z. B. Absoft, PGI, NAG, Lahey, Salford. Reine F77-Compiler werden heute zumeist nicht mehr hergestellt, da Fortran77 fast vollständig im Sprachstandard Fortran95 enthalten ist (nur DO-Schleifen mit REAL-Iterationsvariablen und Hollerith-Edit-Deskriptoren sind in Fortran95 und später verschwunden).
Einige der oben genannten Compiler sind für Privatanwender bzw. nichtkommerzielle Nutzung unentgeltlich, zum Beispiel die Linux-Variante des Intel-Fortran-Compilers (aktuelle Version 11), Sun Studio Express (mit Fortran, C und C++ Compilern für Linux und Solaris), für Microsoft Windows der Compiler von Salford oder DEC Fortran für OpenVMS.
Freie Software
Seit Version 4.0 enthält die praktisch für alle Plattformen verfügbare GNU Compiler Collection (GCC) einen Compiler für Fortran 95 (GNU Fortran). Ältere Versionen von GCC enthalten noch den FORTRAN-77-Compiler g77. Außerdem existiert mit G95 ein weiterer freier Compiler für Fortran 95. Aus diesem ging 2003 gfortran hervor.
Auch die OpenWatcom-Entwicklersuite verfügt über einen FORTRAN-77-Compiler.
Transcompiler
Es gibt Transcompiler, wie z. B. f2c, zur automatischen Übersetzung von Fortran-77 in (allerdings kaum lesbares) C. Auch der NAG-Compiler verwendet als Zwischensprache C; allerdings ist die nötige Laufzeitbibliothek nicht im Quelltext zu bekommen.
Sprachunterstützung
Während die meisten Compiler den Fortran95 Standard voll unterstützen, variiert dies im Falle der Sprachstandards Fortran2003 und Fortran2008 zum Teil noch erheblich (Stand August 2010). Die meisten Compiler unterstützen jedoch bereits entweder weite Teile des Standards Fortran2003, oder im Falle von Cray und IBM den Standard praktisch vollständig.[2]
Literatur zur Geschichte von Fortran
- Annals of History of Computing, 6, 1, Jan. 1984.
- S. Rosen (Hrsg.): Programming Systems and Languages, McGraw Hill, 1967.
- R. L. Wexelblat (Hrsg.): History of Programmining Languages., Academic Press, 1981, S. 25–74.
Literatur zu Fortran
- Michael Metcalf, John Reid, Malcolm Cohen: Fortran 95/2003 Explained, Oxford University Press, 2004, ISBN 0-19-852693-8
- Stephen J. Chapman: Fortran 90/95 for Scientists and Engineers - 2nd edition, McGraw Hill, 2004, ISBN 0-07-123233-8 (International Edition)
- Thomas Kühme, Peter Witschital: Die FORTRAN-Fibel: Strukturierte Programmierung mit FORTRAN 77, Lehr- und Arbeitsbuch für Anfänger, Oldenbourg, 1991, ISBN 978-3-486-22016-2
- Günter Schmitt: Fortran-90-Kurs – technisch orientiert: Einführung in die Programmierung mit Fortran 90, Oldenbourg Verlag, 1996, ISBN 978-3-486-23896-9
- William H. Press, Saul A. Teukolsky, William T. Vetterling, Brian P. Flannery: Numerical Recipes in FORTRAN 77: The Art of Scientific Computing - Volume 1 of Fortran Numerical Recipes - 2nd Edition, Cambridge University Press, 1992 (zweite Edition), 2003 (Reprint mit Korrekturen), ISBN 0-521-43064-X
- William H. Press, Saul A. Teukolsky, William T. Vetterling, Brian P. Flannery: Numerical Recipes in Fortran 90: The Art of Parallel Scientific Computing - Volume 2 of Fortran Numerical Recipes - 2nd Edition, Cambridge University Press, 1996 (erste Auflage), 1999 (Reprint mit Korrekturen), ISBN 0-521-57439-0
Weblinks
-
Wikibooks: Fortran – Lern- und Lehrmaterialien
- Fortran.de Links und Informationen
- Fortran Standards Linksammlung auf der GNU-Fortran-Seite
- Fortran Store Umfangreiche Informationen inkl. Historischem und Standards (engl.)
- Einführung in Fortran90/95
- Einführung in Fortran90/95
Referenzen
- ↑ Vorwort von Michael Metcalf in: W. H. Press, S. A. Teukolsky, W. T. Vetterling, B. P. Flannery: Numerical Recipes in Fortran 90. Cambridge University Press, 1999, ISBN 0-521-57439-0.
- ↑ Ian D. Chivers, Jane Sleightholme, Compiler support for the Fortran 2003 standard, ACM SIGPLAN Fortran Forum 29, 2 (2009).
Wikimedia Foundation.