SymPy - Logische Ausdrücke

Boolesche Funktionen sind in definiert sympy.basic.booleanarg module. Es ist möglich, boolesche Ausdrücke mit den Standard-Python-Operatoren & (And), | zu erstellen (Oder), ~ (Nicht) sowie mit >> und <<. Boolesche Ausdrücke erben von der im SymPy-Kernmodul definierten Basisklasse.

BooleanTrue-Funktion

Diese Funktion entspricht True wie in Core Python. Es gibt einen Singleton zurück, der von S.true abgerufen werden kann.

>>> from sympy import * 
>>> x=sympify(true) 
>>> x, S.true

Das obige Code-Snippet liefert die folgende Ausgabe:

(Wahr, wahr)

BooleanFalse-Funktion

In ähnlicher Weise entspricht diese Funktion Boolean False in Python und kann von S.false aufgerufen werden

>>> from sympy import * 
>>> x=sympify(false) 
>>> x, S.false

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch, Falsch)

Und funktionieren

Eine logische AND-Funktion wertet ihre beiden Argumente aus und gibt False zurück, wenn eines von beiden False ist. Die Funktion emuliert & operator.

>>> from sympy import * 
>>> from sympy.logic.boolalg import And 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=True 
>>> And(x,y), x"&"y

Das obige Code-Snippet liefert die folgende Ausgabe:

(Wahr, wahr)

>>> y=False 
>>> And(x,y), x"&"y

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch, Falsch)

Oder funktionieren

Diese Funktion wertet zwei boolesche Argumente aus und gibt True zurück, wenn eines von beiden True ist. Die | Der Bediener emuliert bequem sein Verhalten.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Or 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=False 
>>> Or(x,y), x|y

Das obige Code-Snippet liefert die folgende Ausgabe:

(Wahr, wahr)

>>> x=False 
>>> y=False 
>>> Or(x,y), x|y

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch, Falsch)

Keine Funktion

Eine logische Not-Funktion führt zur Negation des Booleschen Arguments. Es gibt True zurück, wenn das Argument False ist, und False, wenn True. Der Operator ~ führt die Operation ähnlich der Funktion Not aus. Es wird im folgenden Beispiel gezeigt -

>>> from sympy import * 
>>> from sympy.logic.boolalg import Or, And, Not 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=False 
>>> Not(x), Not(y)

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch Richtig)

>>> Not(And(x,y)), Not(Or(x,y))

Das obige Code-Snippet liefert die folgende Ausgabe:

(Wahr falsch)

Xoder Funktion

Die Funktion Logisches XOR (exklusives ODER) gibt True zurück, wenn eine ungerade Anzahl der Argumente True und der Rest False ist, und False, wenn eine gerade Anzahl der Argumente True und der Rest False ist. Eine ähnliche Operation wird vom Operator ^ ausgeführt.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Xor 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=False

>>> Xor(x,y), x^y

Das obige Code-Snippet liefert die folgende Ausgabe:

(Wahr, wahr)

>>> a,b,c,d,e=symbols('a b c d e') 
>>> a,b,c,d,e=(True, False, True, True, False) 
>>> Xor(a,b,c,d,e)

Das obige Code-Snippet liefert die folgende Ausgabe:

Wahr

Im obigen Fall sind drei Argumente (ungerade Zahl) True, daher gibt Xor true zurück. Wenn die Anzahl der True-Argumente jedoch gerade ist, führt dies zu False (siehe unten).

>>> a,b,c,d,e=(True, False, False, True, False) 
>>> Xor(a,b,c,d,e)

Das obige Code-Snippet liefert die folgende Ausgabe:

Falsch

Nand Funktion

Diese Funktion führt eine logische NAND-Operation aus. Es wertet seine Argumente aus und gibt True zurück, wenn eines von ihnen False ist, und False, wenn alle True sind.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Nand 
>>> a,b,c=symbols('a b c') 
>>> a,b,c=(True, False, True) 
>>> Nand(a,b,c), Nand(a,c)

Das obige Code-Snippet liefert die folgende Ausgabe:

(Wahr falsch)

Noch Funktion

Diese Funktion führt eine logische NOR-Operation aus. Es wertet seine Argumente aus und gibt False zurück, wenn eines von ihnen True ist, und True, wenn alle False sind.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Nor 
>>> a,b,c=symbols('a b c') 
>>> a,b,c=(True, False, True) 
>>> Nor(a,b,c), Nor(a,c)

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch, Falsch)

Beachten Sie, dass SymPy den Operator ^ für Xor, ~ für Not, | bereitstellt Für Or und & für And fungiert als Bequemlichkeit, ihre normale Verwendung in Python ist als bitweise Operator. Wenn Operanden ganze Zahlen sind, sind die Ergebnisse daher unterschiedlich.

Äquivalente Funktion

Diese Funktion gibt die Äquivalenzbeziehung zurück. Äquivalent (A, B) ist genau dann wahr, wenn A und B beide wahr oder beide falsch sind. Die Funktion gibt True zurück, wenn alle Argumente logisch äquivalent sind. Gibt sonst False zurück.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Equivalent 
>>> a,b,c=symbols('a b c') 
>>> a,b,c=(True, False, True) 
>>> Equivalent(a,b), Equivalent(a,c)

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch Richtig)

ITE-Funktion

Diese Funktion fungiert als If then else-Klausel in einer Programmiersprache .ITE (A, B, C) wertet das Ergebnis von B aus und gibt es zurück. Wenn A wahr ist, gibt es das Ergebnis von C zurück. Alle Argumente müssen Boolesche Werte sein.

>>> from sympy import * >>> from sympy.logic.boolalg import ITE >>> a,b,c=symbols('a b c') >>> a,b,c=(True, False, True) 
>>> ITE(a,b,c), ITE(a,c,b)

Das obige Code-Snippet liefert die folgende Ausgabe:

(Falsch Richtig)