Idempotenz

An/Aus Knöpfe eines Zuges Zielzeichen Schalttafel. Drücken Sie die An Taste (grün) ist eine idempotente Operation, da sie den gleichen Effekt hat, unabhängig davon, ob es einmal oder mehrmals ausgeführt wird. Ebenso drücken Aus ist idempotent.

Idempotenz (Vereinigtes Königreich: /ˌɪdɛmˈptəns/,[1] UNS: /ˈdəm-/)[2] ist das Eigentum von bestimmt Operationen in Mathematik und Informatik wobei sie mehrmals angewendet werden können, ohne das Ergebnis über die anfängliche Anwendung hinaus zu ändern. Das Konzept der Idempotenz ergibt sich an einer Reihe von Orten an Zusammenfassung Algebra (insbesondere in der Theorie von Projektoren und Verschlussbetreiber) und Funktionelle Programmierung (in dem es mit der Eigenschaft von verbunden ist Referenztransparenz).

Der Begriff wurde vom amerikanischen Mathematiker eingeführt Benjamin Peirce 1870[3] im Kontext von Elementen von Algebren, die in einer positiven ganzzahligen Kraft invariant bleiben und wörtlich "(die Qualität der gleichen Kraft) der gleichen Kraft" bedeutet idem + Potenz (gleiche + Kraft).

Definition

Ein Element eines Satzes ausgestattet mit einem Binärbetreiber wird gesagt, dass idempotent unter wenn[4][5]

.

Das Binäroperation wird gesagt, dass idempotent wenn[6][7]

für alle .

Beispiele

  • In dem Monoid des natürliche Zahlen mit Multiplikation, nur 0 und 1 sind idempotent. In der Tat, und , was nicht für andere natürliche Zahlen gilt.
  • In einem Magma , ein Identitätselement oder an absorbierendes Element , wenn es existiert, ist idempotent. In der Tat, und .
  • In einem Gruppe , das Identitätselement ist das einzige idempotente Element. In der Tat, wenn ist ein Element von so dass , dann und schlussendlich durch multiplizieren links von der umgekehrtes Element von .
  • In den Monoiden und des Leistungssatz des Satzes mit Set Union und Schnittpunkt setzen beziehungsweise, und sind idempotent. In der Tat, für alle , und für alle .
  • In den Monoiden und des Boolesche Domain mit logische Disjunktion und logische Konjunktion beziehungsweise, und sind idempotent. In der Tat, für alle , und für alle .
  • In einem Boolean Ring, Multiplikation ist idempotent.
  • In einem Tropical SemingAddition ist idempotent.

Idempotente Funktionen

Im Monoid des Funktionen von einem Set für sich selbst mit Funktionszusammensetzung , idempotente Elemente sind die Funktionen so dass ,[8] das ist so, dass für alle (Mit anderen Worten das Bild von jedem Element ist ein Fixpunkt von ). Zum Beispiel:

Wenn das Set hat Elemente, wir können es aufteilt ausgewählte Fixpunkte und Nicht fixierte Punkte unter , und dann ist die Anzahl der verschiedenen idempotenten Funktionen. Daher berücksichtigen Sie alle möglichen Partitionen,

ist die Gesamtzahl möglicher idempotenter Funktionen auf dem Satz. Das Ganzzahlsequenz der Anzahl der idempotenten Funktionen n = 0, 1, 2, 3, 4, 5, 6, 7, 8, ... beginnt mit 1, 1, 3, 10, 41, 196, 1057, 6322, 41393, ... (Sequenz A000248 in dem Oeis).

Weder die Eigenschaft, idempotent zu sein noch nicht zu sein, wird unter Funktionszusammensetzung bewahrt.[9] Als Beispiel für erstere, Mod 3 und sind beide idempotent, aber ist nicht,[10] obwohl ist zufälligerweise.[11] Als Beispiel für letztere die Negationsfunktion Auf der Booleschen Domain ist nicht idempotent, sondern ist. In ähnlicher Weise die Unary Negation realer Zahlen ist nicht idempotent, sondern ist. In beiden Fällen ist die Zusammensetzung einfach die Identitätsfunktion, was idempotent ist.

Informatik Bedeutung

Im Informatik, der Begriff idempotenz kann je nach Kontext, in dem es angewendet wird, eine andere Bedeutung haben:

Dies ist in vielen Situationen eine sehr nützliche Eigenschaft, da eine Operation so oft wie nötig wiederholt oder wiederholt werden kann, ohne unbeabsichtigte Auswirkungen zu verursachen. Bei nicht-idempotenten Operationen muss der Algorithmus möglicherweise verfolgen, ob der Betrieb bereits ausgeführt wurde oder nicht.

Beispiele für Informatik

Eine Funktion, die den Namen und die Adresse eines Kunden in a nachschlagen Datenbank ist normalerweise idempotent, da sich die Datenbank nicht ändert. In ähnlicher Weise ist eine Anfrage zur Änderung der Adresse eines Kunden in XYZ in der Regel idempotent, da die endgültige Adresse gleich ist, egal wie oft die Anfrage eingereicht wird. Eine Kundenanfrage zur Aufgabe einer Bestellung ist jedoch in der Regel nicht idemPotent, da mehrere Anfragen zu mehreren Bestellungen führen. Eine Anfrage zur Stornierung einer bestimmten Bestellung ist idempotent, da unabhängig davon, wie viele Anfragen die Bestellung gestellt werden, storniert bleibt.

Eine Sequenz von idempotenten Subroutinen, bei denen sich mindestens eine Unterroutine von den anderen unterscheidet, ist jedoch nicht unbedingt idempotent, wenn eine spätere Unterroutine in der Sequenz einen Wert ändert, von dem ein früherer Unterprogramm abhängt -Idempotenz wird unter sequentieller Zusammensetzung nicht geschlossen. Nehmen wir beispielsweise an, der Anfangswert einer Variablen beträgt 3 und es gibt eine Subroutine -Sequenz, die die Variable liest, sie dann auf 5 ändert und dann erneut liest. Jeder Schritt in der Sequenz ist idempotent: Beide Schritte Das Lesen der Variablen haben keine Nebenwirkungen und der Schritt, der die Variable in 5 ändert, hat immer den gleichen Effekt, egal wie oft sie ausgeführt wird. Dennoch erzeugt die Ausführung der gesamten Sequenz einmal die Ausgabe (3, 5), erzeugt sie jedoch ein zweites Mal die Ausgabe (5, 5), sodass die Sequenz nicht idempotent ist.

int x = 3; Leere lesen() { printf("%d\n", x); } Leere Rückgeld() { x = 5; } Leere Reihenfolge() { lesen(); Rückgeld(); lesen(); } int hauptsächlich() {   Reihenfolge();  // Drucke "3 \ n5 \ n"   Reihenfolge();  // Drucke "5 \ n5 \ n"   Rückkehr 0; } 

In dem Hypertext Transfer Protocol (Http), idempotence und Sicherheit sind die Hauptattribute, die sich trennen HTTP -Methoden. Von den wichtigsten HTTP -Methoden sollte Get, Put und Löschen nach dem Standard auf idempotentes Implementieren implementiert werden, aber Post muss es nicht sein.[12] Holen Sie sich den Zustand einer Ressource ab; Aktualisierung des Zustands einer Ressource; und löschen löscht eine Ressource. Wie im obigen Beispiel haben Lesendaten normalerweise keine Nebenwirkungen, so dass sie idempotent sind (in der Tat nullipotent). Das Aktualisieren und Löschen einer bestimmten Daten ist in der Regel idempotent, solange die Anfrage die Ressource und nur diese Ressource in Zukunft wieder identifiziert. Setzen und löschen mit eindeutigen Kennungen, die auf den einfachen Fall der Zuordnung zu einer Variablen eines Werts oder des Null-Werts reduzieren, und sind aus dem gleichen Grund idempotent; Das Endergebnis ist immer das gleiche wie das Ergebnis der anfänglichen Ausführung, auch wenn sich die Antwort unterscheidet.[13]

Verstöße gegen die eindeutige Identifikationsanforderung bei der Lagerung oder Löschung verursachen typischerweise Verstoß gegen die Idempotenz. Zum Beispiel das Speichern oder Löschen eines bestimmten Inhaltssatzes ohne Angabe einer eindeutigen Kennung: Postanforderungen, die nicht idempotent sein müssen, enthalten häufig keine eindeutigen Kennungen, sodass die Erstellung der Kennung an das Empfangssystem delegiert wird, das dann erstellt wird ein entsprechender neuer Datensatz. In ähnlicher Weise können Put- und Löschen von Anforderungen mit unspezifischen Kriterien je nach Status des Systems zu unterschiedlichen Ergebnissen führen - beispielsweise eine Anfrage zum Löschen des neuesten Datensatzes. In jedem Fall werden nachfolgende Ausführungen den Status des Systems weiter ändern, sodass sie nicht idemPotent sind.

Im Ereignisstromverarbeitung, ideMpotence bezieht sich auf die Fähigkeit eines Systems, das gleiche Ergebnis zu erzielen, auch wenn dieselbe Datei, Ereignis oder Nachricht mehr als einmal empfangen wird.

In einem Last -Store -Architektur, Anweisungen, die möglicherweise a verursachen könnten Seitenfehler sind idempotent. Also, wenn ein Seitenfehler auftritt, die Betriebssystem Kann die Seite von der Festplatte laden und dann die fehlerhafte Anweisung einfach erneut ausführen. In einem Prozessor, bei dem solche Anweisungen nicht idempotent sind, ist der Umgang mit Seitenfehlern viel komplexer.[14][15]

Bei der neu formating outpution, ziemlich gedruckt wird erwartet, dass es idempotent ist. Mit anderen Worten, wenn die Ausgabe bereits "hübsch" ist, sollte es für den hübschen Drucker nichts zu tun haben.

Im Serviceorientierte Architektur (SOA) kann ein ausschließlich aus idempotenter Schritten bestehender mehrstufiger Orchestrierungsprozess ohne Nebenwirkungen wiedergegeben werden, wenn ein Teil dieses Prozesses fehlschlägt.

Viele Operationen, die idempotent sind, haben oft Möglichkeiten, einen Prozess zu "wieder aufnehmen", wenn er unterbrochen wird - Möglichkeiten, die viel schneller abschließen als von Anfang an von vorne zu beginnen. Zum Beispiel, Wiederaufnahme einer DateiübertragungAnwesendDateien synchronisieren, ein ... Erstellen Software Buildinstallieren eine Anwendung und alle ihre Abhängigkeiten mit a Paket-Manager, etc.

Angewandte Beispiele

Ein typischer Zergastknopf ist ein Beispiel für ein idempotentes System

Angewandte Beispiele, auf die viele Menschen in ihrem täglichen Leben begegnen könnten Aufzug Rufen Sie Knöpfe an und Zergrohrknöpfe.[16] Die anfängliche Aktivierung der Taste verschiebt das System in einen anspruchsvollen Status, bis die Anfrage erfüllt ist. Nachfolgende Aktivierungen der Taste zwischen der anfänglichen Aktivierung und der erfüllten Anforderung haben keinen Einfluss, es sei denn, das System ist so konzipiert, dass die Zeit für die Erfüllung der Anforderung basierend auf der Anzahl der Aktivierungen angepasst wird.

Siehe auch

Verweise

  1. ^ "idempotence". Oxford Englisch Wörterbuch (3. Aufl.). Oxford University Press. 2010.
  2. ^ "idempotent". Merriam-Webster. Archiviert vom Original am 2016-10-19.
  3. ^ Polcino & Sehgal 2002, p.127.
  4. ^ Valenza, Robert (2012). Lineare Algebra: Eine Einführung in die abstrakte Mathematik. Berlin: Springer Science & Business Media. p. 22. ISBN 9781461209010. Ein Element s eines Magmas so das ss = s wird genannt idempotent.
  5. ^ Doneddu, Alfred (1976). Polynômes et algèbre linéaire (auf Französisch). Paris: Vuibert. p. 180. So dass es M UN Magma, Noté multiplicativement. Auf nomme idempotent de M Tout Élément a de M Tel Que a2 = a.
  6. ^ George Grätzer (2003). Allgemeine Gittertheorie. Basel: Birkhäuser. Hier: Abschn. 1.2, S. 5.
  7. ^ Garrett Birkhoff (1967). Gittertheorie. Kolloquiumpublikationen. Vol. 25. Providence: Am. Mathematik. SOC.. Hier: Sect.I.5, S.8.
  8. ^ Dies ist eine Gleichung zwischen Funktionen. Zwei Funktionen sind gleich, wenn ihre Domänen und Bereiche zustimmen und ihre Ausgabewerte auf ihre gesamte Domäne einverstanden sind.
  9. ^ Wenn und pendeln unter Zusammensetzung (d. H. Wenn ) dann idempotenz von beidem und impliziert das von , seit unter Verwendung der Assoziativität der Zusammensetzung.
  10. ^ z.B. , aber
  11. ^ Auch zeigen diese Kommutierung von und ist kein notwendige Bedingung Für die Erhaltung der Idempotenz
  12. ^ Ietf, Hypertext -Transferprotokoll (HTTP/1.1): Semantik und Inhalt Archiviert 2014-06-08 bei der Wayback -Maschine. Siehe auch Hypertext Transfer Protocol.
  13. ^ "Idempotente Methoden". Hypertext -Transferprotokoll (HTTP/1.1): Semantik und Inhalt. Sek. 4.2.2. doi:10.17487/rfc7231. RFC 7231. Es weiß, dass die Wiederholung der Anfrage den gleichen beabsichtigten Effekt hat, auch wenn die ursprüngliche Anfrage erfolgreich war, obwohl sich die Antwort unterscheiden könnte.
  14. ^ John outsterhout."Paging fordern".
  15. ^ Marc A. de Kruijf."Compiler -Konstruktion von idempotenten Regionen und Anwendungen im Architekturdesign". 2012. p. 10.
  16. ^ https://web.archive.org/web/20110523081716/http://www.nclabor.com/elevator/geartrac.pdf Diese Entwurfsspezifikation enthält beispielsweise einen detaillierten Algorithmus, wenn Aufzugsautos auf nachfolgende Aufforderungen nach Service reagieren werden

Weitere Lektüre