<?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=Advanced_Boolean_Equation_Language</id>
	<title>Advanced Boolean Equation Language - 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=Advanced_Boolean_Equation_Language"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Advanced_Boolean_Equation_Language&amp;action=history"/>
	<updated>2026-05-18T09:00:31Z</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=Advanced_Boolean_Equation_Language&amp;diff=595901&amp;oldid=prev</id>
		<title>imported&gt;Aka: Abkürzung korrigiert</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Advanced_Boolean_Equation_Language&amp;diff=595901&amp;oldid=prev"/>
		<updated>2023-03-25T21:16:07Z</updated>

		<summary type="html">&lt;p&gt;Abkürzung korrigiert&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;Advanced Boolean Equation Language&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;ABEL&amp;#039;&amp;#039;&amp;#039;) ist eine heute kaum noch genutzte [[Hardwarebeschreibungssprache]], die in der Digitaltechnik der 1980er und 1990er Jahre eingesetzt wurde, um einfache logische Schaltungen für Bausteine wie CPLDs ([[Complex Programmable Logic Device]]s) und für kleinere FPGAs ([[Field Programmable Gate Array]]) zu entwerfen. Die Beschreibung erfolgt mit booleschen Gleichungen, Wahrheitstafeln oder bedingten Zuweisungen. Bei Zustandsautomaten können die Zustandsübergänge als STATE_DIAGRAMM beschrieben werden. Während [[Verilog]] und [[Very High Speed Integrated Circuit Hardware Description Language|VHDL]] ursprünglich nur für die Schaltungssimulation konzipiert wurden, lag das Augenmerk bei der Konzeption von ABEL auf der automatischen und sehr hardwarenahen Generierung von Programmierfiles für CPLDs.&lt;br /&gt;
&lt;br /&gt;
ABEL wurde in den 1980er Jahren von der „Data I/O Corporation“ in Redmond (Washington) entwickelt. Nach einer Reihe von Verkäufen wird ABEL seit 1999 von [[Xilinx]] gepflegt.&amp;lt;ref&amp;gt;{{Webarchiv |url=http://www.xilinx.com/prs_rls/assets.htm |wayback=20000423140328 |text=&amp;#039;&amp;#039;XILINX Completes Purchase Of Software Assets&amp;#039;&amp;#039;.}} Presseerklärung&amp;lt;/ref&amp;gt; Heute wird ABEL nur noch wenig genutzt, da durch das Aufkommen leistungsfähiger [[Synthese (Elektrotechnik)|Synthesetools]] abstraktere Beschreibungen wie zum Beispiel in VHDL automatisch in Gatterlisten umgesetzt werden können. Für Schaltungen, die aus mehreren Hunderttausenden Logikgattern bestehen, ist die manuelle Beschreibung mit logischen Gleichungen wie in ABEL nicht praktikabel. Aber auch bei kleineren Schaltungen findet ABEL kaum noch Anwendung, da die komplette Funktionalität mit heute üblichen Hardwaresprachen wie VHDL oder Verilog abgedeckt werden kann.&lt;br /&gt;
&lt;br /&gt;
== ABEL-Syntax ==&lt;br /&gt;
&lt;br /&gt;
=== Programmaufbau ===&lt;br /&gt;
Ein Abelprogramm besteht aus verschiedenen Abschnitten, die durch entsprechende Schlüsselwörter (u.&amp;amp;nbsp;a. module, declarations, equations, truth_table, state_diagramm, test_vectors) eingeleitet werden. Pro Zeile sind maximal 150 Zeichen erlaubt. Alle Zeilen enden mit einem Semikolon.&lt;br /&gt;
&lt;br /&gt;
=== Reservierte Schlüsselworte ===&lt;br /&gt;
Es gibt ca. 30 Schlüsselworte, die nicht frei verwendet werden dürfen (z.&amp;amp;nbsp;B. if, else, istype, buffer, com, when, then, truth_table, equations, u.&amp;amp;nbsp;a.&amp;amp;nbsp;m.)&lt;br /&gt;
&lt;br /&gt;
==== Identifier (selbstdefinierte Signalbezeichner) ====&lt;br /&gt;
Identifier müssen mit einem Buchstaben oder Unterstrich beginnen und dürfen maximal 31 Zeichen lang sein. Identifier dürfen keine Sonderzeichen (außer ~ und _), Umlaute (ä, ö, ü) oder Leerzeichen enthalten. &amp;#039;&amp;#039;&amp;#039;Identifier sind case-sensitiv&amp;#039;&amp;#039;&amp;#039;!&lt;br /&gt;
&lt;br /&gt;
=== Kommentare ===&lt;br /&gt;
Zur Auszeichnung von Kommentaren gibt es zwei Möglichkeiten.&lt;br /&gt;
&lt;br /&gt;
* Beginn und Ende mit &amp;#039;&amp;#039;&amp;#039;&amp;quot;&amp;#039;&amp;#039;&amp;#039; kennzeichnen&lt;br /&gt;
* Beginn mit &amp;#039;&amp;#039;&amp;#039;//  -&amp;#039;&amp;#039;&amp;#039; gilt bis Zeilenende, sinnvoll wenn Kommentar selbst &amp;#039;&amp;#039;&amp;#039;&amp;quot;&amp;#039;&amp;#039;&amp;#039; enthält&lt;br /&gt;
&lt;br /&gt;
=== Konstanten (Auswahl) ===&lt;br /&gt;
&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.X.&amp;#039;&amp;#039;&amp;#039; don&amp;#039;t care Bedingung (z.&amp;amp;nbsp;B. im Abschnitt truth_table)&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.C.&amp;#039;&amp;#039;&amp;#039; vollständiger Takt: low-high-low (z.&amp;amp;nbsp;B. in test_vectors)&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.K.&amp;#039;&amp;#039;&amp;#039; vollständiger Takt high-low-high&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.D.&amp;#039;&amp;#039;&amp;#039; absteigende Taktflanke&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.U.&amp;#039;&amp;#039;&amp;#039; ansteigende Taktflanke&lt;br /&gt;
&lt;br /&gt;
=== Operatoren ===&lt;br /&gt;
In ABEL gibt es 4 Gruppen von Operatoren: logische Operatoren, arithmetische Operatoren, Vergleichsoperatoren und Zuweisungsoperatoren.&lt;br /&gt;
&lt;br /&gt;
* Logische Operatoren sind: &amp;#039;&amp;#039;&amp;#039;!&amp;#039;&amp;#039;&amp;#039; (NOT), &amp;#039;&amp;#039;&amp;#039;&amp;amp;&amp;#039;&amp;#039;&amp;#039; (AND), &amp;#039;&amp;#039;&amp;#039;#&amp;#039;&amp;#039;&amp;#039; (OR), &amp;#039;&amp;#039;&amp;#039;$&amp;#039;&amp;#039;&amp;#039; (XOR), &amp;#039;&amp;#039;&amp;#039;!$&amp;#039;&amp;#039;&amp;#039; (XNOR), &amp;#039;&amp;#039;&amp;#039;&amp;lt;&amp;lt;&amp;#039;&amp;#039;&amp;#039; (Shift left) und &amp;#039;&amp;#039;&amp;#039;&amp;gt;&amp;gt;&amp;#039;&amp;#039;&amp;#039; (Shift right)&lt;br /&gt;
* Arithmetische Operatoren sind &amp;#039;&amp;#039;&amp;#039;+&amp;#039;&amp;#039;&amp;#039; (Addition), &amp;#039;&amp;#039;&amp;#039;−&amp;#039;&amp;#039;&amp;#039; (Subtraktion oder Zweierkomplement), &amp;#039;&amp;#039;&amp;#039;*&amp;#039;&amp;#039;&amp;#039; (Multiplikation) und &amp;#039;&amp;#039;&amp;#039;/&amp;#039;&amp;#039;&amp;#039; (Division)&lt;br /&gt;
* Die Vergleichsoperationen entsprechen der Syntax vieler Hochsprachen. Möglich sind &amp;#039;&amp;#039;&amp;#039;==&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;!=&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;&amp;lt;&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;&amp;lt;=&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;&amp;gt;&amp;#039;&amp;#039;&amp;#039;, &amp;#039;&amp;#039;&amp;#039;&amp;lt;=&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Bei Zuweisungen werden kombinatorische Zuweisungen und Zuweisungen mit Speicher unterschieden:&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;=&amp;#039;&amp;#039;&amp;#039; bei Ausgängen ohne Flipflop (und bei Ausgängen mit FF unter Verwendung von Dot-Extensions)&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;:=&amp;#039;&amp;#039;&amp;#039; bei Ausgängen mit Flipflop&lt;br /&gt;
&lt;br /&gt;
[[Datei:ABEL-DOT-Extensions .gif|alt=Dot-Extensions|mini|hochkant=1.8|Dot-Extensions eines D-Flipflops in einem CPLD]]&lt;br /&gt;
&lt;br /&gt;
=== Dot-Extensions ===&lt;br /&gt;
DOT-Extensions in ABEL sind ein wichtiges Hilfsmittel, um auf internen Signale der im CLPD enthaltenen D-Flipflops zuzugreifen.&lt;br /&gt;
Die Abbildung zeigt die am häufigsten genutzten Dot-Extensions:&lt;br /&gt;
&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.OE&amp;#039;&amp;#039;&amp;#039; schaltet den Tristate-Buffer&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.D&amp;#039;&amp;#039;&amp;#039; ist der Daten-Eingang des Flipflops&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.CLK&amp;#039;&amp;#039;&amp;#039; bezeichnet den Takt-Eingang des Flipflops&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.AR&amp;#039;&amp;#039;&amp;#039; bezeichnet den asynchronen Rücksetzeingang des Flipflops&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.Q&amp;#039;&amp;#039;&amp;#039; ist der Ausgang des Flipflops. Bei internen Flipflops (NODE) kann nur &amp;#039;&amp;#039;&amp;#039;.Q&amp;#039;&amp;#039;&amp;#039; genutzt werden.&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;.Pin&amp;#039;&amp;#039;&amp;#039; ist das Signal am Ausgangspin. Durch Verwendung von &amp;#039;&amp;#039;&amp;#039;.OE&amp;#039;&amp;#039;&amp;#039; sind auch bidirektionale Busse möglich.&lt;br /&gt;
&lt;br /&gt;
Weitere Dot-Extensions werden bausteinspezifisch direkt umgesetzt oder emuliert. So kann in einem CPLD, welches nur D-Flipflops enthält, mittels &amp;#039;&amp;#039;&amp;#039;.J&amp;#039;&amp;#039;&amp;#039; und &amp;#039;&amp;#039;&amp;#039;.K&amp;#039;&amp;#039;&amp;#039; oder &amp;#039;&amp;#039;&amp;#039;.R&amp;#039;&amp;#039;&amp;#039; und &amp;#039;&amp;#039;&amp;#039;.S&amp;#039;&amp;#039;&amp;#039; das Verhalten eines JK- oder RS-Flipflops nachgebildet werden. Wenn die internen Flipflops des CPLD kein asynchrones Setz-Signal (&amp;#039;&amp;#039;&amp;#039;.AS&amp;#039;&amp;#039;&amp;#039;) aufweisen, wird bei der Verwendung von &amp;#039;&amp;#039;&amp;#039;.AS&amp;#039;&amp;#039;&amp;#039; die Logik des Flipflops invertiert und stattdessen der asynchrone Rücksetzeingang &amp;#039;&amp;#039;&amp;#039;.AR&amp;#039;&amp;#039;&amp;#039; genutzt. Dabei kann &amp;#039;&amp;#039;&amp;#039;.AR&amp;#039;&amp;#039;&amp;#039; und &amp;#039;&amp;#039;&amp;#039;.AS&amp;#039;&amp;#039;&amp;#039; nicht gleichzeitig genutzt werden.&lt;br /&gt;
&lt;br /&gt;
== Beispiel Ampelschaltung in ABEL-HDL ==&lt;br /&gt;
Der folgende [[Quelltext]] stellt ein [[Computerprogramm|Programm]] zur einfachen Ampelschaltung dar, welches die Ampelphasen rot – rot/gelb – grün – gelb – rot – usw. durchläuft, solange ein High-Signal am Enable-Eingang anliegt.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- start des quellcodes --&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;c&amp;quot;&amp;gt;&lt;br /&gt;
MODULE trafficlight&lt;br /&gt;
TITLE &amp;#039;trafficlight&amp;#039;&lt;br /&gt;
DECLARATIONS&lt;br /&gt;
// inputs&lt;br /&gt;
    clk    pin 11; // clock signal&lt;br /&gt;
    en     pin  9; // enable signal to start the traffic light&lt;br /&gt;
// nodes&lt;br /&gt;
    q0     node   istype &amp;#039;reg&amp;#039;;&lt;br /&gt;
    q1     node   istype &amp;#039;reg&amp;#039;;&lt;br /&gt;
// output&lt;br /&gt;
    red    pin 36 istype &amp;#039;com&amp;#039;; // the red light&lt;br /&gt;
    yellow pin 42 istype &amp;#039;com&amp;#039;; // the yellow light&lt;br /&gt;
    green  pin 39 istype &amp;#039;com&amp;#039;; // the green light&lt;br /&gt;
EQUATIONS&lt;br /&gt;
    q0 := !q0 &amp;amp; !en;&lt;br /&gt;
    q1 := (q1 $ q0) &amp;amp; !en;&lt;br /&gt;
    q0.clk = clk;&lt;br /&gt;
    q1.clk = clk;&lt;br /&gt;
    red = q1;&lt;br /&gt;
    yellow = !q0;&lt;br /&gt;
    green = !(q1 &amp;amp; !q0);&lt;br /&gt;
TEST_VECTORS&lt;br /&gt;
           ([clk, en] -&amp;gt; [ red, yellow, green]);&lt;br /&gt;
@repeat 1  {[.C., 1] -&amp;gt; [.X., .X., .X.];}&lt;br /&gt;
@repeat 7  {[.C., 0] -&amp;gt; [.X., .X., .X.];}&lt;br /&gt;
@repeat 3  {[.C., 1] -&amp;gt; [.X., .X., .X.];}&lt;br /&gt;
@repeat 40 {[.C., 0] -&amp;gt; [.X., .X., .X.];}&lt;br /&gt;
END&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* University of Pennsylvania’s {{Webarchiv |url=http://ez-ware.com/abel.primer.htm |wayback=20050207015851 |text=&amp;#039;&amp;#039;ABEL primer&amp;#039;&amp;#039;}} (englisch)&lt;br /&gt;
* Xilinx ABEL [https://www.xilinx.com/itp/xilinx10/help/iseguide/mergedProjects/abelref/whnjs.htm Reference Guide]&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
{{Normdaten|TYP=s|GND=4383423-1}}&lt;br /&gt;
&lt;br /&gt;
{{Navigationsleiste programmierbare Logik}}&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Hardwarebeschreibungssprache]]&lt;br /&gt;
[[Kategorie:Programmierbare Logik]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Aka</name></author>
	</entry>
</feed>