AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Optimierung eines Stück Codes für eine Wette!
Thema durchsuchen
Ansicht
Themen-Optionen

Optimierung eines Stück Codes für eine Wette!

Ein Thema von R2009 · begonnen am 12. Nov 2009 · letzter Beitrag vom 12. Nov 2009
Antwort Antwort
Seite 1 von 3  1 23      
R2009

Registriert seit: 9. Mär 2009
Ort: Heidelberg
440 Beiträge
 
Delphi 2007 Professional
 
#1

Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:24
Hi DP'ler,
ich habe mich dazu verleiten lassen zu behaupten, dass ich dieses Programmstück mindestens doppelt so schnell bekomme wie
ein vergleichbares Stück Code in VB.
Seht ihr noch Optimierungsmöglichkeiten?
Das Ganze ist recht primitiv und berechnet Primzahlen. Die Vorgehensweise ist vorgegeben. Am Algorithmus kann ich nur bedingt etwas ändern.
Das ganze Programm hängt an. Für 1000000 benötigt VB 22 Sekunden und das Teil hier 19.

Delphi-Quellcode:
procedure Tfrm_Hauptform.btn_RechneClick(Sender: TObject);

{ ################################################################################################################################## }

var
D : cardinal;
flg_NoPrim : Boolean;

Anfg_Zeit : TDateTime;
Ende_Zeit : TDateTime;
Diff_Zeit : TDateTime;

I : cardinal;
r : cardinal;
{ ################################################################################################################################## }

begin

max_Prim := StrToInt(txt_MaxZahl.Text);
setlength(prim,1000000);
Prim[1] := 2;
Prim[2] := 3;
Prim[3] := 5;
anz_Prim := 3;

lst_Ausgabe.Clear;
lst_Ausgabe.Items.Add('Suche Primzahlen ..');
lst_Ausgabe.Items.Add('Start: ' + DateTimeToStr(Now));
lst_Ausgabe.Refresh;

Anfg_Zeit := Now;

For D := 6 To max_Prim do
  begin

    flg_NoPrim := FALSE;
    I := 1;

    repeat
      begin
        r:=D mod Prim[I];
        If r = 0 Then flg_NoPrim := TRUE;
        inc(i);
      end;
    until (flg_NoPrim OR (I = anz_Prim));

    If flg_NoPrim=false then
         begin
           anz_Prim := anz_Prim + 1;
           Prim[anz_Prim] := D;
         {lst_Ausgabe.Items.Add(IntToStr(D) + ' ist eine Primzahl!'); }
         end;
end;

Grüsse
Rainer
Angehängte Dateien
Dateityp: zip delphi_628.zip (251,0 KB, 16x aufgerufen)
Rainer Unger
Mein Profil:
Studium Allgemeine Elektrotechnik TH Darmstadt
Entwicklung von Tools für die Rundsteuer und Zählertechnik.
uP's Atmel Prozessoren (ATmega16,32,88...) in C und Assembler.
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:31
Ich sag mal so - diese Wette wirst du verlieren. Wenn man den VB-Code ebenfalls schon im Quelltext optimiert wird der Delphicode niemals doppelt so schnell sein.
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
IIIMADDINIII
(Gast)

n/a Beiträge
 
#3

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:39
hast du es schonmal in ein thread mit der hösten priorität(timecritical) ausprobiert?
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#4

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:47
For D := 6 To max_Prim do Nur ungerade Zahlen können Primzahlen sein.
Wenn du die Schleife so änderst, dass nur ungerade Zahlen getestet werden, spart das Zeit.
fork me on Github
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#5

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:52
aber wäre vb auch langsamer wenn der dazugehörige vb code ebenfalls nur die ungeraden zahlen testet und der Thread mit höherer Priorität läuft?!
Das füllen der Listbox könnte man durch Verwendung von BeginUpdate und EndUpdate beschleunigen (sofern eine Liveausgabe nicht benötigt wird)
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#6

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:53
Hallo,

soviel schneller nicht mit meinen Änderungen, aber eventuell 1 oder 2 Millisekunden?

Delphi-Quellcode:
procedure Tfrm_Hauptform.btn_RechneClick(Sender: TObject);

{ ################################################################################################################################## }

var
D : cardinal;
flg_NoPrim : Boolean;

Anfg_Zeit : TDateTime;
Ende_Zeit : TDateTime;
Diff_Zeit : TDateTime;

I : cardinal;
r : cardinal;
{ ################################################################################################################################## }

begin

max_Prim := StrToInt(txt_MaxZahl.Text);
setlength(prim,1000000);
Prim[1] := 2;
Prim[2] := 3;
Prim[3] := 5;
anz_Prim := 3;

lst_Ausgabe.Clear;
lst_Ausgabe.Items.Add('Suche Primzahlen ..');
lst_Ausgabe.Items.Add('Start: ' + DateTimeToStr(Now));
lst_Ausgabe.Refresh;

Anfg_Zeit := Now;

// For D := 6 To max_Prim do
  d := 6;
  Repeat
    begin

    // flg_NoPrim := FALSE; // <- ist diese Zuweisung erforderlich,
                            // wird doch im Repeat Until überschrieben.
    I := 1;

    repeat
      // begin
        // r := D mod Prim[I];
        // If r = 0 Then flg_NoPrim := TRUE;
        // flg_NoPrim := r = 0;
        flg_NoPrim = D mod Prim[I];
        inc(i);
      // end;
    until (flg_NoPrim OR (I = anz_Prim));

    // If flg_NoPrim=false then
    // If Not flg_NoPrim then
    case flg_NoPrim of
      false : begin
                // wo ist denn anz_Prim definiert?
                // anz_Prim := anz_Prim + 1;
                Inc(anz_Prim);
                Prim[anz_Prim] := D;
                {lst_Ausgabe.Items.Add(IntToStr(D) + ' ist eine Primzahl!'); }
              end;
    end;
    Inc(d,2);
  Until d >= max_Prim;
end;
Achso, nur hingedaddelt, nicht getestet.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.195 Beiträge
 
Delphi 10.4 Sydney
 
#7

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 08:54
VB oder VB.NET?

Mit VB.NET wird es schwierig. Bei gleichen Code eigentlich unmöglich doppelt so schnell zu werden. Auch du verwendest hochoptimierten Assemblercode in der Routine.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#8

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 09:03
ich könnte mir vorstellen das dieser Abschnitt
Delphi-Quellcode:
repeat
  flg_NoPrim = D mod Prim[I];
  inc(i);
until (flg_NoPrim OR (I = anz_Prim));
schneller wäre wenn man nicht bei jedem Schleifendurchlauf flg_noPrim prüft.

Aber auch das hat nichts mit Delphi vs VB zu tun. Denn wenn du den Quelltext fertig hast und dieser so nach VB übernommen wird ist dieser auch dort schneller.
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
Benutzerbild von Corpsman
Corpsman

Registriert seit: 8. Nov 2005
Ort: nähe Stuttgart
981 Beiträge
 
Delphi XE2 Professional
 
#9

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 09:06
Also wenn du nichts am Algorithmus machen kannst ist das natürlich blöd.

Im Prinzip berechnest du ja alle Primzahlen unter 1000000 und zählst diese.

Ich hab mal nen alten Algo von meinen Project Euler Aufgaben rausgekramt, und den das Berechnen lassen. Der lag unter 1 sec. hat also immer 00:00:00 ausgegeben.

Wenn du allerdings wirklich den vorgegebenen Code nehmen musst, dann siehts schlecht aus für dich. Wirklich Zeit sparen kannst du nur wenn du schneller = anders auf dein Ziel kommst, und das wäre ja wieder eine Algorithmische Änderung.
Uwe
My Sitewww.Corpsman.de

My marble madness clone Balanced ( ca. 70,0 mb ) aktuell ver 2.01
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.442 Beiträge
 
Delphi 12 Athens
 
#10

Re: Optimierung eines Stück Codes für eine Wette!

  Alt 12. Nov 2009, 09:07
Wenn du am Algorithmus nichts ändern darfst, wird es schwierig werden...

Aber trotzdem hier der Code mit ein paar Boostern:

Delphi-Quellcode:
For D := 7 To max_Prim do begin // 6 ist keine Primzahl, daher ab 7
  if not Odd(D) then Continue; // schließe alle geraden Zahlen aus
  maxTest := Trunc(Sqrt(D)); // prüfe nur bis max. Quadratwurzel des Kandidaten
  flg_NoPrim := false;
  for I := 2 to anz_Prim do begin // gerade Zahlen hatten wir ausgeschlossen, daher ab 2
    test := Prim[I];
    if test > maxTest then Break;
    flg_NoPrim := ((D mod test) = 0);
    if flg_NoPrim then Break;
  end;
  if flg_NoPrim then Continue;
  Inc(anz_Prim);
  Prim[anz_Prim] := D;
end;
Uwe Raabe
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:47 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz