<?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=Aggregat-Methode</id>
	<title>Aggregat-Methode - 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=Aggregat-Methode"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Aggregat-Methode&amp;action=history"/>
	<updated>2026-05-27T16:25:07Z</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=Aggregat-Methode&amp;diff=143634&amp;oldid=prev</id>
		<title>imported&gt;Fan-vom-Wiki am 15. Dezember 2024 um 12:03 Uhr</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Aggregat-Methode&amp;diff=143634&amp;oldid=prev"/>
		<updated>2024-12-15T12:03:23Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Die &amp;#039;&amp;#039;&amp;#039;Aggregat-Methode&amp;#039;&amp;#039;&amp;#039; (auch &amp;#039;&amp;#039;&amp;#039;Aggregationsmethode&amp;#039;&amp;#039;&amp;#039; oder &amp;#039;&amp;#039;&amp;#039;Ganzheitsmethode&amp;#039;&amp;#039;&amp;#039;) ist ein Vorgehen der [[Amortisierte Laufzeitanalyse|amortisierten (Laufzeit-)Analyse]]. Bei der Aggregat-Methode wird versucht die durchschnittlichen Kosten einer Einzeloperation zu ermitteln, indem man zunächst die Gesamtkosten aller Operationen ermittelt und diese dann durch die Anzahl der Operationen dividiert.&lt;br /&gt;
&lt;br /&gt;
== Beispiele ==&lt;br /&gt;
=== Binärzähler ===&lt;br /&gt;
Die Aggregat-Methode wird am Beispiel eines [[Dualsystem|Binärzählers]], dessen einzig mögliche Operation eine [[Inkrement und Dekrement|Inkrementation]] ist, durchgeführt.&lt;br /&gt;
&lt;br /&gt;
Der [[Worst Case]] bei einem Binärzähler mit &amp;#039;&amp;#039;k&amp;#039;&amp;#039; Bit tritt dann auf, wenn bei einer Inkrementation alle &amp;#039;&amp;#039;k&amp;#039;&amp;#039; Bit gekippt werden müssen. Seien die Kosten für einen Bitwechsel 1. Dann würden nach der Worst-Case-Abschätzung bei &amp;#039;&amp;#039;n&amp;#039;&amp;#039; Operationen Kosten von &amp;#039;&amp;#039;nk&amp;#039;&amp;#039; entstehen. Diese Abschätzung ist allerdings zu pessimistisch. Mittels der amortisierten Analyse wird versucht eine realistischere und weniger pessimistische Abschätzung der Kosten nach oben zu erreichen.&lt;br /&gt;
&lt;br /&gt;
Betrachten wir die Anzahl der Bitwechsel bei einem Zähler mit 4 Bit:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Zähler || Anzahl Bitwechsel&lt;br /&gt;
|-&lt;br /&gt;
| 0000 || -&lt;br /&gt;
|-&lt;br /&gt;
| 0001 || 1&lt;br /&gt;
|-&lt;br /&gt;
| 0010 || 2&lt;br /&gt;
|-&lt;br /&gt;
| 0011 || 1&lt;br /&gt;
|-&lt;br /&gt;
| 0100 || 3&lt;br /&gt;
|-&lt;br /&gt;
| 0101 || 1&lt;br /&gt;
|-&lt;br /&gt;
| 0110 || 2&lt;br /&gt;
|-&lt;br /&gt;
| 0111 || 1&lt;br /&gt;
|-&lt;br /&gt;
| 1000 || 4&lt;br /&gt;
|-&lt;br /&gt;
| ... ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Wenn man sich die Folge der Bitwechsel anschaut, fällt auf, dass sich das niedrigste Bit bei jeder Inkrementation ändert, das nächsthöhere bei jeder zweiten, das wiederum nächsthöhere bei jeder vierten usw. Damit ergibt sich bei &amp;#039;&amp;#039;n&amp;#039;&amp;#039; Inkrementationen folgende Summe von Bitwechseln:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div style=&amp;quot;text-align:center;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;math&amp;gt; n + \left\lfloor\frac{n}{2}\right\rfloor +&lt;br /&gt;
  \left\lfloor\frac{n}{2^2}\right\rfloor +&lt;br /&gt;
  \left\lfloor\frac{n}{2^3}\right\rfloor + \cdots +&lt;br /&gt;
  \left\lfloor\frac{n}{2^k}\right\rfloor&lt;br /&gt;
  \leq n \sum_{i=0}^k \frac{1}{2^i}&amp;lt;/math&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Diese Summe können wir nach oben abschätzen:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div style=&amp;quot;text-align:center;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;math&amp;gt;n \sum_{i=0}^k \frac{1}{2^i} \leq n \sum_{i=0}^\infty \frac{1}{2^i}&amp;lt;/math&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Die Summe dieser [[unendliche Reihe|unendlichen Reihe]] ist wohlbekannt und lautet 2. Daraus folgt:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div style=&amp;quot;text-align:center;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;math&amp;gt;n \sum_{i=0}^k \frac{1}{2^i} \leq 2n&amp;lt;/math&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Betrachten wir nun die amortisierten Kosten &amp;lt;math&amp;gt;a_i&amp;lt;/math&amp;gt; für eine einzelne Operation &amp;lt;math&amp;gt;Op_i&amp;lt;/math&amp;gt; der insgesamt &amp;#039;&amp;#039;n&amp;#039;&amp;#039; Operationen, indem wir die bereits ermittelten Gesamtkosten durch die Anzahl &amp;#039;&amp;#039;n&amp;#039;&amp;#039; der Operationen teilen, erhalten wir:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div style=&amp;quot;text-align:center;&amp;quot;&amp;gt;&amp;lt;math&amp;gt;a_i \leq \frac{2n}{n} = 2&amp;lt;/math&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Damit sind die amortisierten Kosten für eine Operation höchstens 2 und somit in [[Landau-Symbol|O]](1), egal, wie viele Bits der Zähler insgesamt hat.&lt;br /&gt;
&lt;br /&gt;
=== Wörterbuch ===&lt;br /&gt;
Eine außerordentlich verbreitete Sorte von Datenstrukturen sind die binären Suchbäume. Sie lösen bspw. das “Wörterbuch”problem (s. [[Binärer Suchbaum#Motivation]]), und zwar die balancierten unter ihnen die wichtigsten Operationen im schlechtesten Fall (&amp;#039;&amp;#039;worst case&amp;#039;&amp;#039;) in logarithmischer Zeit. Eine Aussage über amortisiertes Laufzeitverhalten findet sich ggf. im entsprechenden Artikel.&lt;br /&gt;
&lt;br /&gt;
Hier werde eine Datenstruktur, genannt &amp;#039;&amp;#039;amortisierte Wörterbuch-Datenstruktur&amp;#039;&amp;#039; (englisch &amp;#039;&amp;#039;amortized dictionary data structure&amp;#039;&amp;#039;&amp;lt;ref name=CMU&amp;gt;{{cite web|title=Lecture 7: Amortized Analysis|url=https://www.cs.cmu.edu/afs/cs/academic/class/15451-s07/www/lecture_notes/lect0206.pdf|website=https://www.cs.cmu.edu/|accessdate=2016-10-04|language=en}}&amp;lt;/ref&amp;gt;), vorgestellt, deren amortisiertes Laufzeitverhalten für das Suchen in {{nowrap|&amp;#039;&amp;#039;O&amp;#039;&amp;#039;(log&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt; &amp;#039;&amp;#039;n&amp;#039;&amp;#039;)}} und für das Einfügen in {{nowrap|&amp;#039;&amp;#039;O&amp;#039;&amp;#039;(log &amp;#039;&amp;#039;n&amp;#039;&amp;#039;)}} ist.&lt;br /&gt;
&lt;br /&gt;
Die Anzahl &amp;#039;&amp;#039;n&amp;#039;&amp;#039; der Einträge sei in der binären Darstellung:&lt;br /&gt;
:&amp;lt;math&amp;gt;n=:\sum_{i=0}^k \lambda_i 2^i&amp;lt;/math&amp;gt; mit &amp;lt;math&amp;gt;\lambda_i\in \{0,1\}&amp;lt;/math&amp;gt;&lt;br /&gt;
Die Datenstruktur besteht dann aus &amp;#039;&amp;#039;k&amp;#039;&amp;#039;+1 sortierten Folgen, die entweder ganz leer (&amp;amp;lambda;&amp;lt;sub&amp;gt;i&amp;lt;/sub&amp;gt;=0) oder ganz voll (&amp;amp;lambda;&amp;lt;sub&amp;gt;i&amp;lt;/sub&amp;gt;=1) sind. Die einzelnen Elemente der Datenstruktur werden beliebig auf diese Folgen verteilt.&lt;br /&gt;
&lt;br /&gt;
Beispiel:&lt;br /&gt;
Es sei &amp;#039;&amp;#039;n&amp;#039;&amp;#039; = 11 (dann ist 11 = 1 + 2 + 8 und &amp;#039;&amp;#039;k&amp;#039;&amp;#039; = 3). Die Elemente seien &amp;#039;&amp;#039;&amp;#039;C&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;D&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;E&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;F&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;H&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;J&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;M&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;P&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;S&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;W&amp;#039;&amp;#039;&amp;#039; und &amp;#039;&amp;#039;&amp;#039;Y&amp;#039;&amp;#039;&amp;#039;, die wie folgt über die Datenstruktur verteilt seien:&lt;br /&gt;
:{|&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;: || [&amp;#039;&amp;#039;&amp;#039;E&amp;#039;&amp;#039;&amp;#039;] || &amp;amp;lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt; = 1&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;: || [&amp;#039;&amp;#039;&amp;#039;D&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;H&amp;#039;&amp;#039;&amp;#039;] || &amp;amp;lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt; = 1&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;: || leer || &amp;amp;lambda;&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt; = 0&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;: || [&amp;#039;&amp;#039;&amp;#039;C&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;F&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;J&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;M&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;P&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;S&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;W&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;Y&amp;#039;&amp;#039;&amp;#039;] &amp;amp;nbsp; || &amp;amp;lambda;&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt; = 1&lt;br /&gt;
|}&lt;br /&gt;
Eine Suchoperation geschieht durch binäres Suchen in jeder Folge &amp;amp;Lambda;&amp;lt;sub&amp;gt;i&amp;lt;/sub&amp;gt; dar, plus einer logischen Zusammenfassung, so dass sich im schlechtesten Fall das Laufzeitverhalten&lt;br /&gt;
:&amp;lt;math&amp;gt;\sum_{i=0}^k \lambda_i \lceil \log(2^i+1) \rceil +k+1= \sum_{i=0}^k \lambda_i (i+1) +k+1&amp;lt;/math&amp;gt; = &amp;#039;&amp;#039;O&amp;#039;&amp;#039;(log&amp;lt;sup&amp;gt;2&amp;lt;/sup&amp;gt; &amp;#039;&amp;#039;n&amp;#039;&amp;#039;)&lt;br /&gt;
ergibt.&lt;br /&gt;
&lt;br /&gt;
Eine Einfügung verwendet [[Mergesort]], dessen Aufwand durch die Summe der beiden Längen gegeben ist. Um den Buchstaben &amp;#039;&amp;#039;&amp;#039;K&amp;#039;&amp;#039;&amp;#039; einzufügen, wird eine Folge &amp;amp;Lambda; der Länge 1 mit dem Inhalt &amp;#039;&amp;#039;&amp;#039;K&amp;#039;&amp;#039;&amp;#039; gebildet. Ist nun &amp;amp;Lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt; leer (Häufigkeit 1/2), machen wir &amp;amp;Lambda; zu &amp;amp;Lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt; und sind fertig. Wenn nicht (wie im obigen Beispiel) (Häufigkeit 1/2), mischen (englisch &amp;#039;&amp;#039;merge&amp;#039;&amp;#039;) wir &amp;amp;Lambda; mit &amp;amp;Lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt; mit Aufwand 1 + 1; der Name des Ergebnisses sei wieder &amp;amp;Lambda;. Ist dann &amp;amp;Lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt; leer (Häufigkeit 1/4), machen wir &amp;amp;Lambda; zu &amp;amp;Lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt; und sind fertig. Wenn nicht (Häufigkeit 1/4), mischen wir &amp;amp;Lambda; mit &amp;amp;Lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt; mit Aufwand 2 + 2 und neuem Namen &amp;amp;Lambda;. Ist dann &amp;amp;Lambda;&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt; leer (wie im obigen Beispiel) (Häufigkeit 1/8), machen wir &amp;amp;Lambda; zu &amp;amp;Lambda;&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt; und sind fertig. Wenn nicht (Häufigkeit 1/8), geht es weiter wie gehabt. Im obigen Beispiel ergibt die Einfügung von &amp;#039;&amp;#039;&amp;#039;K&amp;#039;&amp;#039;&amp;#039;:&lt;br /&gt;
:{|&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;: || leer || &amp;amp;lambda;&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt; = 0&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;: || leer || &amp;amp;lambda;&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt; = 0&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;: || [&amp;#039;&amp;#039;&amp;#039;D&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;E&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;H&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;K&amp;#039;&amp;#039;&amp;#039;] || &amp;amp;lambda;&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt; = 1&lt;br /&gt;
|-&lt;br /&gt;
| &amp;amp;Lambda;&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;: || [&amp;#039;&amp;#039;&amp;#039;C&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;F&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;J&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;M&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;P&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;S&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;W&amp;#039;&amp;#039;&amp;#039;,&amp;#039;&amp;#039;&amp;#039;Y&amp;#039;&amp;#039;&amp;#039;] &amp;amp;nbsp; || &amp;amp;lambda;&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt; = 1&lt;br /&gt;
|}&lt;br /&gt;
Der Gesamtaufwand ist maximal&lt;br /&gt;
:1/2·(1 + 1) + 1/4·(2 + 2) + ... + 2&amp;lt;sup&amp;gt;–&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;lt;/sup&amp;gt;·2&amp;lt;sup&amp;gt;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;lt;/sup&amp;gt; = &amp;#039;&amp;#039;k&amp;#039;&amp;#039; + 1 in {{nowrap|&amp;#039;&amp;#039;O&amp;#039;&amp;#039;(log &amp;#039;&amp;#039;n&amp;#039;&amp;#039;)}}&lt;br /&gt;
&lt;br /&gt;
;Ergebnis&lt;br /&gt;
Bei der vorgestellten Datenstruktur sind die amortisierten Kosten für eine Einfügung in {{nowrap|&amp;#039;&amp;#039;O&amp;#039;&amp;#039;(log &amp;#039;&amp;#039;n&amp;#039;&amp;#039;)}}.&lt;br /&gt;
&lt;br /&gt;
;Bemerkung&lt;br /&gt;
Sie sind damit nicht besser als bei [[AVL-Baum|AVL-]] oder [[Rot-Schwarz-Baum|Rot-Schwarz-Bäumen]], bei denen reine Einfügungen (reine Baumänderungen) amortisiert konstant sind, das Aufsuchen der Einfügeposition mit {{nowrap|&amp;#039;&amp;#039;O&amp;#039;&amp;#039;(log &amp;#039;&amp;#039;n&amp;#039;&amp;#039;)}} aber noch hinzugerechnet werden muss.&amp;lt;br/&amp;gt;Bemerkenswerterweise sind die Einfügekosten jedoch kleiner als zugehörige reine Suchkosten.&lt;br /&gt;
&lt;br /&gt;
== Abgrenzung ==&lt;br /&gt;
Im Gegensatz zur [[Account-Methode]] werden bei der Aggregat-Methode die amortisierten Kosten auch von unterschiedlichen Arten von Operationen gleichgesetzt. D. h., mit der Account-Methode können verschiedenen Arten von Operationen unterschiedliche amortisierte Kosten zugeordnet werden. Außerdem wird bei der Account-Methode die Differenz zwischen amortisierten und realen Kosten auf einem Konto gebucht.&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
&lt;br /&gt;
* {{Literatur| Autor=Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein | Titel=Introduction to Algorithms | Auflage=2. | Verlag=MIT Press and McGraw-Hill | Jahr=2001 | ISBN=0-262-03293-7 | Seiten=406–410 |Sprache=en}}&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Theoretische Informatik]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Fan-vom-Wiki</name></author>
	</entry>
</feed>