Difference between revisions of "Randomisierte Algorithmen"
(→2. RANSAC-ALGORITHMUS (Random Sample Consensus)) |
(→2. RANSAC-ALGORITHMUS (Random Sample Consensus)) |
||
| Line 118: | Line 118: | ||
-<math>trials= \frac{log\left(1-p\right)}{log\left(1-\left(1-\Epsilon\right)^k\right)}</math> mit k=Anzahl der Datenpunkte und p=Erfolgswahrscheinlichkeit, <math>\Epsilon</math>=Outlier-Anteil | -<math>trials= \frac{log\left(1-p\right)}{log\left(1-\left(1-\Epsilon\right)^k\right)}</math> mit k=Anzahl der Datenpunkte und p=Erfolgswahrscheinlichkeit, <math>\Epsilon</math>=Outlier-Anteil | ||
| + | |||
| + | |||
| + | |||
| + | <math>\begin{array}{|c||c|c|c|c|c|} | ||
| + | Beispiel & k & \Epsilon=10% & 20% & 50% & 70%\\ | ||
| + | \hline | ||
| + | linie in 2D & 2 & 3 &5 & 17 & 49\\ | ||
| + | Kreis in 2D & 3 & 4 & 7 & 35 & 169\\ | ||
| + | Ebene in 3D & 8 & 9 & 26 & 1172 & 70188\\</math> | ||
Revision as of 18:30, 3 July 2008
1. Randomisierte Algorithmen
Def.: Algorithmen, die bei Entscheidung oder bei der Wahl der Parameter Zufallszahlen benutzen
Bsp.: Lösen des K-SAT-Problems durch RA
geg.: logischer Ausdruck in K-CNF (n Variablen, m Klauseln, k Variablen pro Klausel)
for i in range (trials): #Anzahl der Versuche
#Bestimme eine Zufallsbelegung des
:
for j in range (steps):
if
erfüllt alle Klauseln: return
#wähle zufällig eine Klausel, die nicht erfüllt ist und negiere zufällig eine der Variablen in dieser Klausel
(die Klausel ist jetzt erfüllt)
return None
Eigenschaft: falls
: steps *trials
z.B.
steps=3*n, trials=
aber: bei
sind im Mittel nur steps=
nötig, trials=
-Zufallsbelegung hat
richtige Variablen (im Mittel
)
Negieren einer Variable ändert t um 1,
u.Z.
mit Wahrscheinlichkeit
:: (für beliebiges k:
)
mit Wahrscheinlichkeit
:: (für beliebiges k:
)
-Wieviele Schritte braucht man im Mittel, um zu einer Lösung mit t Richtigen zu kommen?
![]()
#Abbruchbedingung der Schleife
![]()
Probe:![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
Das ist das Random Walk Problem
Im ungünstigsten Fall (t=0) werden im Mittel
Schritte benötigt, um durch random walk nach t=n zu gelangen.
2. RANSAC-ALGORITHMUS (Random Sample Consensus)
Aufgabe: gegeben: Datenpunkte
- gesucht: Modell, das die Datenpunkte erklärt
Messpunkte
übliche Lösung: Methode der kleinsten Quadrate
Schulmathematik:
pod gesucht: RANSAC
- Problem:
der Datenpunkte sind Outlier
Einfaches Anpassen des Modells an die Datenpunkte funktioniert nicht
- Seien mindestens k Datenpunkte notwendig, um das Programm anpassen zu können
RANSAC-Algorithmus
for l in range (trials):
wähle zufällig k Punkte aus
passe das Modell an die k Punkte an
zähle, wieviele Punkte in der Nähe des Modells liegen (d.h.
muss geschickt gewählt werden)
#Bsp. Geradenfinden:-wähle a,b aus zwei Punkten
-berechne:
-zähle Punkt i als Inlier, falls
return: Modell mit höchster Zahl der Inlier
-mit k=Anzahl der Datenpunkte und p=Erfolgswahrscheinlichkeit,
=Outlier-Anteil
Failed to parse (Missing <code>texvc</code> executable. Please see math/README to configure.): \begin{array}{|c||c|c|c|c|c|} Beispiel & k & \Epsilon=10% & 20% & 50% & 70%\\ \hline linie in 2D & 2 & 3 &5 & 17 & 49\\ Kreis in 2D & 3 & 4 & 7 & 35 & 169\\ Ebene in 3D & 8 & 9 & 26 & 1172 & 70188\\
#Abbruchbedingung der Schleife
mit k=Anzahl der Datenpunkte und p=Erfolgswahrscheinlichkeit,
=Outlier-Anteil