Java Lineare-Suche Zeitmessung

slitec

Mitglied
Hallo,

ich habe vorab 2 Fragen, allerdings sollte zuvor der Code erklärt werden:

Ich habe hier einen Code geschrieben, der die Dauer (Zeit) der Linearen-Suche misst. Hierzu wird in der Methode suchzeitLinear() die Methode
suche() 1000 mal ausgeführt (schritte2), die Zeit addiert und dann ein Mittelwert gebildet. Anschließend wird dies 30 mal mit 30 verschiedenen Zahlen durchgeführt um letztendlich nochmals einen Mittelwert zu bilden. Somit kommen wir auf 30.000 Durchläufe um einen einigermaßen zuverlässigen Durchschnittswert zu bekommen.

Nun zu meinen Fragen:

1. Ich weiß, dass die Methode suchen() beim mehrmaligen Ausführen optimiert wird. Hierzu habe ich mir überlegt ein "Warmup" einzuführen sodass diese Methode suchen() zuvor erst mal 1000 vor der Zeitmessung ausgeführt wird mit jeweils einer unterschiedlicher Suchzahl, damit diese beim Messen dann schon optimiert ist.
--> Reicht dieses Warmup somit aus, damit ein einigermaßen zuverlässiger Messwert gemessen werden kann?

2. Ist es auch so, dass die gesuchten Zahlen vielleicht im Speicher geladen werden ? Denn manche Zahlen werden nach dem Warmup deutlich schneller gefunden als andere Zahlen. Somit müssten doch dann die bereits gesuchten Zahlen schneller gefunden werden?
--> Wenn dies der Fall ist, gibt es vielleicht eine Möglichkeit den Speicher nach jeder Suche zu leeren, damit alle Suchzahlen die selbe Voraussetzungen besitzen und somit auch die Zeitmessung nicht verfälscht wird?

Ich bedanke mich im Voraus für die Antworten.

Vollständiger Code:
Java:
package a3;


import java.util.Random;   
import java.util.Arrays;



public class LineareSuche {
    
    int[] liste; //Array wird definiert als "liste"
    Random zufall = new Random();    // wird erzeugt für Klasse erzeugenUnsortiert()
    int suchzahl; //Dies ist die gesuchte Zahl
    int schritte;

    
    public LineareSuche(){
    }
    
    public void erzeugeZufallszahl(int plätze,int oberGrenze) {
        //Erzeugt nicht gleichverteilte Zufallszahlen (doppelte sind möglich)
        
        liste = new int [plätze];
        //Anzahl an Plätze wird übergeben
        
        for (int i=0; i<liste.length;i++) {
            liste[i] = zufall.nextInt(oberGrenze);
            // Liefert eine int-Pseudo-Zufallszahl im Bereich von 0 bis oberGrenze
        }
    }
    
    public void sortieren(){
        Arrays.sort(liste);
    }
    
    
    
    public void ausgabe() {
        for (int i=0; i<liste.length; i++) {
            System.out.println(liste[i] + " || Index: " + (i));
        }
    }
    
    
    
    
    public int suche(int suchzahl) {
        
        //suchzahl = liste[zufall.nextInt(liste.length)]; //legt eine zufällige Suchzahl im Array fest
        for (int i = 0; i < liste.length; i++){
            schritte++;
            if(liste[i] == suchzahl){
                return suchzahl; //wenn gefunden wird suchzahl zurückgegeben
                
            }
        }
                
        return -1; //wenn nicht gefunden
        
        
    }
    
    
    public long suchzeitLinear(int schritte1,int schritte2,int warmup) { //schritte1 = 30 , schritte2= 1000 //warmup = 1000
        
        
        /*for(int y=0; y<warmup; y++) {
            suchzahl = 0;
            suche(suchzahl);
        } */
        
        long zeit1=0; //Zeit für 30 Suchen
        
        for (int x=0; x<schritte1;x++) {
            
        long    zeit2=0;; // Zeit für 1000 Suchen
        schritte=0;
        
        for (int j=0; j<schritte2;j++ ) {
            
            final long timeStart = System.nanoTime();
            suche(suchzahl);
            final long timeEnd = System.nanoTime();
            long zeit = timeEnd - timeStart;
            zeit2 += zeit; //Zeit innere Schleife addiert
        
            
        }
        zeit1 += zeit2/schritte2; //Zeit äußere Schleife addiert
        System.out.println("Suchzahl"+x+": " +suchzahl+"      Zeit: "+zeit2/schritte2+"      Schritte: "+schritte);
        //Für Anzahl an schritte2 wird die Zeit wiedergegeben sowie die Schritte
    
        }
        
        long zeitFinal=zeit1/schritte1; //Finale Zeit
        System.out.println("Suchzeit: "+zeitFinal+" Nanosek.");
        return zeitFinal;
    }
    
    
    
    
    
    
    public static void main(String[] args) {
        LineareSuche l1= new LineareSuche();
        l1.erzeugeZufallszahl(10000, 20000);
        l1.sortieren();
        //l1.ausgabe();
        l1.suchzeitLinear(30,1000,100000);
        
        
    }
}


Code der Methode suchzeitLinear():
Java:
    public long suchzeitLinear(int schritte1,int schritte2,int warmup) { //schritte1 = 30 , schritte2= 1000 //warmup = 1000
        
        
        /*for(int y=0; y<warmup; y++) {
            suchzahl = 0;
            suche(suchzahl);
        } */
        
        long zeit1=0; //Zeit für 30 Suchen
        
        for (int x=0; x<schritte1;x++) {
            
        long    zeit2=0;; // Zeit für 1000 Suchen
        schritte=0;
        
        for (int j=0; j<schritte2;j++ ) {
            
            final long timeStart = System.nanoTime();
            suche(suchzahl);
            final long timeEnd = System.nanoTime();
            long zeit = timeEnd - timeStart;
            zeit2 += zeit; //Zeit innere Schleife addiert
        
            
        }
        zeit1 += zeit2/schritte2; //Zeit äußere Schleife addiert
        System.out.println("Suchzahl"+x+": " +suchzahl+"      Zeit: "+zeit2/schritte2+"      Schritte: "+schritte);
        //Für Anzahl an schritte2 wird die Zeit wiedergegeben sowie die Schritte
    
        }
        
        long zeitFinal=zeit1/schritte1; //Finale Zeit
        System.out.println("Suchzeit: "+zeitFinal+" Nanosek.");
        return zeitFinal;
    }
 

mihe7

Top Contributor
Du verfälscht Dein Ergebnis schon dadurch, dass Du zwischen den Schritten die Zeit misst. Das haben wir in einem anderen Thread schon mal erklärt.

Für das Warmup würde ich einfach in zigtausend Iterationen die Klasse instantiieren und die Zeitmessung durchführen. Ggf. noch auf den GC achten.
 

slitec

Mitglied
Du verfälscht Dein Ergebnis schon dadurch, dass Du zwischen den Schritten die Zeit misst. Das haben wir in einem anderen Thread schon mal erklärt.

Für das Warmup würde ich einfach in zigtausend Iterationen die Klasse instantiieren und die Zeitmessung durchführen. Ggf. noch auf den GC achten.

Ich messe die Zeit aber doch nicht zwischen den Schritten oder ? Ich messe die Zeit ja nur solange die Methode suche() läuft. Oder sollte ich die Zeitmessung innerhalb der Methode suche() ausführen?

Was genau meinst du mit instantiieren ?
 

mihe7

Top Contributor
Ich messe die Zeit ja nur solange die Methode suche() läuft.
Schon, aber für die Messung musst Du ja auch Methoden aufrufen (System.currentTime...) Es reicht, wenn Du einmal vor der (inneren) Schleife und einmal außerhalb misst.

Was genau meinst du mit instantiieren ?
Neue Objekte erzeugen. Im Prinzip so etwas:
Java:
        for (int i = 20; i >= 0; i--) {
            LineareSuche l = new LineareSuche(i == 0 ? 1L : System.currentTimeMillis());
            l.erzeugeZufallszahl(10000, 20000);
            l.sortieren();            
            l.suchzeitLinear(30,1000, i == 0);
        }
wobei der letzte Parameter von suchzeitLinear in dem Fall angibt, ob eine Ausgabe erfolgen soll oder nicht.
 

slitec

Mitglied
Schon, aber für die Messung musst Du ja auch Methoden aufrufen (System.currentTime...) Es reicht, wenn Du einmal vor der (inneren) Schleife und einmal außerhalb misst.

Ich rufe aber doch die Methode System.nanoTime() für die Messung schon auf in der Methode suchzeitInterpolation() ? Versteh nicht ganz was genau du mit dieser Aussage meinst?
 

mihe7

Top Contributor
1. Ich sehe keine Methode suchzeitInterpolation().
2. Was ich damit meine: der Methodenaufruf von System.nanoTime (oder System.currentTime... oder was auch immer) benötigt auch ein klein wenig Zeit und zusätzlich ist der relative Fehler größer, je kürzer die Abstände sind (z. B. bekommst Du je nach Betriebssystem die Zeit nicht mit einer Auflösung von 1 ns zurück). Wenn Du die Messwerte addierst, addiert sich damit auch der Fehler.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Java Lineare Suche Java Basics - Anfänger-Themen 1
V_Fynn03 Beliebiges Element in einer Liste löschen (Java)(Lineare Datenstrukturen) Java Basics - Anfänger-Themen 9
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben