Performance steigern

vimar

Bekanntes Mitglied
Hallo,
wie kann ich diesen code beschleunigen? ideen waren:

Erstens: 4 threads(1 pro kern), in der innersten for schleife 4x m++ und 4 mal distance gleichzeitig berechnen.

Zweitens: Zeile 18-21 ersetzen, die distanzen in einer arraylist speichern, anschließend Collections.min(arraylist) irgendwie den index rauskriegen von dem kleinsten element und dann in "clusterid" speichern.

oder habt ihr grundlegende vorschläge. das problem ist dass bei der rechnung nur ein kern genutzt wird, diese rechnung sich gewissermaßen zwischen rechnungen befinden die mit 4 threads alle kerne auslasten. ich will permanent volle auslastung aller kerne erreichen.

vielen dank für jegliche hilfe.

tsk.jpg





Java:
for (int j = 0; j < ImageList.size(); j++){ // durch alle bilder durch
               distanz = 0;
               for (int k = 0; k < ImageList.get(j).size();k++){ // jeder vektor im bild?;P
                   
                     
                    for (int m = 0; m < clist.size(); m++){ // jeder Cluster ;P
                                  
                       if (m == 0){
                      
                        
                         clusterid = 0; // == 0                 
                         distanz = distance(clist.get(m).Centroid, ImageList.get(j).get(k));
                        // distance ist einfach nur eine abstandsfkt(manhattendistance) von 2 vektoren.
                     }// end if
                      
                         distemp = distance(clist.get(m).Centroid, ImageList.get(j).get(k));
        
                         if (distemp < distanz){
                      //       System.out.println("jow trifft zu");
                              distanz = distemp;
                              clusterid = m;
                         }//end if

                    } //end FOR m
 

vimar

Bekanntes Mitglied
Java:
public int distance(ArrayList <Integer> centroid, ArrayList <Integer> kpoint){
            
     
            int sum = 0;
            for (int i = 0; i < 128; i++){
                
              // euklid distance ohne wurzel
              //  sum = sum + (centroid.get(i) - kpoint.get(i)) * (centroid.get(i) - kpoint.get(i)) ; 

               // performance: manhatten R^1 distance
                sum = sum + Math.abs(centroid.get(i) - kpoint.get(i));
            }
           
             return sum;
        }
 
J

JohannisderKaeufer

Gast
Hab doch schon mal vor einem Monat auf die Frage geantwortet.

Java:
for (int j = 0; j < ImageList.size(); j++){
//Nicht mehr 0 sondern MAX_VALUE
               distanz = Integer.MAX_VALUE;
               for (int k = 0; k < ImageList.get(j).size();k++){
                    for (int m = 0; m < clist.size(); m++){ 
//Das If (m == 0) einfach entfernen
//Ein weiterer Parameter distanz
                         distemp = distance(clist.get(m).Centroid, ImageList.get(j).get(k), distanz);
        
                         if (distemp < distanz){
                              distanz = distemp;
                              clusterid = m;
                         }
 
                    } 
}

und

Java:
        public int distance(ArrayList <Integer> centroid, ArrayList <Integer> kpoint, int minDistanz){
            int sum = 0;
            for (int i = 0; i < 128; i++){
                
              // euklid distance ohne wurzel, "War übrigens mein Vorschlag"
              //  sum = sum + (centroid.get(i) - kpoint.get(i)) * (centroid.get(i) - kpoint.get(i)) ; 
 
               // performance: manhatten R^1 distance
                
                sum = sum + Math.abs(centroid.get(i) - kpoint.get(i));
//Eine Abbruchbedingung da der exakte Wert von sum uninteressant ist, 
//wenn er größer als die bereits kleinste gefunde Distanz ist.
                if(sum>minDistanz){
                  return sum;
                }
            }           
             return sum;
        }

Erklärungen im Code. Ansonsten das GALILEO (Pro7) Motto, Sehen, Staunen, Verstehen.

Ansonsten zu den Threads.

Für jedes ImageList-Objekt einen Thread. Also schon in Zeile 2, Direkt nach der ersten for-Schleife.
 

Marco13

Top Contributor
Für Zeitkritisches könnte/sollte man auch auf autoboxing verzichten. Wie viel man hier rausholen könnte (und welche Änderungen dafür notwendig wären) ist aber schwer zu sagen.
 

vimar

Bekanntes Mitglied
jo danke!

johannes: ja ich check das jetzt mal aus! war die letzten 2 wochen verhindert und hatte keine zeit zum coden. werde das jetzt mal umsetzen! und ja ohne wurzel war von dir :p
 

Empire Phoenix

Top Contributor
Am rande hätte man nicht eifnach cpuanzahl bilder auf einmal machen können?
dann muss nur noch der finale zugriff auf distanz jeweisl im synchronized laufen oder sehe ich das falsch?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
goldmensch Datentypen Welche Methode hat die bessere Performance? Allgemeine Java-Themen 12
H Watson-Crick-Complement Performance Allgemeine Java-Themen 18
L Best Practice Auslagerung von Code = Performance Optimierung? Allgemeine Java-Themen 4
B Performance Messungen Allgemeine Java-Themen 4
J Threads verbessern die Performance NICHT ? Allgemeine Java-Themen 8
X Performance für Tomcat / Apache optimieren Allgemeine Java-Themen 2
I Performance - JDBC UPC PoolDataSoure Allgemeine Java-Themen 0
E Lambda filter performance Allgemeine Java-Themen 2
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
A Jasper Report Performance bei PDF erzeugen Allgemeine Java-Themen 0
A Best Practice Variablen vertauschen - Performance Allgemeine Java-Themen 1
R DBUnit Performance Probleme Allgemeine Java-Themen 0
P Performance: super explizit erwähnen oder weglassen? Allgemeine Java-Themen 5
S starke performance probleme des forums Allgemeine Java-Themen 10
C Performance Tips Allgemeine Java-Themen 13
A Performance/Speicherplatz-Nutzung bei Tests Allgemeine Java-Themen 6
R Java Performance testen Allgemeine Java-Themen 18
StrikeTom Java Performance Fragen Allgemeine Java-Themen 5
D Reflection-Performance Allgemeine Java-Themen 7
M Einfluss von Caching auf die Performance (große Arrays) Allgemeine Java-Themen 24
R Collections Performance einer HashMap Allgemeine Java-Themen 26
i<3java [Groovy/Grails](oder auch java) Mögliche Performance Probleme bei Mailversendung Allgemeine Java-Themen 2
D Performance Objektallokation Allgemeine Java-Themen 28
J Java Performance nicht nachvollziehbar Allgemeine Java-Themen 3
I Library für High Performance Mime Type Erkennung Allgemeine Java-Themen 8
S Performance Frage: Objekt oder static? Allgemeine Java-Themen 33
M Runtime.exec() - Performance / Frage zu Threads Allgemeine Java-Themen 5
M Performance Allgemeine Java-Themen 6
M Performance Allgemeine Java-Themen 5
E Performance website download Allgemeine Java-Themen 13
MQue Performance Methodenaufruf - if Abfrage Allgemeine Java-Themen 19
hdi Was frisst in meinem Programm den Speicher / verschlechtert die Performance Allgemeine Java-Themen 11
J Performance von Java GUI-Anwendungen Allgemeine Java-Themen 2
U Java Performance im Vergleich zu C++ in speziellem Anwendungsfall Allgemeine Java-Themen 6
S Performance und Function Call Depth Allgemeine Java-Themen 6
H Performance Vorteil durch Wechsel der JVM? Allgemeine Java-Themen 6
A Performance: byte[] in byte[][][] konvertieren Allgemeine Java-Themen 2
T Performance ArrayList#remove Allgemeine Java-Themen 8
ARadauer Performance Pptimierung -Lesen/Schreiben Allgemeine Java-Themen 10
Chris81T Performance Problem durch mehrfaches Starten eines JAVA Prog Allgemeine Java-Themen 8
G Hibernate, JTable und Performance Allgemeine Java-Themen 17
M Listener und Performance Allgemeine Java-Themen 9
P Performance: Ziehen ohne Zurücklegen (große Datenmenge) Allgemeine Java-Themen 10
D Performance: ArrayList vs. Array vs. "Eigene Liste&quot Allgemeine Java-Themen 8
M nichtreferenzierte Objekte auf NULL setzen -> Performance Allgemeine Java-Themen 4
S Ursache für schlechte Performance Allgemeine Java-Themen 2
L Java Performance Check Tool Allgemeine Java-Themen 3
S Performance von Comparator Allgemeine Java-Themen 3
egrath Performance Problem mit File-I/O Allgemeine Java-Themen 6
S Performance Problem Allgemeine Java-Themen 11
X Java Performance auf Sun Systemen bzw. generell Allgemeine Java-Themen 4
T Performance String-Operationen und StringBuffer (1.4und 1.5) Allgemeine Java-Themen 18
P miese performance bei nem BufferedImage + repaint :( Allgemeine Java-Themen 6
T Performance-Grundlagen Allgemeine Java-Themen 4
G Performance Problem bei der Übertragung Server zum Client Allgemeine Java-Themen 3
V Performance Leck finden Allgemeine Java-Themen 3
T Tile Game Performance Allgemeine Java-Themen 32
M Performance enorm langsam Allgemeine Java-Themen 26
F Performance von Reflection vs Statisches Coden Allgemeine Java-Themen 4
M Performance: Java zu C/C++ bei Datenbankanwendung Allgemeine Java-Themen 3
Y unnecessary cast & Performance Allgemeine Java-Themen 29
conan2 Performance von paint() Allgemeine Java-Themen 2
G Performance JDOM - DOM - eigene HashMap (SAX) Allgemeine Java-Themen 2
F Bilder als "Thumbnails" laden - Performance Allgemeine Java-Themen 6
S Java3D Performance optimieren Allgemeine Java-Themen 5
F Wenn ihr Performance wollt nehmt C++ Allgemeine Java-Themen 39
N Performance-Test (Geschwindigkeit von Methoden vergleichen)? Allgemeine Java-Themen 4
S Performance Test mit JMeter Allgemeine Java-Themen 2
T Performance Allgemeine Java-Themen 8
J Anfängerliste für gute Performance? Allgemeine Java-Themen 3
Luma Performance-Problem mit RandomAcces File Allgemeine Java-Themen 4
I Performance bei "String <-> Byte"-Umwandlung Allgemeine Java-Themen 4
I Performance-Probleme bei Schleife Allgemeine Java-Themen 3
C Performance von FOR Schleifen Allgemeine Java-Themen 25
C Performance Vergleich, Java vs. Tcl/Tk Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben