<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Boosting</id>
	<title>Boosting - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Boosting"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Boosting&amp;action=history"/>
	<updated>2026-05-25T01:56:05Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Boosting&amp;diff=528025&amp;oldid=prev</id>
		<title>2A02:908:175:1AA0:FC89:98FD:389E:C87F: /* Grundlagen */</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Boosting&amp;diff=528025&amp;oldid=prev"/>
		<updated>2023-02-10T09:48:32Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Grundlagen&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{Dieser Artikel | behandelt Boosting im Zusammenhang mit Informatik; zu Boosting als Abart von Doping siehe [[Boosting (Sport)]].}}&lt;br /&gt;
{{Belege fehlen|Artikel komplett unbelegt. --[[Spezial:Beiträge/217.186.67.100|217.186.67.100]] 17:16, 28. Okt. 2012 (CET)}}&lt;br /&gt;
&lt;br /&gt;
[[Datei:Klassifizierung.svg|mini|rechts|Klassifizierung in fünf Klassen. Der durch Boosting erzeugte Klassifikator klassifiziert nur in zwei Klassen.]]&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;&amp;#039;&amp;#039;Boosting&amp;#039;&amp;#039;&amp;#039;&amp;#039;&amp;#039; ([[Englische Sprache|engl.]] „Verstärken“) ist ein [[Ensemble learning|Ensemble-learning]]-Algorithmus, der mehrere aufeinander aufbauende [[Klassifikator|Klassifikations-]] oder [[Regressionsanalyse |Regressionsmodelle]] zu einem einzigen Modell verschmilzt. &lt;br /&gt;
Die Idee des Boosting wurde 1990 von [[Robert Schapire]] eingeführt.&amp;lt;ref&amp;gt;{{Literatur | Autor=Robert Schapire | Titel=The strength of weak learnability | Sammelwerk=Machine Learning | Band=5 | Nummer=2 | Jahr=1990 | Seiten=197-227 | DOI=10.1007/BF00116037}}&amp;lt;/ref&amp;gt; 1997 veröffentlichten [[Yoav Freund]] und Schapire den AdaBoost-Algorithmus.&amp;lt;ref&amp;gt;{{Literatur | Autor=Yoav Freund, Robert E Schapire | Titel=A Decision-Theoretic Generalization of On-Line Learning and an Application to Boosting | Sammelwerk=Journal of Computer and System Sciences | Band=55 | Nummer=1 | Jahr=1997 | Seiten=119-139 | DOI=10.1006/jcss.1997.1504}}&amp;lt;/ref&amp;gt; Der Name kommt von der Art, wie der Algorithmus mit den Fehlern der schwächeren Klassifizierer umgeht: Er passt sich diesen an (engl. „&amp;#039;&amp;#039;&amp;#039;ad&amp;#039;&amp;#039;&amp;#039;justs &amp;#039;&amp;#039;&amp;#039;a&amp;#039;&amp;#039;&amp;#039;daptively“), indem jedes nachfolgende Modell das vorhergehende Modell verbessert.&lt;br /&gt;
&lt;br /&gt;
== Bedeutung ==&lt;br /&gt;
Die Technik liefert akzeptable Ergebnisse und lässt sich einfach in ein [[Computerprogramm]] umsetzen, das sparsam im Speicherbedarf und schnell in der Laufzeit ist.&lt;br /&gt;
&lt;br /&gt;
== Funktionsweise ==&lt;br /&gt;
Vorgegeben ist eine Reihe von Objekten und eine Reihe schwacher Klassifikatoren. Gesucht ist ein Klassifikator, der die Objekte möglichst fehlerfrei in zwei Klassen einteilt. Boosting kombiniert die vorhandenen schwachen Klassifikatoren so, dass der entstehende neue Klassifikator möglichst wenige Fehler macht.&lt;br /&gt;
&lt;br /&gt;
Schwache Klassifikatoren, auch &amp;#039;&amp;#039;base classifiers&amp;#039;&amp;#039; (engl. „Basisklassifikatoren“) oder &amp;#039;&amp;#039;weak learners&amp;#039;&amp;#039; (engl. „schwache Lerner“) genannt, sind sehr einfach aufgebaut und berücksichtigen meist nur ein einziges Merkmal der Objekte. Für sich genommen liefern sie deswegen einerseits schlechte Ergebnisse, können aber andererseits sehr schnell ausgewertet werden. Boosting führt alle schwachen Klassifikatoren so mit einer Gewichtung zusammen, dass die stärkeren unter den schwachen Klassifikatoren besonders berücksichtigt, die wirklich schwachen hingegen ignoriert werden.&lt;br /&gt;
&lt;br /&gt;
=== Grundlagen ===&lt;br /&gt;
Gegeben ist ein Merkmalsraum &amp;lt;math&amp;gt;M&amp;lt;/math&amp;gt; beliebiger Dimension und darin eine Trainingsstichprobe &amp;lt;math&amp;gt;T&amp;lt;/math&amp;gt; der Größe &amp;lt;math&amp;gt;n&amp;lt;/math&amp;gt;, also eine Menge von Mustervektoren &amp;lt;math&amp;gt;x_1, \dots, x_n&amp;lt;/math&amp;gt;. Von jedem dieser Mustervektoren ist bekannt, in welche Klasse er gehört, das heißt zu jedem &amp;lt;math&amp;gt;x_i&amp;lt;/math&amp;gt; ist ein &amp;lt;math&amp;gt;y_i \in {+1, -1}&amp;lt;/math&amp;gt; gegeben, das angibt, in welche der beiden Klassen +1 oder −1 der Mustervektor gehört. Ferner sind &amp;lt;math&amp;gt;m&amp;lt;/math&amp;gt; primitive Klassifikatoren &amp;lt;math&amp;gt;f_1, f_2, \dots, f_m: M \rightarrow {+1, -1}&amp;lt;/math&amp;gt; gegeben, die jeweils den Merkmalsraum in die beiden Klassen &amp;lt;math&amp;gt;+1&amp;lt;/math&amp;gt; und &amp;lt;math&amp;gt;-1&amp;lt;/math&amp;gt; aufspalten.&lt;br /&gt;
&lt;br /&gt;
Gesucht sind die m Gewichtungsfaktoren &amp;lt;math&amp;gt;w_1, \dots, w_m&amp;lt;/math&amp;gt; des Klassifikators &amp;lt;math&amp;gt;F: M \rightarrow {+1, -1}&amp;lt;/math&amp;gt;, der über die [[Vorzeichenfunktion]] &amp;lt;math&amp;gt;\sgn&amp;lt;/math&amp;gt; durch&lt;br /&gt;
: &amp;lt;math&amp;gt;F(x) := \sgn\left(\sum_{i=1}^m w_i f_i(x)\right)&amp;lt;/math&amp;gt;&lt;br /&gt;
gegeben ist. Die Gewichtungsfaktoren sollen so optimiert werden, dass &amp;lt;math&amp;gt;F&amp;lt;/math&amp;gt; möglichst wenige Fehler macht.&lt;br /&gt;
&lt;br /&gt;
Für die Optimierung bietet sich eine über die [[Exponentialfunktion|Exponentialfunktion &amp;lt;math&amp;gt;\mathrm{e}&amp;lt;/math&amp;gt;]] definierte, sogenannte „exponentielle Verlustfunktion“ L als Optimierungskriterium an:&lt;br /&gt;
: &amp;lt;math&amp;gt; L := \frac{1}{n} \sum_{i=1}^n \mathrm{e}^{-y_i F(x_i)} \rightarrow \text{min}&amp;lt;/math&amp;gt;&lt;br /&gt;
&amp;lt;math&amp;gt;L&amp;lt;/math&amp;gt; wird umso kleiner, je weniger Objekte &amp;lt;math&amp;gt;F&amp;lt;/math&amp;gt; falsch klassifiziert. Das Ziel ist also, die Gewichtungsfaktoren so zu wählen, dass &amp;lt;math&amp;gt;L&amp;lt;/math&amp;gt; minimal wird.&lt;br /&gt;
&lt;br /&gt;
Diese Optimierung wird schrittweise über &amp;lt;math&amp;gt;m&amp;lt;/math&amp;gt; ausgeführt, das heißt zunächst wird nur &amp;lt;math&amp;gt;w_1&amp;lt;/math&amp;gt; optimiert, dann &amp;lt;math&amp;gt;w_2&amp;lt;/math&amp;gt;, dann &amp;lt;math&amp;gt;w_3&amp;lt;/math&amp;gt; und so weiter, bis alle Gewichtungsfaktoren optimal sind. Die Optimierung wird im nächsten Abschnitt erläutert.&lt;br /&gt;
&lt;br /&gt;
=== Schrittweise Optimierung ===&lt;br /&gt;
Die schrittweise Optimierung benötigt m Durchläufe, um alle Gewichtungsfaktoren für F zu optimieren. In jedem Durchlauf wird ein Klassifikator F&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; erzeugt, indem zum bisher erzeugten Klassifikator F&amp;lt;sub&amp;gt;s−1&amp;lt;/sub&amp;gt; ein schwacher Klassifikator hinzugenommen wird. Das bedeutet, dass der Benutzer die Berechnung nach jedem Durchlauf abbrechen kann, falls das Zwischenergebnis bereits seinen Ansprüchen genügt.&lt;br /&gt;
&lt;br /&gt;
Vor jedem Durchlauf wird beurteilt, welche Mustervektoren mit dem bislang erstellten Klassifikator gut eingeordnet werden können und welche nicht. Diejenigen Mustervektoren, die noch nicht gut klassifiziert werden, werden im nächsten Durchlauf besonders stark berücksichtigt. Dazu werden in jedem Durchlauf&amp;amp;nbsp;s n&amp;amp;nbsp;Hilfsvariablen t&amp;lt;sub&amp;gt;s,1&amp;lt;/sub&amp;gt;,&amp;amp;nbsp;…,&amp;amp;nbsp;t&amp;lt;sub&amp;gt;s,n&amp;lt;/sub&amp;gt; benötigt. Je höher der Wert von t&amp;lt;sub&amp;gt;s,i&amp;lt;/sub&amp;gt;, desto stärker geht der Mustervektor x&amp;lt;sub&amp;gt;i&amp;lt;/sub&amp;gt; in den aktuellen Durchgang ein.&lt;br /&gt;
&lt;br /&gt;
Die Nummer des Durchgangs ist s:&lt;br /&gt;
&lt;br /&gt;
1. &amp;#039;&amp;#039;&amp;#039;Gewichte aktualisieren.&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
: Im ersten Durchlauf (s = 1) werden alle Hilfsvariablen auf den Wert 1/n gesetzt: t&amp;lt;sub&amp;gt;1,1&amp;lt;/sub&amp;gt;,&amp;amp;nbsp;…,&amp;amp;nbsp;t&amp;lt;sub&amp;gt;1,n&amp;lt;/sub&amp;gt;:= 1/n; somit werden im ersten Durchgang alle Mustervektoren gleich stark berücksichtigt. In allen folgenden Durchläufen (s &amp;gt; 1) werden die Hilfsvariablen wie folgt gesetzt:&lt;br /&gt;
:: &amp;lt;math&amp;gt;t_{s,i} := t_{s-1,i} \mathrm{e}^{-y_i w_{s-1} f_{s-1}(x_i) }&amp;lt;/math&amp;gt;&lt;br /&gt;
: Damit werden alle Mustervektoren, die vom eben betrachteten schwachen Klassifikator f&amp;lt;sub&amp;gt;s−1&amp;lt;/sub&amp;gt; falsch klassifiziert wurden, in diesem Durchlauf mit einem besonders hohen Hilfsgewicht versehen, alle anderen mit einem besonders geringen.&lt;br /&gt;
&lt;br /&gt;
2. &amp;#039;&amp;#039;&amp;#039;Gewichteten Trainingsfehler bestimmen.&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
: In diesem Durchgang wird der schwache Klassifikator f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; hinzugenommen. Der „gewichtete Trainingsfehler“ ist ein Maß dafür, wie schlecht dieser primitive Klassifikator für sich genommen abschneidet. Für jeden von f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; falsch klassierten Mustervektor x&amp;lt;sub&amp;gt;i&amp;lt;/sub&amp;gt; summiert er die zugehörige Hilfsvariable t&amp;lt;sub&amp;gt;s,i&amp;lt;/sub&amp;gt; auf:&lt;br /&gt;
:: &amp;lt;math&amp;gt;err_s := \sum_{i: f_s(x_i) \ne y_i} t_{s,i}&amp;lt;/math&amp;gt;&lt;br /&gt;
: Ist der gewichtete Trainingsfehler 0, so klassifiziert f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; alle Mustervektoren richtig, ist er 1, so klassifiziert f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; alles falsch. Ist err&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; = 1/2, so klassifiziert f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; genauso gut, als würde er bei jedem Mustervektor bloß raten oder eine Münze werfen.&lt;br /&gt;
&lt;br /&gt;
3. &amp;#039;&amp;#039;&amp;#039;Nächsten Gewichtungsfaktor optimieren.&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
: Der Gewichtungsfaktor w&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; des in diesem Durchgang hinzugenommenen primitiven Klassifikators f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; wird aus der folgenden Formel bestimmt:&lt;br /&gt;
:: &amp;lt;math&amp;gt;w_s = \frac{1}{2} \log \left( \frac{1-err_s}{err_s} \right)&amp;lt;/math&amp;gt;&lt;br /&gt;
: Nach der Formel wird f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; genau dann mit positivem Gewicht zum Endergebnis hinzugenommen, wenn err&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt;&amp;amp;nbsp;&amp;lt;&amp;amp;nbsp;½ gilt, das heißt der schwache Klassifikator besser ist als bloßes Raten. Gilt exakt err&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt;&amp;amp;nbsp;=&amp;amp;nbsp;½, so folgt w&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt;&amp;amp;nbsp;=&amp;amp;nbsp;0, das heißt f&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; wird ignoriert. Gilt hingegen err&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt;&amp;amp;nbsp;&amp;gt;&amp;amp;nbsp;½, so ist der schwache Klassifikator durchaus brauchbar, er ist nur „falsch gepolt“, das heißt, er klassifiziert genau falsch herum; indem er mit einem negativen Gewicht hinzugenommen wird, kann dieser Formfehler ausgeglichen werden und der umgedrehte Klassifikator mit verstärkendem Effekt hinzugenommen werden.&lt;br /&gt;
&lt;br /&gt;
4. &amp;#039;&amp;#039;&amp;#039;Zwischenergebnis aufstellen.&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
: Das Zwischenergebnis F&amp;lt;sub&amp;gt;s&amp;lt;/sub&amp;gt; ergibt sich aus der Formel:&lt;br /&gt;
:: &amp;lt;math&amp;gt;F_s(x) := \sum_{i=1}^s w_i f_i(x)&amp;lt;/math&amp;gt;&lt;br /&gt;
: Es wird also genauso berechnet wie das eigentliche Ziel F, nur dass statt aller m schwachen Klassifikatoren nur die ersten s bereits optimierten berücksichtigt werden.&lt;br /&gt;
&lt;br /&gt;
Diese Schritte werden in dieser Reihenfolge wiederholt, bis alle schwachen Klassifikatoren berücksichtigt wurden, also s = m ist, oder der Benutzer den Fortgang abbricht.&lt;br /&gt;
&lt;br /&gt;
=== Schwache Klassifikatoren ===&lt;br /&gt;
Typische schwache Klassifikatoren sind sogenannte &amp;#039;&amp;#039;decision stumps&amp;#039;&amp;#039; (engl. „Entscheidungsstümpfe“). Diese Funktionen vergleichen den Wert einer einzelnen Koordinate j mit einem Schwellwert l und begründen damit ihre Entscheidung für +1 oder −1. Ist x:=&amp;amp;nbsp;(x&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;,&amp;amp;nbsp;…,&amp;amp;nbsp;x&amp;lt;sub&amp;gt;d&amp;lt;/sub&amp;gt;)&amp;amp;nbsp;∈&amp;amp;nbsp;M ein Mustervektor im d-dimensionalen Merkmalsraum&amp;amp;nbsp;M, so hat ein solcher primitiver Klassifikator&amp;amp;nbsp;f im Allgemeinen die Form:&lt;br /&gt;
: &amp;lt;math&amp;gt;f(x) = f((x_1, x_2, \dots, x_d)) := \begin{cases} +1 &amp;amp; \text{falls } x_j \geqslant l \\ -1 &amp;amp; \text{falls } x_j &amp;lt; l \end{cases}&amp;lt;/math&amp;gt;&lt;br /&gt;
Genauer gesagt unterteilt f den Merkmalsraum mit einer [[Hyperebene]] in zwei Klassen.&lt;br /&gt;
&lt;br /&gt;
Der Name spielt auf die Analogie zu [[Entscheidungsbaum|Entscheidungsbäumen]] an: Der erzeugte Gesamtklassifikator&amp;amp;nbsp;F kann als Entscheidungsbaum angesehen werden. Jeder schwache Klassifikator ist ein innerer Knoten dieses Baumes, an dem ein Unterbaum (vgl. engl. &amp;#039;&amp;#039;stump&amp;#039;&amp;#039;, „(Baum)Stumpf“) hängt. Die endgültige Klassifizierung in einem der Blätter des Baums wird als Folge binärer Entscheidungen (engl. &amp;#039;&amp;#039;decision&amp;#039;&amp;#039;) erreicht.&lt;br /&gt;
&lt;br /&gt;
Solche &amp;#039;&amp;#039;decision stumps&amp;#039;&amp;#039; sind als Grundlage für Boosting sehr beliebt, denn sie sind einfach zu handhaben und können extrem schnell ausgewertet werden. Zudem müssen sie nicht von Anfang an vorgegeben sein, sondern können erstellt werden, während der Algorithmus läuft.&lt;br /&gt;
&lt;br /&gt;
== Unterarten von Boosting ==&lt;br /&gt;
* [[AdaBoost]]&lt;br /&gt;
* [[AsymBoost]]&lt;br /&gt;
* [[BrownBoost]]&lt;br /&gt;
* [[DiscreteAB]]&lt;br /&gt;
* [[FloatBoost]]&lt;br /&gt;
* [[GentleAB]]&lt;br /&gt;
* [[GloBoost]]&lt;br /&gt;
* [[KLBoost]]&lt;br /&gt;
* [[LogitBoost]]&lt;br /&gt;
* [[RealAB]]&lt;br /&gt;
* [[WeightBoost]]&lt;br /&gt;
* [[GradientBoost]] (zum Beispiel [[XGBoost]])&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Bagging]]&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Klassifizierung]]&lt;br /&gt;
[[Kategorie:Multivariate Statistik]]&lt;/div&gt;</summary>
		<author><name>2A02:908:175:1AA0:FC89:98FD:389E:C87F</name></author>
	</entry>
</feed>