Idempotenz

Idempotenz ist ein Begriff aus der Mathematik und Informatik. In der Mathematik bezeichnet man ein Objekt a, das mit einer Verknüpfung \circ die Eigenschaft a\circ a=a hat, als idempotent bezüglich dieser Verknüpfung. Ein wichtiger Spezialfall sind idempotente Funktionen bezüglich der Hintereinanderausführung. Analog dazu wird in der Informatik ein Stück Programmcode, das mehrfach hintereinander ausgeführt das gleiche Ergebnis wie bei einer einzigen Ausführung liefert, als idempotent bezeichnet.

Definitionen

Idempotente Elemente

Ein Element a einer Menge X heißt idempotent bezüglich einer n-stelligen Verknüpfung v\colon X^{n}\rightarrow X,\,n\in \mathbb{N} und n>1, falls gilt:

v(a,\dotsc ,a)=a.

Erfüllt dagegen a für eine einstellige Verknüpfung f\colon X\rightarrow X die Gleichung

f(a)=a,

dann ist a ein Fixpunkt von f.

Idempotente Funktionen

Man nennt eine einstellige Verknüpfung oder Funktion f\colon \,X\rightarrow X idempotent, wenn sie bezüglich der Komposition idempotent ist:

f\circ f=f,

d.h. für alle x\in X ergibt eine zweimalige Anwendung von f den gleichen Wert wie die einmalige: f(f(x))=f(x).

Idempotente algebraische Strukturen

Sind alle Elemente einer Halbgruppe (oder allgemeiner eines Magmas) (S,*) idempotent bezüglich *, dann wird auch (S,*) selbst idempotent genannt. Alternativ wird eine idempotente Halbgruppe auch oft als ein Band bezeichnet. Jedes kommutative Band heißt Halbverband. Man nennt eine Halbgruppe (S,*) global idempotent, falls gilt:

S*S=S mit S*S:=\{a*b\mid a,b\in S\}.

Einen Halbring (H,+,\cdot ), einen Fastring (F,+,\cdot ) sowie einen Ring (R,+,\cdot ) bezeichnet man als idempotent, falls jeweils (H,\cdot ),(F,\cdot ) bzw. (R,\cdot ) idempotent ist. Im Gegensatz dazu ist ein Dioid (D,+,0,\cdot ,1) ein Hemiring mit Einselement und idempotenter Addition.

Beispiele

Idempotente Verknüpfungen:

3\cdot 3\equiv 3{\pmod  {6}} und 4\cdot 4\equiv 4{\pmod  {6}}.

Idempotente Abbildungen:

Eigenschaften

f_{A}\colon \,K^{n}\to K^{n},\;x\mapsto Ax,
idempotent ist. Insbesondere sind die Eigenwerte von A allesamt {\displaystyle 0} oder 1. Geometrisch können idempotente lineare Abbildungen als Projektion des Vektorraums auf einen Untervektorraum interpretiert werden.
a+0+b=a+b=(a+b)\cdot (a+b)=a\cdot (a+b)+b\cdot (a+b)=a\cdot a+a\cdot b+b\cdot a+b\cdot b=a+a\cdot b+b\cdot a+b,
(zweite und fünfte Gleichung wegen der Idempotenz, dritte und vierte Gleichung wegen der Distributivität), also
{\displaystyle 0=a\cdot b+b\cdot a.\quad (1)}
Damit gilt auch, indem man {\displaystyle a\leftarrow (a\cdot b)} und {\displaystyle b\leftarrow (a\cdot b)} setzt und wiederum die Idempotenz nutzt,
0=(a\cdot b)\cdot (a\cdot b)+(a\cdot b)\cdot (a\cdot b)=a\cdot b+a\cdot b.
Folglich ist
a\cdot b=a\cdot b+0=a\cdot b+a\cdot b+b\cdot a=0+b\cdot a=b\cdot a.
Insbesondere gilt auch (wegen der Idempotenz und wegen (1) mit {\displaystyle b=a})
a+a=a\cdot a+a\cdot a=0 bzw. \,-a=a.
Falls (F,+,\cdot ) kommutativ ist, gilt für alle a,b,c\in F\colon
c\cdot (a+b)=(a+b)\cdot c=(a\cdot c)+(b\cdot c)=(c\cdot a)+(c\cdot b).
Ist hingegen (F,+,\cdot ) distributiv, so folgt daraus genau so wie bei einem idempotenten Ring die Kommutativität.

Informatik

In der Informatik wird Idempotenz von Recovery-Maßnahmen bei Datenbanken und Diensten gefordert, um Fehlertoleranz bei einem Absturz während einer Wiederanlaufphase zu gewährleisten. Undo- und Redo-Operationen müssen hier auch bei mehrfacher Hintereinanderausführung dasselbe Resultat zur Folge haben.

Rein lesende Services sind von Natur aus idempotent, da der Zustand der Daten nicht geändert wird. Jeder nicht idempotente schreibende Service kann aus fachlicher Sicht zu einem idempotenten Service gemacht werden.

Beispiel

Bei einem Service zum Verbuchen von Geldbeträgen ist der Aufruf einzahlen(100) nicht idempotent, da bei mehrmaligem Service-Aufruf der Betrag 100 mehrmals eingezahlt wird. Würde man hingegen neuerKontostand(600) aufrufen, so würde bei mehrmaligem Service-Aufruf der Kontostand gleich bleiben. Dieser Aufruf wäre idempotent.

Trenner
Basierend auf einem Artikel in: Wikipedia.de
Seitenende
Seite zurück
©  biancahoegel.de
Datum der letzten Änderung:  Jena, den: 03.07. 2022