|
Das deutsche QBasic- und FreeBASIC-Forum Für euch erreichbar unter qb-forum.de, fb-forum.de und freebasic-forum.de!
|
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen |
Autor |
Nachricht |
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 16.09.2017, 15:08 Titel: Die schnellste Programmiersprache |
|
|
Vielleicht finde ich hier Gleichgesinnte. Mich würde es interessieren, wie schnell die verschiedenen Sprachen sind. Natürlich ist ein Vergleich nicht einfach. Habe im Web auch nicht genau das gefunden was ich suchte. Das hier ist schon ähnlich, doch nur mit Strings, darum schneidet Perl so gut ab:
https://raid6.com.au/~onlyjob/posts/arena/
Doch so ähnlich könnte man es aufbauen. Ein Testprogramm, das die wichtigsten Operationen in Schleifen misst, das dann in alle Sprachen übersetzt werden könnte, wie am Ende des Links gezeigt. Dieses Testprogramm sollte möglichst einfach sein, damit es leicht übersetzt werden kann.
Die erzeugten .exe-Dateien könnten dann die benötigte Zeit ausgeben und auf einem Referenzrechner gestartet werden. Dann werden alle Werte in ein Koordinatensystem eingetragen und wir haben einen Vergleich. |
|
Nach oben |
|
|
grindstone
Anmeldungsdatum: 03.10.2010 Beiträge: 1237 Wohnort: Ruhrpott
|
Verfasst am: 16.09.2017, 17:13 Titel: |
|
|
Es würde mich sehr wundern, wenn das nicht irgend jemand schon eingehend untersucht hätte...
Gruß
grindstone _________________ For ein halbes Jahr wuste ich nich mahl wie man Proggramira schreibt. Jetzt bin ich einen!
Zuletzt bearbeitet von grindstone am 16.09.2017, 21:53, insgesamt einmal bearbeitet |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 16.09.2017, 17:25 Titel: |
|
|
Also, ich habe so schnell nichts gefunden im Web. Wo wäre denn so etwas zu finden? |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 16.09.2017, 20:47 Titel: |
|
|
Das Programm zum Test könnte etwa so aussehen, in einem spontanen ersten Entwurf:
Code: | ' Speedtest.bas ' Speed-Test für FreeBasic 1.05
Dim Shared As Double Start,Ende
Start = Timer
DIm Shared As Integer i,x,y,z,x1,y1,x2,y2
#Include "fbgfx.bi"
IF SCREENRES(1024,768,32)THEN
PRINT "Fehler: Grafikfenster konnte nicht initialisiert werden!"
SLEEP
END
END If
Color RGB(0, 0, 0), RGB(255, 255, 255)
Cls
randomize timer
' Kreise
For i = 0 To 100000
x=int(rnd*1024)
y=int(rnd*768)
z=int(rnd*768)
Circle(x,y),z,RGB(int(rnd*255),int(rnd*255),int(rnd*255)),,,,F
Next
' Rechtecke
For i = 0 To 100000
x1=int(rnd*1024)
y1=int(rnd*768)
x2=int(rnd*1024)
y2=int(rnd*768)
Line (x1,y1) - (x2,y2), _
RGB(int(rnd*255),int(rnd*255),int(rnd*255)),BF
Next
' Linien
For i = 0 To 100000
x1=int(rnd*1024)
y1=int(rnd*768)
x2=int(rnd*1024)
y2=int(rnd*768)
Line (x1,y1) - (x2,y2), _
RGB(int(rnd*255),int(rnd*255),int(rnd*255))
Next
' Zeichen
For i = 0 To 100000
Print chr(int(rnd*255));
Next
Ende=Timer-Start
Print:Print:Print:Print:Print:Print "Benoetigte Zeit:";Ende
Sleep
End
|
Verbesserungsvorschläge willkommen.
Zuletzt bearbeitet von Marc Bonus am 17.09.2017, 13:56, insgesamt 2-mal bearbeitet |
|
Nach oben |
|
|
nemored
Anmeldungsdatum: 22.02.2007 Beiträge: 4650 Wohnort: ~/
|
Verfasst am: 17.09.2017, 10:17 Titel: |
|
|
http://benchmarksgame.alioth.debian.org/
mit einem schönen Zitat:
Zitat: | Will your toy benchmark program be faster if you write it in a different programming language? It depends how you write it! |
Auf der Seite fällt auch (wenig überraschend) auf, dass verschiedene Sprachen in unterschiedlichen Bereichen ihre Stärken haben. Manche Programme, die in der einen Umsetzung nur wenige Sekunden brauchen, benötigen in einer anderen (ebenfalls insgesamt sehr schnellen) Sprache mehrere Minuten.
Eine Zeitmessung über deinen gesamten Programmcode halte ich daher nicht für sehr sinnvoll; wenn dann würde ich jede Anweisung(sschleife) für sich selbst messen. Außerdem habe ich bei den Forenbeiträgen die Erfahrung gemacht, dass die einen Benutzer berichten, Befehl X wäre bei ihnen deutlich schneller als Befehl Y, bei anderen war es genau anders herum. Auf jeden Fall dürfte auf dem Referenzrechner keinesfalls ein Multitasking-System laufen. _________________ Deine Chance beträgt 1:1000. Also musst du folgendes tun: Vergiss die 1000 und konzentriere dich auf die 1. |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 17.09.2017, 13:31 Titel: |
|
|
LOL, die Programme in dem Link sind schon rund zehnmal länger und komplizierter als meins...
Aber ernsthaft, ich denke mir mein Programm macht es bereits und es ist in kurzer Zeit in anderere Sprachen zu übersetzen, Es soll ja keine abendfüllende Angelegenheit werden. |
|
Nach oben |
|
|
nemored
Anmeldungsdatum: 22.02.2007 Beiträge: 4650 Wohnort: ~/
|
Verfasst am: 17.09.2017, 16:08 Titel: |
|
|
Nun, wie einfach es ist, mit Perl ein Grafikfenster einzurichten, weiß ich nicht - bei Scheme z. B. würde mir da von vornherein jeglicher Ansatz fehlen. Man kann natürlich Allegro nutzen, aber das ist ja dann eigentlich C. Für Perl würde mir als erstes GD einfallen (aber das ist auch wieder C). _________________ Deine Chance beträgt 1:1000. Also musst du folgendes tun: Vergiss die 1000 und konzentriere dich auf die 1. |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 17.09.2017, 16:50 Titel: |
|
|
Fürs Erste könnte man C, PureBasic und XProfan nehmen, das wären die Sprachen die ich installiert habe. |
|
Nach oben |
|
|
Jojo alter Rang
Anmeldungsdatum: 12.02.2005 Beiträge: 9736 Wohnort: Neben der Festplatte
|
Verfasst am: 17.09.2017, 17:20 Titel: |
|
|
Bei C hinge das Ganze dann schon wieder davon ab, welche Grafikbibliothek du verwendest, wenn du überhaupt eine nutzt, und auf welchem Wege die Grafik dann zum Betriebssystem gelangt, und am Ende kommt es natürlich auch bei allen Sprachen darauf an auf welchem Betriebssystem der Test durchgeführt wird. Generell kommt es häufig nicht auf die Sprache an, sondern auf die Abstraktionsebene, auf der man arbeitet - selbst dein FreeBASIC-Beispiel ließe sich schon dadurch beschleunigen, indem man LINE und CIRCLE durch eine eigene Implementierung ersetzt, die genau auf den getesteten Fall zugeschnitten ist (z.B. bei CIRCLE so implementieren, dass es keine beliebig verformten Ellipsen zulässt, Rechteck-Code in LINE optimieren, etc). Oder man ersetzt die FreeBASIC-Gfxlib durch was ganz anderes. Und schon ist FreeBASIC schneller als FreeBASIC. _________________ » Die Mathematik wurde geschaffen, um Probleme zu lösen, die es nicht gäbe, wenn die Mathematik nicht erschaffen worden wäre.
|
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 17.09.2017, 17:35 Titel: |
|
|
Es sollte mit "Bordmitteln" sein, also bei C dann wohl mit "graphics.h".
Natürlich kommt es bei der Geschwindigkeit auf den Rechner und sein Betriebssystem an, Da gäbe es zwei Möglichkeiten:
1. Alle kompilierten Programme werden auf einem Referenzrechner ausgeführt und verglichen.
2. Alle kompilierten Programme werden nach einem Schema benannt wie "Speedtest C.exe", Speedtest FB.exe" usw. und werden irgendwo zum Download gestellt, sodass jeder den Vergleich selber machen kann. |
|
Nach oben |
|
|
nemored
Anmeldungsdatum: 22.02.2007 Beiträge: 4650 Wohnort: ~/
|
Verfasst am: 17.09.2017, 18:44 Titel: |
|
|
Ich würde das ganz dann aber umbenennen von "Geschwindigkeitstest von Programmiersprachen" zu "Geschwindigkeitstest von Bibliotheken". Ansonsten ist nämlich alles, was (ausschließlich) in C geschrieben C-Boardmittel; und eine FB-Zeichenroutine mit direktem Speicherzugriff (ebenfalls Boardmittel) ist deutlich schneller als die Gfxlib (ganz einfach, weil man sich im Spezialfall die kostenaufwendigen, aber im Allgemeinen lebensrettenden Sicherheitsprüfungen sparen kann). Wenn du aber Gfxlib mit graphics.h vergleichen willst, in Ordnung. Trotzdem würde ich jede Zeichenroutine (Rechteck, Kreis) extra messen; und auch bei der Kombination zwischen Zeichen- und Berechnungsroutine ist nicht klar, wessen Geschwindigkeit du misst.
Bei zufälligen Größen der Rechtecke und insb. Kreise sehe ich außerdem die Gefahr, dass eines der Testprogramme zufallsbedingt mit überdurchschnittlich großen Kreisen zu tun bekommt und allein deshalb länger rechnen muss. _________________ Deine Chance beträgt 1:1000. Also musst du folgendes tun: Vergiss die 1000 und konzentriere dich auf die 1. |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 17.09.2017, 19:06 Titel: |
|
|
Das wäre ein Argument, dass der Zufall das Ergebnis ungenau macht. Habe tatsächlich mit dem Testprogramm leicht abweichende Ergebnisse. Warum du aber Kreise und Rechtecke getrennt messen willst verstehe ich nicht. |
|
Nach oben |
|
|
Jojo alter Rang
Anmeldungsdatum: 12.02.2005 Beiträge: 9736 Wohnort: Neben der Festplatte
|
Verfasst am: 17.09.2017, 23:47 Titel: |
|
|
Bei C gibt es wie gesagt keine eingebaute oder standardisierte Grafikbibliothek - es gibt viele verschiedene, von denen man sich die aussucht, die dem Zweck am besten entspricht. Das könnte hier z.B. SDL sein, was auch direkt unter FB verwendbar wäre, und ein messbarer Unterschied wäre dann (sofern das Rahmenprogramm sinnvoll programmiert ist) nicht vorhanden.
Zitat: | Warum du aber Kreise und Rechtecke getrennt messen willst verstehe ich nicht. |
Ein Kreis ist z.B. ungleich komplizierter zur Zeichnen für einen Computer als ein Rechteck. Ist der Kreis in Grafikbibliothek A effizienter implementiert als in Grafikbibliothek B, verschwimmt dieser vielleicht deutliche Unterschied dadurch, dass du die Messergbnisse mit denen der Linienfunktion vermischst. _________________ » Die Mathematik wurde geschaffen, um Probleme zu lösen, die es nicht gäbe, wenn die Mathematik nicht erschaffen worden wäre.
|
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 18.09.2017, 00:07 Titel: |
|
|
Vielleicht könnte man auch noch mehr Befehle in den Test aufnehmen und einzeln messen. Das macht es aber komplizierter in andere Sprachen zu übersetzen. Ich selber will auch nicht behaupten, ich hätte den vollen Überblick, welche Befehle besonders signifikant für die Geschwindigkeit wären.
Obiges Programm ist nur ein erster Entwurf, es bringt um rund 10% abweichende Ergebnisse. Absolute Exaktheit sieht anders aus.
Aber hier sieht man in dem Link von Nemored in der unteren Grafik, dass ein Geschwindigkeitsvergleich möglich ist:
http://benchmarksgame.alioth.debian.org/u64q/which-programs-are-fastest.html
Links sieht man C erwartungsgemäss sehr schnell. Free Pascal ist verglichen damit schon eine Schlaftablette. Perl und Lua völlig abgeschlagen. Da sieht man wie verzerrt die Darstellung im ersten Link war.
Nun müsste man wissen wo FreeBasic da liegt... |
|
Nach oben |
|
|
grindstone
Anmeldungsdatum: 03.10.2010 Beiträge: 1237 Wohnort: Ruhrpott
|
Verfasst am: 18.09.2017, 08:40 Titel: |
|
|
Perl und Lua sind Scriptsprachen und deshalb schon vom Prinzip her langsamer als Compilersprachen wie C oder FB. Und Pascal wurde zu Lehrzwecken entwickelt, um Anfängern das strukturierte Programmieren beizubringen. Die Arbeitsgeschwindigkeit war dabei (ebenso wie die Praxistauglichkeit) zweitrangig.
Die meisten Programme, die heute auf Superrechnern laufen (Klimamodelle, Wetterprognosen etc.), sind übrigens in FORTRAN geschrieben.
Zitat: | Nun müsste man wissen wo FreeBasic da liegt... |
FB kann man guten Gewissens in der Nähe von C ansiedeln.
Gruß
grindstone _________________ For ein halbes Jahr wuste ich nich mahl wie man Proggramira schreibt. Jetzt bin ich einen! |
|
Nach oben |
|
|
nemored
Anmeldungsdatum: 22.02.2007 Beiträge: 4650 Wohnort: ~/
|
Verfasst am: 18.09.2017, 08:52 Titel: |
|
|
Wieso verzerrt? Dass Perl z. B. bei Grafik nicht gut so gut abschneidet, ist völlig klar - die Sprache hat vollkommen andere Ziele. Und das Hauptziel von Lua ist nicht die Geschwindigkeit im Vergleich zu Compilersprachen, sondern seine effiziente Verwendbarkeit als eingebettete Skriptsprache - geringe Interpretergröße, Speichereffizienz - und in diesem Rahmen auch eine hohe Ausführungsgeschwindigkeit. In meinem Link findest du eine Vielzahl von getesteten Programmen, und bei weitem nicht immer geht "Sprache X" als Gewinner oder als Verlierer heraus. Je nach Anwendungsgebiet ist das sehr unterschiedlich. (Dass Lua als Skriptsprache langsamer ist als ein compiliertes C-Programm, wundert mich wenig; aber ob sich umgekehrt C als eingebettete Skriptsprache eignet ...)
Zitat: | Aber hier sieht man in dem Link von Nemored in der unteren Grafik, dass ein Geschwindigkeitsvergleich möglich ist |
Natürlich ist er möglich; ob er so pauschal aber sinnvoll ist, ist eine andere Frage.
Zitat: | Habe tatsächlich mit dem Testprogramm leicht abweichende Ergebnisse. |
Unterschiede können auch durch Hintergrundprogramme entstehen - in einem Multitasking-System sind Geschwindigkeitsmessungen systembedingt immer ungenau. 10% Abweichung sind da nicht besonders viel. _________________ Deine Chance beträgt 1:1000. Also musst du folgendes tun: Vergiss die 1000 und konzentriere dich auf die 1. |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 18.09.2017, 10:43 Titel: |
|
|
grindstone hat Folgendes geschrieben: |
FB kann man guten Gewissens in der Nähe von C ansiedeln.
|
Das ist eigentlich auch mein Eindruck. Vieles läuft schon recht zackig bei FreeBasic. Doch schöner wäre es, wenn man es schwarz auf weiss hat. |
|
Nach oben |
|
|
Marc Bonus
Anmeldungsdatum: 19.11.2016 Beiträge: 43
|
Verfasst am: 18.09.2017, 10:55 Titel: |
|
|
nemored hat Folgendes geschrieben: | aber ob sich umgekehrt C als eingebettete Skriptsprache eignet ...)
|
Das ist es eben, C ist kryptisch und schwer zu lesen. Sonst würden ja alle in C programmieren.
Da ist Freebasic wesentlich einfacher und bequemer zu benutzen, wenn es auch minimal langsamer sein mag. Bei Menüs und Texten merkt man das kaum. Höchstens wenn sehr viel zu rechnen ist oder viele Grafikoperationen könnte es sinnvoll sein Teile mit C oder ASM einzubinden.
Der Nutzen von einem Geschwindigkeitsvergleich ist, dass man Newbies zeigen könnte "Sieh her, so schnell und gut ist FreeBasic wirklich!". |
|
Nach oben |
|
|
Jojo alter Rang
Anmeldungsdatum: 12.02.2005 Beiträge: 9736 Wohnort: Neben der Festplatte
|
Verfasst am: 18.09.2017, 14:46 Titel: |
|
|
Die "Lesbarkeit" von C ist eigentlich weniger ein Gegenargument (die meisten modernen Programmiersprachen fußen auf derselben Syntax) - viel wichtiger ist eigentlic eher, dass es verdammt einfach ist, sich in den eigenen Fuß damit zu schießen, weshalb sicherheitsrelevante Software eigentlich auf einem höheren Level programmiert werden sollte. An den vielen { und } wirst du dich spätestens erfreuen, wenn es dir zu langatmig wird, ständig "END FUNCTION" oder so einzugeben.
Man kann übrigens auch nicht einfach sagen dass interpretierte Sprachen immer langsamer sind als kompilierte, da inzwischen z.B. das .NET-Framework oder auch die Java-Runtime einen Just-In-Time-Compiler enthalten, um so kritischen Code (also z.B. Schleifen, die sehr häufig ausgeführt werden) zu kompilieren und zu optimieren, während das Programm läuft. Somit können diese teilweise schnelleren Code für die aktuelle Plattform (z.B. CPU) erzeugen, als ein für die Allgemeinheit (also für mehrere CPU-Typen) vorkompilierter Code.
Zitat: | Und Pascal wurde zu Lehrzwecken entwickelt, um Anfängern das strukturierte Programmieren beizubringen. Die Arbeitsgeschwindigkeit war dabei (ebenso wie die Praxistauglichkeit) zweitrangig. |
Das ist ebenfalls veraltet und moderne Pascal-Compiler können auch sehr schnell sein. Wofür eine Sprache mal gedacht wurde und wofür sie heute eingesetzt wird sind häufig zwei paar verschiedene Schuhe - vergleiche mal einen JavaScript-Interpreter von vor 10 Jahren mit einem aktuellen JavaScript-Interpreter und wundere dich, wie viel schneller der aktuelle ist, einfach weil JavaScript heute für ganz andere Dinge eingesetzt wird und die Browserhersteller deswegen auch ihre JavaScript-Engines optimieren mussten.
Zitat: | aber ob sich umgekehrt C als eingebettete Skriptsprache eignet ... |
PicoC existiert
...und ist als Interpreter natürlich wesentlich langsamer als ein optimierender C-Compiler, womit wir wieder beim Thema "eine Sprache hat keine fest definierte Geschwindigkeit" wären. _________________ » Die Mathematik wurde geschaffen, um Probleme zu lösen, die es nicht gäbe, wenn die Mathematik nicht erschaffen worden wäre.
|
|
Nach oben |
|
|
nemored
Anmeldungsdatum: 22.02.2007 Beiträge: 4650 Wohnort: ~/
|
Verfasst am: 18.09.2017, 16:41 Titel: |
|
|
Jojo hat Folgendes geschrieben: | Man kann übrigens auch nicht einfach sagen dass interpretierte Sprachen immer langsamer sind als kompilierte |
Ja, das war natürlich etwas vorschnell verallgemeinert. Ich würde zwar Java nicht zu den Scriptsprachen zählen, aber auch bei Perl weiß ich, dass da vorcompiliert wird.
Wie Jojo zwischen den Zeilen auch schon andeutet, ist Geschwindigkeit sowieso keine Frage der Sprache, sondern des Compilers (oder sonstigen Ausführungsorgans). Für C bspw. gibt es nicht "den" Compiler, sondern ziemlich viele, und nicht alle sind richtig optimiert. D. h. je nach verwendeten Compiler kann das resultierende Programm auch mal schneller oder langsamer sein. (Wie verbreitet schlechte C-Compiler allerdings sind bzw. ob sie in der Praxis eine Rolle spielen, kann ich nicht sagen.)
Sieh an. Ich hoffe ja immer noch darauf, dass jemand FBScript implementiert. _________________ Deine Chance beträgt 1:1000. Also musst du folgendes tun: Vergiss die 1000 und konzentriere dich auf die 1. |
|
Nach oben |
|
|
|
|
Du kannst keine Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum nicht antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen.
|
|