Exponentielle Verteilung in einer Liste

Cole

Bekanntes Mitglied
Hallo zusammen,

ich habe hier eine kleine Frage:

Ich habe eine Arraylist mit einer beliebigen Anzahl von POJOs. Die POJOs haben ein Attribute "prio".
Für einen Testcase möchte ich jetzt die POJOs mit einem Wert für die Prio befüllen und zwar sollen die werte exponentiell verteilt sein.
Beispiel:

Prio | Anzahl | %
0 | 80 | 0.5
1 | 5000 | 5
2 | 60000 | 20

und so weiter.

Hat da jemand ne gute Idee wie ich das möglichst elegant umsetzen kann?

Danke und Gruss
 
Zuletzt bearbeitet von einem Moderator:

HoaX

Top Contributor
Brauchst doch nur eine Funktion f(prio) die mittels einer exponentiellen Funktion, welche du dir ausdenkst, die Anzahl zurückgibt. Dann musst du nurnoch soviele Objekte einfügen.
 

freez

Top Contributor
Ist die prozentuale Angabe fix, oder muss sie nur annähernd erreicht werden?

wenn zweites: Du könntest dir eine Zufallszahl zwischen 0-40 generieren. Ist sie < 1 dann Prio 0, ist sie zwischen 1 und 10, dann Prio 1 und alles drüber ist Prio 2.
 

HoaX

Top Contributor
wenn zweites: Du könntest dir eine Zufallszahl zwischen 0-40 generieren. Ist sie < 1 dann Prio 0, ist sie zwischen 1 und 10, dann Prio 1 und alles drüber ist Prio 2.
Auf die Zufallszahl kannste getrost verzichten, denn Anhand der Prozente kann man sich ja die Anzahl der einzelnen Abschnitte ausrechnen.
 

freez

Top Contributor
Auf die Zufallszahl kannste getrost verzichten, denn Anhand der Prozente kann man sich ja die Anzahl der einzelnen Abschnitte ausrechnen.

Ich hatte einfach mal unterstellt, dass dieselben Prios nicht alle nebeneinander stehen sollen, da dies ja nicht gerade eine schwierige Aufgabe sein sollte x mal prio 0, y mal prio1 und z mal prio 2 in ein Array zu schieben.

Die zufällige Verteilung dieser vordefinierten Objekte in ein Array dürfte wohl etwas schwieriger sein, als die Prio zufällig zu generieren.
 

0x7F800000

Top Contributor
hingerotzt & lahm:
Java:
	/** generates a sample of Exp_lambda - distributed values, where lambda is the rate */
	public double[] rexp(double lambda, int size){
		double[] res = new double[size];
		for (int i = 0; i < size; i++) res[i] = -Math.log(Math.random())/lambda;
		return res;
	}
 

Cole

Bekanntes Mitglied
@0x7F800000:
Verständnisfrage:
Was ist lamda? Bezogen auf mein Beispiel vom Startthread?

Vielleicht muss ich meine Ursprungsfrage auch nochmal präzisieren:

Ich habe zB 100 Pojos in einer Liste, davon sollen 5 die Prio 0 bekommen, 10 die Prio 1, 25 die Prio 2 und der Rest (60) die Prio 3 (Prio ist ein Feld im Pojo).
(die Zahlen 5, 10, 25, 60 sind nur Beispiele, ich will damit sagen, dass es nicht mit simplem Verdoppeln o.ä. getan ist)
 
Zuletzt bearbeitet:

0x7F800000

Top Contributor
Lambda ist die Rate. Da sind alle werte zwischen 0 und unendlich zugelassen. Rate ist anschaulich der Kehrwert der Zeit, die zwischen den Klicks des Geigerzählers vergeht. Wenn du hier spazieren gehst, klickt es vielleicht einmal in 5 sekunden, rate ist niedrig. Wenn du in Fukushima spazieren gehst, klickt es vielleicht tausend mal pro sekunde, die rate wäre dann 5000 mal höher.
Bezogen auf mein Beispiel vom Startthread?
Weiß ich nicht so recht, das was du in der anfänglichen Frage skizziert hast, sieht überhaupt nicht wie die Exponentielle Verteilung aus. Ich schätze mal, du hast einfach einen reservierten Begriff an der falschen Stelle verwendet (muss man als nicht-Naturwissenschaftler bzw nicht-Mathematiker auch nicht unbedingt kennen, obwohl die Exponentialverteilung so einer Art fundamentaler Bestandteil alles Zufälligen im Universum ist).

Vielleicht muss ich meine Ursprungsfrage auch nochmal präzisieren:

Ich habe zB 100 Pojos in einer Liste, davon sollen 5 die Prio 0 bekommen, 10 die Prio 1, 25 die Prio 2 und der Rest (60) die Prio 3 (Prio ist ein Feld im Pojo).
(die Zahlen 5, 10, 25, 60 sind nur Beispiele, ich will damit sagen, dass es nicht mit simplem Verdoppeln o.ä. getan ist)
Ja, gut, ich sehe da eine Aufgabe, aber ich sehe nicht wo dein Problem ist: pack doch einfach die richtige Anzahl der POJO's rein, und shuffle das ganze zusätzlich, wo soll man denn da hängen bleiben?
Java:
import java.util.*;

public class RandomPOJOs {
	
	static class MyPojo{
		int priority;
		public MyPojo(int p){ priority = p; }
		@Override
		public String toString(){ return "MP[" + priority + "]"; }
	}
	
	// exact numbers of pojos, random shuffling
	static List<MyPojo> createPojosExact(int total, double... probabilities){
		
		List<MyPojo> res = new ArrayList<MyPojo>(total);
		
		int[] exactNumbers = new int[probabilities.length];
		int sum = 0;
		for (int i = 0; i < probabilities.length - 1; i++){
			exactNumbers[i] = (int)(total * probabilities[i]);
			sum += exactNumbers[i];
		}
		exactNumbers[exactNumbers.length - 1] = total - sum;
		
		for (int prio = 0; prio < exactNumbers.length; prio ++)
			for (int i = 0; i < exactNumbers[prio]; i++) 
				res.add(new MyPojo(prio));
		
		
		java.util.Collections.shuffle(res);
		return res;
	}
	
	// random number of pojos, random shuffling
    static List<MyPojo> createPojosRandom(int total, double... probabilities){
		
		List<MyPojo> res = new ArrayList<MyPojo>(total);
		
		// ecdf = "empirical cumulated distribution function"
		double[] ecdf = new double[probabilities.length];
		for (int i = 0; i < probabilities.length; i++)
			ecdf[i] = (i == 0 ? 0d : ecdf[i - 1]) + probabilities[i];
		
		// sampling from ecdf with binary search
		for (int i = 0; i < total; i++){
			int binSearchRes = Arrays.binarySearch(ecdf, Math.random());
			int prio = (binSearchRes >= 0) ? binSearchRes : (-binSearchRes - 1);
			res.add(new MyPojo(prio));
		}
		
		return res;
	}
	
	public static void main(String... _){
		System.out.println("exakt");
		
		// exakte anzahlen von pojos mit verteilung: 0.1 mit prio 0, 0.2 mit 1, 0.4 mit 2, 0.3 mit 3
		for (MyPojo pojo : createPojosExact(10, 0.1, 0.2, 0.4, 0.3)) System.out.println(pojo);
		
		System.out.println("\nzufällig");
		
		// zufällige anzahlen von pojos mit verteilung: 0.1 mit prio 0, 0.2 mit 1, 0.4 mit 2, 0.3 mit 3
		for (MyPojo pojo : createPojosRandom(10, 0.1, 0.2, 0.4, 0.3)) System.out.println(pojo);
		
		System.out.println("\nhistogramm: ");
		// nachzählen was die random variante eigentlich ausgibt
		int[] hist = new int[4];
		for (MyPojo pojo : createPojosRandom(1000000, 0.1, 0.2, 0.4, 0.3)) hist[pojo.priority]++;
		for (int h: hist) System.out.println(h/1000000d);
	}
}
so, bisschen code... hoffentlich halbwegs selbsterklärend...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Anzahl von Möglichkeiten zur Verteilung von Kugeln in Behälter Allgemeine Java-Themen 3
K F-Verteilung FINV in Java berechnen Allgemeine Java-Themen 4
M Logikaufgabe: Beste Verteilung Allgemeine Java-Themen 11
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6
T Compiler-Fehler NoClassDefFoundError beim Laden einer Class Allgemeine Java-Themen 11
H Klassen LibGDX - Verschiedene Klassen als Value in einer Map Allgemeine Java-Themen 8
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
E Elemente innerhalb einer ArrayList vergleichen Allgemeine Java-Themen 33
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
temi Java Programm aus einer DB laden und starten Allgemeine Java-Themen 2
J int Werte in einer anderen Klasse in Arrays speichern Allgemeine Java-Themen 3
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
ReinerCoder Methode einer Klasse meldet Fehler "misplaced construct(s)" Allgemeine Java-Themen 13
L Fehler bei der Ausführung einer Jar Allgemeine Java-Themen 2
Javafan01 Deklarieren einer Math.random() Zufallszahl Allgemeine Java-Themen 16
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
H Laden einer (Resourcendatei) aus einem Jar-File Allgemeine Java-Themen 17
P Array einer abstrakten Klasse Allgemeine Java-Themen 4
J Teil einer URL auslesen Allgemeine Java-Themen 13
J Ordner und Datei Struktur einer War Datei Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben