Skip to content

Commit

Permalink
Added documentation to Not class that represents the ¬ (not) symb…
Browse files Browse the repository at this point in the history
…ol in a propositional logic (PL)

Signed-off-by: Ayush Joshi <[email protected]>
  • Loading branch information
joshiayush committed Nov 25, 2023
1 parent 6fe7d8c commit 429f1f1
Show file tree
Hide file tree
Showing 2 changed files with 115 additions and 31 deletions.
31 changes: 18 additions & 13 deletions ai/boolalg/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,19 +21,24 @@
either true or false. It is a technique of knowledge representation in logical
and mathematical form.
#### Examples
>>> from ai import (Symbol, And, Or, Not, Implication)
>>> rain = Symbol("rain")
>>> hagrid = Symbol("hagrid")
>>> dumbledore = Symbol("dumbledore")
>>> knowledge = And(
>>> Implication(Not(rain), hagrid),
>>> Or(hagrid, dumbledore),
>>> Not(And(hagrid, dumbledore)),
>>> dumbledore
>>> )
>>> print(model_check(knowledge, rain))
##### Example
```python
from ai import (Symbol, And, Or, Not, Implication)
rain = Symbol("rain")
hagrid = Symbol("hagrid")
dumbledore = Symbol("dumbledore")
knowledge = And(
Implication(Not(rain), hagrid),
Or(hagrid, dumbledore),
Not(And(hagrid, dumbledore)),
dumbledore
)
print(model_check(knowledge, rain))
```
"""

from .logic import (
Expand Down
115 changes: 97 additions & 18 deletions ai/boolalg/logic.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ class Symbol(_Sentence):
symbols used in propositional logic determines whether the logic holds `true`
or turns out to be `false`.
#### Examples
##### Example
>>> from logic import (Symbol, And)
>>> P = Symbol('P')
Expand All @@ -116,7 +116,7 @@ def __init__(self, name: str):
name: `Symbol` name; can be anything including digits, words, letters, or
special characters.
#### Examples
##### Example
>>> P = Symbol('P')
>>> Q = Symbol('Q')
Expand Down Expand Up @@ -156,7 +156,7 @@ def evaluate(self, model: dict[str, bool]) -> bool:
Returns:
The evaluated model of the symbol.
#### Examples
##### Example
>>> from ai import Symbol, Not
>>> P = Symbol('P')
Expand All @@ -181,7 +181,7 @@ def formula(self) -> str:
Returns:
String representation of the current symbol.
#### Examples
##### Example
>>> P = Symbol('P')
>>> P.formula()
Expand All @@ -195,27 +195,106 @@ def symbols(self) -> str:


class Not(_Sentence):
def __init__(self, operand):
"""`Not` class implements the properties and behaviour of the `(¬)` symbol.
In a propositional logic (PL) the `NOT` symbol inverts the value of the
symbol it is used with. For example, if the value of the symbol is `true` then
it will be evaluated to `false` and vice-versa.
##### Example
>>> from logic import (Not, Symbol)
>>> rain = Symbol('Rain')
>>> Not(rain).formula()
'¬Rain'
"""
def __init__(self, operand: 'Symbol'):
"""Constructs a `Not` instance.
A `Symbol` instance is used while constructing a `Not` instance. This symbol
will then be evaluated with a `(¬)` operator every time a propositional
logic model is evaluated. If the value of the symbol holds `true` then the
evaluated value of the entire expression will be `false` and vice-versa.
Args:
operand: An instance of a `Symbol` which is a operand in a propositional
logic.
##### Example
>>> from logic import (Not, Symbol)
>>> P = Symbol('P')
>>> knowledge = Not(P)
>>> knowledge.formula()
'¬P'
"""
_Sentence.validate(operand)
self.operand = operand
self._operand = operand

def __eq__(self, other):
return isinstance(other, Not) and self.operand == other.operand
def __eq__(self, other: 'Not') -> bool:
"""Compares `self` with the `other`."""
return isinstance(other, Not) and self._operand == other._operand

def __hash__(self):
return hash(("not", hash(self.operand)))
def __hash__(self) -> int:
"""Returns the hash of the current `Not` expression."""
return hash(("not", hash(self._operand)))

def __repr__(self):
return f"Not({self.operand})"
def __repr__(self) -> str:
"""Returns a string representation of `self`."""
return f"Not({self._operand})"

def evaluate(self, model):
return not self.operand.evaluate(model)
def evaluate(self, model: dict[str, bool]) -> bool:
"""Evaluates the value of the current expression i.e., `self` in the
propositional logic (PL).
def formula(self):
return "¬" + _Sentence.parenthesize(self.operand.formula())
Evaluating a model for `self` means evaluating the value of the current
expression. For example, for a symbol :math:`¬P \\implies \\mathrm{True}` in
a propositional logic (PL) —
def symbols(self):
return self.operand.symbols()
.. math::
¬P \\implies \\mathrm{False}
Args:
model: A propositional logic model mapping from the symbol name to its
truth or false value.
Returns:
The evaluated model of the current expression.
##### Example
>>> from ai import Symbol, Not
>>> P = Symbol('P')
>>> knowledge = Not(P)
>>> model_true[str(P)] = True
>>> knowledge.evaluate(model_true)
False
"""
return not self._operand.evaluate(model)

def formula(self) -> str:
"""Returns the expression for `self` that is to be used in the formula.
This function returns a string representation of the `Symbol` with the `(¬)`
operator that can later be joined with other operators and operands to
complete the propositional logic (PL).
Returns:
String representation of the current symbol.
##### Example
>>> P = Symbol('P')
>>> knowledge(Not(P))
>>> knowledge.formula()
'¬P'
"""
return "¬" + _Sentence.parenthesize(self._operand.formula())

def symbols(self) -> set:
"""Returns a set containing the name of the symbols in the expression."""
return self._operand.symbols()


class And(_Sentence):
Expand Down

0 comments on commit 429f1f1

Please sign in to comment.