Geschwindigkeit Fortran und Java

Status
Nicht offen für weitere Antworten.
O

Osix2000

Gast
Hallo,

Eine Frage, was meint ihr zum Vergleich Fortran und Java....

Macht es Sinn eine naturwissenschaftliche Berechnung in Fortran nach Java umzuschreiben ?

Ja, klar, ich weiß, daß man das nicht so pauschal beantworten kann.

Es geht halt, um ein dreidimensionales Feld mit einigen hunderttausend Zellen, die bearbeitet werden müssen.

Das Fortran Programm ist "gewachsen" und recht chaotisch...

Aber dennoch: Ich erinnere mich ans Studium wo es hieß, das Fortran zwar veraltet, aber eine sehr effiziente Sprache sei, und superschnell bei Berechnungen, weil der Code sehr Assembler nah ist.

Kann Java nicht einschätzen, wie schell das ist bei Rechenoperationen und natürlich auch schleifen und if abfragen...

Ob ich da viel mit Objekten machen kann ist schwierig, ich würde das eher fast "prozedural" nachprogrammieren...

Hat jemand eine Idee, oder weiß was dazu ?
 

Marco13

Top Contributor
Sumbjektiv-Unfundiertes Gelaber:

Schneller wird es dadurch vermutlich erstmal nicht. Ob es "Sinn macht", kann man schwer sagen - zumindest wäre so ein Umschreiben ja vielleicht ein Anlaß, das ganze neu zu strukturieren und zu optimieren, so dass eventuelle Vorteile durch den "besseren" Code entstehen. Aber es "so-wie-es-ist" einfach stupide runter-abzutippen, und jedes Fortran-Statement 1:1 in ein Java-Statement zu übersetzen ... höm. Würde ich mir wohl nicht antun ....
 
O

osix2000

Gast
mit "nachprogrammieren" meinte ich ja nicht EXAKT, jede zeile nachprogrammieren...für alle 13-jährigen muß ich das noch dazusagen :)

Sondern schon zu schauen, wo man was effizienter gestalten kann, aber alle subroutinen zu übernehmen...
 
M

maki

Gast
aber alle subroutinen zu übernehmen...
Seit wann gibt es in Java "subroutinen"?

So wie sich das anhört, versuchst du dann wirklich die prozedurale Struktur von Fortran in Java abzubilden, und dass geht schief, immer.

Also: Entweder komplett neu aufsetzen und ein OO Konzept entwerfen, das die festgestellten Anforderungen erfüllt, oder ganz bleiben lassen.

Performance wird ja wohl kaum ein Kriterium für eine Portierung sein, oder?
Meist will man damit etwas altes neu strukturieren.
 

Marco13

Top Contributor
Nun. Man kann auch in Java prozedural programmieren. Ob man das nun "subroutine" oder "private static final synchronized void"-Methode nennt ist wurscht. Was daran "schief gehen" soll ist mir nicht ganz klar. Man kann natürlich alles 1:1 übernehmen, oder bestimmte Dinge anders strukturieren. Wenn es reines Numbercrunching ist, wird Fortran erstmal sicher schneller sein. Wenn das, was dort berechnet wird, sich irgendwie in ein sinnvolles Obektorientieres Konzept packen läßt (d.h. OHNE Klassen wie "ComputationInput" und "ComputationOutput"), wäre eine Portierung vielleicht nicht verkehrt, weil schönerer, wartbarerer Code dabei entsteht. Was besser ist (oder wie groß die Vor/Nachteile sind) kann man so erstmal nicht sagen.

Übrigens fände ich es ziemlich blöd, jedes Jahr meinen Nicknamen ändern zu müssen.
 
M

maki

Gast
Marco,

wenn du mal "Java" Code liest, der von Leuten geschrieben wurde die nix mit OO am Hut haben und die dachten, man könne das wie in C++ machen, also einfach C schreiben, wirst du wissen was ich meine ;)

Unwartbar, unverständlich, nur sehr schwer falls überhaupt zu verändern... das meine ich mit schiefgehen.

Das man bei diesen dünnen Fakten gar keine Aussage machen kann was schneller ist, ist klar.

Nebenbei bemerkt wird "Performance" von vielen Leuten in ihrer Wichtigkeit überschätzt ;)
 

Marco13

Top Contributor
Jo. Wenn man objektorientiert programmiert, dann verwendet man Klassen. Umgekehrt gilt die Implikation NICHT. Das ist mir klar. Aber da man nicht weiß, worum es geht, ist nich klar, inwiefern eine Umstrukturierung möglich, gewünscht oder sinnvoll ist....
 

nebulo

Bekanntes Mitglied
Ich denke auch es macht keinen großen Sinn, dass Programm prozedural auf Java zu portieren. Wenn dann sollte man die Anforderungen aus dem Fortran-Programm ableiten und ein Objektorientiertes Design entwerfen. Das ist ein großer Aufwand der sich nur lohnt wenn das Programm weiter gewartet und erweitert werden soll. Dabei sollte dann falls nicht vorhanden eine genaue Spezifikation und ein programmiersprachenunabhäniger Entwurf erstellt werden.

Ich gebe maki im übrigen Recht das sehr häufig Performanz überschätzt wird und dagegen Wartbarkeit (Portabilität, Änderbarkeit, und auch Prüfbarkeit) und Bedienbarkeit oft unterschätzt werden.
 
O

Osix2000

Gast
Es geht aber hier um wissenschaftliche Rechnungen.... "Numbercrunching" ja, einige dreidimensonalen Felder (100 x 100 x 100) an denen was berechnet werden soll... da wird differnziert, integriert und noch andere mathematische Operationen verwendet... Vektor-Faltungen, die in Subroutinen ausgelagert sind.

Da läßt sich nicht so einfach ein sauberes Objektmodell entwerfen...
Andererseits kann man mit der Komfortabilität von Java einiges eleganter machen als in Fortran, und ich frage mich
halt, wie effizient das wird.

Wir würden es ja in Fortran lassen, aber es soll eine webfähige Anwendung werden...
Da bleiben zwei Möglichkeiten.... Ein Wrapperframework drumrumstricken (Es sind mehrere einzelne Fortranprogramme, die sich ganz altmodisch über ASCII-Dateien austauschen) oder die einzelnen Programme gleich in Java neu schreiben.

Geschwindigkeit ist ebenfalls höchste Priorität, deshalb meine Frage...

@marco: Soso, dann bist Du also 1913 geboren :) Auch nicht schlecht. Ein 94-jähriger der Java programmiert... :)
 
S

SlaterB

Gast
fang doch klein an, suche dir eine abgeschlosse Teil-Operation von 100 Zeilen
und lasse die in Fortran + Java 1 Mio. durchlaufen um einen ganz groben Eindruck zu erhalten
 

Marco13

Top Contributor
Hm. Eine Matrix (bzw. ein Tensor) ist ein Objekt. Aber sowas selbst schreiben macht keinen Sinn. Dazu sollte man eher mal auf
http://math.nist.gov/javanumerics/
unter "Libraries" schauen. Dort ist übrigens auch ein Link zu einen Fortran-2-Java-Übersetzer
http://icl.cs.utk.edu/f2j/
Bei solchen automatischen Übersetungen sollte man kritisch sein, aber vielleicht hilft es, schnell und leicht einen Eindruck von der möglichen Performance zu bekommen...

EDIT: Nyehe... die FAQ dazu ist ja geil:
http://icl.cs.utk.edu/f2j/faq/index.html
:lol:
 
H

Hurga38

Gast
Ich hab den Transpiler f2j mal angelesen.

Ich verstehe aber nicht so recht, ob der alles in Fortran übersetzt oder nur die BLAS LAPACK Sachen....

Hat jemand noch einen anderen Transpiler von Fortran nach Java ?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Input/Output Programm zum Auslesen/Beschreiben von Textdateien, wie Geschwindigkeit erhöhen? Allgemeine Java-Themen 18
T Geschwindigkeit beim Generieren erhöhen? Allgemeine Java-Themen 7
S Geschwindigkeit HashMap oder .getParent Allgemeine Java-Themen 5
byte JMockit - Geschwindigkeit Allgemeine Java-Themen 7
B Verzeichnis durchsuchen geschwindigkeit optimieren Allgemeine Java-Themen 6
R Parser: Datei auslesen, Datei erstellen - Geschwindigkeit Allgemeine Java-Themen 16
G java spiel (geschwindigkeit) Allgemeine Java-Themen 37
F Geschwindigkeit messen Allgemeine Java-Themen 7
E Geschwindigkeit static Allgemeine Java-Themen 6
O RXTX Geschwindigkeit? Codebeispiel dabei. Allgemeine Java-Themen 21
P Geschwindigkeit von Java GUIs Allgemeine Java-Themen 45
J Http/Https Geschwindigkeit Allgemeine Java-Themen 14
B java geschwindigkeit Allgemeine Java-Themen 16
J JCopy & Geschwindigkeit? Allgemeine Java-Themen 4
A Geschwindigkeit Java unter Linux Allgemeine Java-Themen 9
M Geschwindigkeit RXTX JAVA Allgemeine Java-Themen 3
N Performance-Test (Geschwindigkeit von Methoden vergleichen)? Allgemeine Java-Themen 4
P Geschwindigkeit und Genauigkeit bei Zeitmessung Allgemeine Java-Themen 13
T Geschwindigkeit bei Polygonen und BufferedImage Allgemeine Java-Themen 9
R Geschwindigkeit herausfinden Allgemeine Java-Themen 2
E JNA:Zugriff auf Common-Block von Fortran bzw. Struct in C Allgemeine Java-Themen 2
S Fortran Funktion mit JNI aufrufen: java.lang.UnsatisfiedLink Allgemeine Java-Themen 2
G Fortran nach Java mit f2j Allgemeine Java-Themen 13
J fortran exe über java ausführen Allgemeine Java-Themen 4
OnDemand Java Deployment Vaadin Allgemeine Java-Themen 3
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 0
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
Mick P. F. Wie kriege ich die Fehlermeldung "java: symbol lookup error: ..." weg? Allgemeine Java-Themen 11
K Nachhilfe Java Allgemeine Java-Themen 11
KonradN Java 19 Allgemeine Java-Themen 11
F IDEA IntelliJ Java Songliste erstellen Allgemeine Java-Themen 6
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
E Java und integrierte Grafikkarten Allgemeine Java-Themen 18
Sachinbhatt Wie wird die Typumwandlung bei Mehrfachvererbung in Java implementiert? Allgemeine Java-Themen 3
Peterw73 Hilfe bei Java gesucht Allgemeine Java-Themen 3
A Java unter Win 10 Allgemeine Java-Themen 1
B Woher kommen die Bildschirmkoordinaten beim java Robot? Allgemeine Java-Themen 14
P9cman java.Lang Klassen fehlen in JRE System Library Allgemeine Java-Themen 1
T Java Robot Class - Bot Allgemeine Java-Themen 3
E Wie Java Heap Space vergrößern? Allgemeine Java-Themen 3
B Java Programm auf virutellem Desktop laufen lassen? Allgemeine Java-Themen 1
D VBA Code mit Java ausführen möglich? Allgemeine Java-Themen 10

Ähnliche Java Themen

Neue Themen


Oben