<?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=Logische_Programmierung</id>
	<title>Logische Programmierung - 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=Logische_Programmierung"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Logische_Programmierung&amp;action=history"/>
	<updated>2026-05-25T03:11:56Z</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=Logische_Programmierung&amp;diff=138965&amp;oldid=prev</id>
		<title>imported&gt;Thomas Dresler: Reference-Tag eingefügt</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Logische_Programmierung&amp;diff=138965&amp;oldid=prev"/>
		<updated>2022-03-06T08:52:08Z</updated>

		<summary type="html">&lt;p&gt;Reference-Tag eingefügt&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;Logische Programmierung&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;Prädikative Programmierung, Logikprogrammierung&amp;#039;&amp;#039;&amp;lt;ref&amp;gt;{{Internetquelle |url=https://www.informatik.uni-kiel.de/~mh/lehre/lp03.html |titel=Logikprogrammierung |abruf=2022-03-05}}&amp;lt;/ref&amp;gt;) ist ein [[Programmierparadigma]], das auf der [[Mathematische Logik|mathematischen Logik]] beruht. Anders als bei der [[Imperative Programmierung|imperativen Programmierung]] besteht ein Logik-Programm nicht aus einer Folge von Anweisungen, sondern aus einer Menge von [[Axiom]]en, welche hier als eine Ansammlung von Fakten oder Annahmen zu verstehen ist. Stellt der Benutzer eines Logik-Programms eine Anfrage, so versucht der [[Interpreter]], die Lösungsaussage allein aus den Axiomen zu berechnen.&lt;br /&gt;
&lt;br /&gt;
Dazu werden eine Menge von so genannten &amp;#039;&amp;#039;Regeln&amp;#039;&amp;#039; und Anweisungen, die der Syntax gemäß aufgebaut sind zusammen mit der Information, welche Lösungsmethode vorgesehen ist, in den Programmcode eingefügt. Logische Programmiersprachen gehören zu den [[Deklarative Programmierung|deklarativen Programmiersprachen]] und haben ihre Ursprünge im Forschungsgebiet [[Künstliche Intelligenz]].&lt;br /&gt;
&lt;br /&gt;
In einem [[Imperative Programmiersprache|imperativen Programm]] wird genau beschrieben, wie und in welcher Reihenfolge ein Problem zu lösen ist. Im Gegensatz dazu wird in einem logikbasierten Programm beschrieben, was gilt. Das Wie ist durch die Lösungsmethode vorgegeben. Die Lösung wird aus den Regeln [[Deduktion|hergeleitet]].&lt;br /&gt;
&lt;br /&gt;
Die bekannteste logische Programmiersprache ist [[Prolog (Programmiersprache)|Prolog]]. Zu den Begründern der logischen Programmierung zählten in den 1970er Jahren [[Alain Colmerauer]] und [[Robert Kowalski]].&lt;br /&gt;
&lt;br /&gt;
== Erläuterungen ==&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;Syntax&amp;#039;&amp;#039;&amp;#039; gibt an, wie Regeln geschrieben werden müssen, damit der Computer sie verwenden kann. &amp;#039;&amp;#039;&amp;#039;Regeln&amp;#039;&amp;#039;&amp;#039; sind Wenn-Dann-Aussagen und Fakten, die das Wissen zu einem Problemkreis beschreiben. Daneben gibt es spezielle Konstrukte, um die Lösungsmethode zu beeinflussen. Am bekanntesten ist die Rückwärtsabschneidung (engl. &amp;#039;&amp;#039;cut&amp;#039;&amp;#039;) in Prolog, womit z.&amp;amp;nbsp;B. Ausnahmeregeln modelliert werden.&lt;br /&gt;
&lt;br /&gt;
Einem regelbasierten Programm kann man &amp;#039;&amp;#039;&amp;#039;Fragen&amp;#039;&amp;#039;&amp;#039; (engl. &amp;#039;&amp;#039;query&amp;#039;&amp;#039;) stellen, indem man ein &amp;#039;&amp;#039;&amp;#039;Ziel&amp;#039;&amp;#039;&amp;#039; (engl. &amp;#039;&amp;#039;goal&amp;#039;&amp;#039;) vorgibt. &lt;br /&gt;
&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;Lösungsmethode&amp;#039;&amp;#039;&amp;#039; gibt vor, wie die Inferenzmaschine die Regeln interpretiert, um die Frage zu beantworten. In Prolog wird eine [[Tiefensuche]] (engl. &amp;#039;&amp;#039;depth first&amp;#039;&amp;#039;) mit [[Unifikation (Logik)|Unifikation]] und [[Backtracking]] verwendet. Auch andere Methoden sind geeignet und werden je nach Anwendungsfall auch eingesetzt.&lt;br /&gt;
&lt;br /&gt;
== Beispiel ==&lt;br /&gt;
Dieses Beispiel ist in natürlicher Sprache formuliert, um das Prinzip aufzuzeigen. &lt;br /&gt;
&lt;br /&gt;
Fakten:&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;Lucia ist die Mutter von Minna.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;Lucia ist die Mutter von Klaus.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;Minna ist die Mutter von Nadine.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Regel:&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;&amp;#039;Falls&amp;#039;&amp;#039;&amp;#039; &amp;#039;&amp;#039;X ist die Mutter von Y&amp;#039;&amp;#039; &amp;#039;&amp;#039;&amp;#039;und&amp;#039;&amp;#039;&amp;#039; &amp;#039;&amp;#039;Y ist die Mutter von Z&amp;#039;&amp;#039; &amp;#039;&amp;#039;&amp;#039;Dann&amp;#039;&amp;#039;&amp;#039; &amp;#039;&amp;#039;X ist die Großmutter von Z.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Frage/Ziel:&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;Wer ist die Großmutter von Nadine?&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Antwort des Computers, Folgerung aus den Fakten und Regeln:&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;Lucia&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
== Einsatzgebiete ==&lt;br /&gt;
&lt;br /&gt;
{{Belege fehlen|Dieser Abschnitt hat keine Belege. --[[Benutzer:8Paule|8Paule]] ([[Benutzer Diskussion:8Paule|Diskussion]]) 21:34, 20. Nov. 2019 (CET)}}&lt;br /&gt;
&lt;br /&gt;
Typische Einsatzgebiete sind Simulatoren, Generatoren, sowie Systeme zur Diagnose und Prognose. Anwendungen der Logikprogrammierung finden sich in folgenden Bereichen:&lt;br /&gt;
&lt;br /&gt;
* [[Künstliche Intelligenz]]&lt;br /&gt;
* [[Datenbank]]en&lt;br /&gt;
* [[Expertensystem]]e&lt;br /&gt;
&lt;br /&gt;
Beispiele außerhalb der Informatik:&lt;br /&gt;
* [[Wirtschaft]] und [[Handel]]: Produktkonfigurator, Routenplaner, Marktsimulation (z.&amp;amp;nbsp;B. zur Preisfindung)&lt;br /&gt;
* [[Medizin]]: Diagnosesysteme&lt;br /&gt;
* [[Mathematik]]: Theorembeweiser und Theoremgeneratoren&lt;br /&gt;
* [[Naturwissenschaft]]en: Auswerten und Abfragen geologischer und meteorologischer Datensammlungen, Simulatoren und Vorhersagesysteme für Wetter, Erdbeben und Wasserstände&lt;br /&gt;
* [[Technik]]: [[Computer-aided design|CAD]], [[Computer-aided manufacturing|CAM]]&lt;br /&gt;
* [[Soziologie]]&lt;br /&gt;
* [[Psychologie]]&lt;br /&gt;
* [[Computerlinguistik]]: Maschinelles Übersetzen natürlicher Sprache, Erkennen und Verstehen gesprochener Sprache&lt;br /&gt;
* und viele weitere&lt;br /&gt;
&lt;br /&gt;
Auf dem Gebiet der Informatik und Computertechnik:&lt;br /&gt;
* [[Computertechnik]]: Design und Simulation von Prozessoren und Schaltkreisen&lt;br /&gt;
* [[Compilerbau]]&lt;br /&gt;
* [[Computerspiel]]e: „intelligentes“ Verhalten simulierter Mitspieler, Taktik, Strategie&lt;br /&gt;
* [[parallele Datenverarbeitung]]&lt;br /&gt;
* [[Dokumentenmanagement]]: Strukturierte Dokumente verarbeiten, [[Semantisches Web]], [[XSLT]]&lt;br /&gt;
* [[Prototyping (Softwareentwicklung)|Rapid Prototyping]]&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [http://informatikdidaktik.de/HyFISCH/Spitzenforschung/Schaub.htm] – knapper Überblick von der Entwicklung der klassischen Logik hin zur logischen Programmierung (110 kB)&lt;br /&gt;
* [http://xsb.sourceforge.net/ XSB] (englisch) Logik-System und Deduktive Datenbank (Open Source)&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Programmierparadigma]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Thomas Dresler</name></author>
	</entry>
</feed>