diff --git a/Experiments/ExConsole/main.py b/Experiments/ExConsole/main.py index 1f78214..ed808a1 100644 --- a/Experiments/ExConsole/main.py +++ b/Experiments/ExConsole/main.py @@ -216,7 +216,7 @@ def exeF(arguments: Iterable[Term], task: Task=None, memory: Memory=None) -> Uni ''' print(f'executed: arguments={arguments}, task={task}, memory={memory}. the "task" will be returned') return task - Operation.register(Operation.Operation('f'), exeF) + Operation.register(Operation.Operator('f'), exeF) # build task # task1: Task = NarseseParser.parse('f(x).') # the same as <(*, x) --> ^f>. # task1: Task = NarseseParser.parse('f(x).') # the same as <(*, x) --> ^f>. diff --git a/Experiments/FighterPlane/Agent.py b/Experiments/FighterPlane/Agent.py index f3ac083..6ddde27 100644 --- a/Experiments/FighterPlane/Agent.py +++ b/Experiments/FighterPlane/Agent.py @@ -26,10 +26,10 @@ def __init__(self): # nars_type: 'opennars' or 'ONA' # self.dont_move() # elif operation == '^fire': # self.fire() - self.core.register_operation('left', self.move_left) - self.core.register_operation('right', self.move_right) - self.core.register_operation('deactivate', self.dont_move) - self.core.register_operation('fire', self.fire) + self.core.register_operator('left', self.move_left) + self.core.register_operator('right', self.move_right) + self.core.register_operator('deactivate', self.dont_move) + self.core.register_operator('fire', self.fire) self.inference_cycle_frequency = 5 diff --git a/Experiments/GoalAgent/main.py b/Experiments/GoalAgent/main.py index 634ac59..f4a413a 100644 --- a/Experiments/GoalAgent/main.py +++ b/Experiments/GoalAgent/main.py @@ -19,7 +19,7 @@ def main(): Config.projection_decay = 1e-4 nars = Reasoner(100, 100) - nars.register_operation("say_hello", say_hello) + nars.register_operator("say_hello", say_hello) # task1 = Narsese.parse("<{SELF}-->[good]>! :|:") # task2 = Narsese.parse("<{SELF}-->[good]>! :|:") diff --git a/Experiments/Pong/main.py b/Experiments/Pong/main.py index 96d8fa8..c87f119 100644 --- a/Experiments/Pong/main.py +++ b/Experiments/Pong/main.py @@ -119,8 +119,8 @@ def player_move(arguments: Iterable[Term], task: Task=None, memory: Memory=None) def player_stop(arguments: Iterable[Term], task: Task=None, memory: Memory=None): Action.value = 0 - nars.register_operation('move', player_move) - nars.register_operation('stop', player_stop) + nars.register_operator('move', player_move) + nars.register_operator('stop', player_stop) # begin playing i_step = 0 diff --git a/Experiments/Pong/main2.py b/Experiments/Pong/main2.py index d92452f..46d3fbd 100644 --- a/Experiments/Pong/main2.py +++ b/Experiments/Pong/main2.py @@ -130,8 +130,8 @@ def player_move(arguments: Iterable[Term], task: Task=None, memory: Memory=None) def player_stop(arguments: Iterable[Term], task: Task=None, memory: Memory=None): action = 0 - nars.register_operation('move', player_move) - nars.register_operation('stop', player_stop) + nars.register_operator('move', player_move) + nars.register_operator('stop', player_stop) # begin playing i_step = 0 diff --git a/pynars/Console.py b/pynars/Console.py index 8505138..f42d110 100644 --- a/pynars/Console.py +++ b/pynars/Console.py @@ -163,7 +163,7 @@ def run_nars(filepath: str, seed: int = 137, n_memory: int = 100, capacity: int rand_seed(seed) print_out(PrintType.COMMENT, f'rand_seed={seed}', comment_title='Setup') nars = Reasoner(n_memory, capacity) - nars.register_operation('left', lambda *args: print('execute left.')) + nars.register_operator('left', lambda *args: print('execute left.')) # try to run file if exists print_out(PrintType.COMMENT, 'Init...', comment_title='NARS') print_out(PrintType.COMMENT, 'Run...', comment_title='NARS') diff --git a/pynars/ConsolePlus.py b/pynars/ConsolePlus.py index 1e810ea..9f5b4ff 100644 --- a/pynars/ConsolePlus.py +++ b/pynars/ConsolePlus.py @@ -299,31 +299,31 @@ def eval_code(*args: List[str]) -> None: print(f'eval failed: {e}') -@cmd_register(('operation', 'operation-list', 'o-list')) -def operation_list(*keywords: List[str]) -> None: - '''Format: operation-list [*keywords] - Enumerate existing operations; It can be retrieved with parameters''' +@cmd_register(('operator', 'operator-list', 'o-list')) +def operator_list(*keywords: List[str]) -> None: + '''Format: operator-list [*keywords] + Enumerate existing operators; It can be retrieved with parameters''' keywords = keywords if keywords else [''] # Search for a matching interface name - from pynars.NARS.Operation.Register import registered_operations, get_registered_operation_by_name, registered_operation_names - operation_names: List[str] = prefix_browse(registered_operation_names(), *keywords) + from pynars.NARS.Operation.Register import registered_operators, get_registered_operator_by_name, registered_operator_names + operator_names: List[str] = prefix_browse(registered_operator_names(), *keywords) # Displays information about "matched interface" - if operation_names: - for name in operation_names: # match the list of all cmds, as long as they match the search results - not necessarily in order - op = get_registered_operation_by_name(name) - f = registered_operations[op] - print(f''': { + if operator_names: + for name in operator_names: # match the list of all cmds, as long as they match the search results - not necessarily in order + op = get_registered_operator_by_name(name) + f = registered_operators[op] + print(f''': { 'No function' if f == None else 'No description' if f.__doc__.strip() == '' else f.__doc__}''') return - print(f'No Operation is browsed by "{", ".join(keywords)}"') + print(f'No Operator is browsed by "{", ".join(keywords)}"') -@cmd_register(('register-operation', 'operation-register', 'o-register', 'register')) -def operation_register(*args: List[str]) -> None: - '''Format: register-operation [<'eval'/'exec'> ] - Register an operation to NARS interface. +@cmd_register(('register-operator', 'operator-register', 'o-register', 'register')) +def operator_register(*args: List[str]) -> None: + '''Format: register-operator [<'eval'/'exec'> ] + Register an operator to NARS interface. function signature: execution_F(arguments: Iterable[Term], task: Task=None, memory: Memory=None) -> Union[Task,None] @@ -331,7 +331,7 @@ def operation_register(*args: List[str]) -> None: default fallback of execution_F when only 1 argument is provided: print(f'executed: arguments={arguments}, task={task}, memory={memory}. the "task" will be returned') - ! Unsupported: register mental operations + ! Unsupported: register mental operators ''' name = args[0] "The operator's name without `^` as prefix" @@ -354,13 +354,13 @@ def execution_F(arguments: Iterable[Term], task: Task=None, memory: Memory=None) execution_F.__doc__ = f''' The execution is auto generated from operator with name={name} in {eType} mode with code={code} '''.strip() - if (op:=current_NARS_interface.reasoner.register_operation(name, execution_F)) is not None: - print(f'Operation {str(op)} was successfully registered ' + ( + if (op:=current_NARS_interface.reasoner.register_operator(name, execution_F)) is not None: + print(f'Operator {str(op)} was successfully registered ' + ( 'without code' if len(args) == 1 else f'in mode "{eType}" with code={code}')) else: - print(f'The operation with name="{name}" was already registered!') + print(f'The operator with name="{name}" was already registered!') @cmd_register(('simplify-parse', 'parse')) diff --git a/pynars/NAL/MentalOperation/_aware.py b/pynars/NAL/MentalOperation/_aware.py index faf76b2..942d0ab 100644 --- a/pynars/NAL/MentalOperation/_aware.py +++ b/pynars/NAL/MentalOperation/_aware.py @@ -10,7 +10,7 @@ from pynars.Narsese._py.Statement import Statement from pynars.Narsese._py.Task import Belief, Desire, Task from pynars.Narsese._py.Truth import Truth -from ._register import registered_operations +from ._register import registered_operators from pynars.Narsese import Term from ..Functions.Tools import truth_from_term, truth_to_quality, truth_to_term from pynars.Narsese import Base diff --git a/pynars/NAL/MentalOperation/_execute.py b/pynars/NAL/MentalOperation/_execute.py index 6aecaf7..bc64e01 100644 --- a/pynars/NAL/MentalOperation/_execute.py +++ b/pynars/NAL/MentalOperation/_execute.py @@ -6,7 +6,7 @@ from pynars.Narsese._py.Statement import Statement from pynars.Narsese._py.Task import Belief, Desire, Task from pynars.Narsese._py.Truth import Truth -from ._register import registered_operations +from ._register import registered_operators from pynars.Narsese import Term from ..Functions.Tools import truth_from_term, truth_to_quality from pynars.Narsese import Base @@ -16,9 +16,9 @@ def execute(task: Task): '''''' stat: Statement = task.term if stat.is_executable: - operation: Operation = stat.predicate + operator: Operator = stat.predicate args = stat.terms - return registered_operations[operation](task, *args) + return registered_operators[operator](task, *args) else: return None diff --git a/pynars/NAL/MentalOperation/_register.py b/pynars/NAL/MentalOperation/_register.py index 8168268..2054238 100644 --- a/pynars/NAL/MentalOperation/_register.py +++ b/pynars/NAL/MentalOperation/_register.py @@ -2,9 +2,9 @@ from typing import Callable, Dict from pynars.Narsese._py.Operation import * -registered_operations: Dict[Operation, Callable] = {} +registered_operators: Dict[Operator, Callable] = {} -def register(operation: Operation, callable: Callable): +def register(operator: Operator, callable: Callable): '''''' - global registered_operations - registered_operations[operation] = callable \ No newline at end of file + global registered_operators + registered_operators[operator] = callable \ No newline at end of file diff --git a/pynars/NARS/Control/Reasoner.py b/pynars/NARS/Control/Reasoner.py index f8a9600..699c65c 100644 --- a/pynars/NARS/Control/Reasoner.py +++ b/pynars/NARS/Control/Reasoner.py @@ -182,11 +182,11 @@ def mental_operation(self, task: Task, concept: Concept, answers_question: Task, return task_operation_return, task_executed, belief_awared - def register_operation(self, name_operation: str, callback: Callable): - '''register an operation and return the operation if successful (otherwise, return None)''' - if not Operation.is_registered_by_name(name_operation): - from pynars.Narsese import Operation as Op - op = Op(name_operation) + def register_operator(self, name_operator: str, callback: Callable): + '''register an operator and return the operator if successful (otherwise, return None)''' + if not Operation.is_registered_by_name(name_operator): + from pynars.Narsese import Operator as Op + op = Op(name_operator) Operation.register(op, callback) return op return None diff --git a/pynars/NARS/DataStructures/_py/Memory.py b/pynars/NARS/DataStructures/_py/Memory.py index 2cfa07e..4d09bb7 100644 --- a/pynars/NARS/DataStructures/_py/Memory.py +++ b/pynars/NARS/DataStructures/_py/Memory.py @@ -240,13 +240,13 @@ def _accept_goal(self, task: Task, concept: Concept, task_link: TaskLink=None): truth = task.truth if truth.e > Config.decision_threshold: if (task is not None) and task.is_executable and not (desire is not None and desire.evidential_base.contains(task.evidential_base)): - # execute registered operations + # execute with registered operators stat: Statement = task.term op = stat.predicate - from pynars.NARS.Operation.Register import registered_operations + from pynars.NARS.Operation.Register import registered_operators from pynars.NARS.Operation.Execution import execute # ! if `op` isn't registered, an error "AttributeError: 'NoneType' object has no attribute 'stamp'" from "key: Callable[[Task], Any] = lambda task: (hash(task), hash(task.stamp.evidential_base))" will be raised - if op in registered_operations and not task.is_mental_operation: + if op in registered_operators and not task.is_mental_operation: # to judge whether the goal has been fulfilled task_operation_return, task_executed = execute(task, concept, self) concept_task = self.take_by_key(task.term, remove=False) diff --git a/pynars/NARS/Operation/Execution.py b/pynars/NARS/Operation/Execution.py index 5e8ebd3..175e38d 100644 --- a/pynars/NARS/Operation/Execution.py +++ b/pynars/NARS/Operation/Execution.py @@ -8,7 +8,7 @@ from pynars.Narsese._py.Statement import Statement from pynars.Narsese._py.Task import Belief, Desire, Task from pynars.Narsese._py.Truth import Truth -from .Register import registered_operations +from .Register import registered_operators from pynars.Narsese import Term from pynars.NAL.Functions.Tools import truth_from_term, truth_to_quality from pynars.Narsese import Base @@ -34,9 +34,9 @@ def execute(task: Task, concept: Concept, memory: Memory): if task.term != concept.term: concept = memory.take_by_key(task.term, remove=False) stat: Statement = task.term - operation: Operation = stat.predicate + operator: Operator = stat.predicate args = stat.subject.terms - function_op: Callable = registered_operations.get(operation, None) + function_op: Callable = registered_operators.get(operator, None) if function_op is not None: belief = executed_task(task) diff --git a/pynars/NARS/Operation/Register.py b/pynars/NARS/Operation/Register.py index 2e4e7ab..d8dccaf 100644 --- a/pynars/NARS/Operation/Register.py +++ b/pynars/NARS/Operation/Register.py @@ -1,33 +1,33 @@ from typing import Callable, Dict from pynars.Narsese._py.Operation import * -registered_operations: Dict[Operation, Callable] = {} +registered_operators: Dict[Operator, Callable] = {} -def registered_operation_names(): +def registered_operator_names(): '''''' - global registered_operations - return [registered_operation.word for registered_operation in registered_operations.keys()] + global registered_operators + return [registered_operator.word for registered_operator in registered_operators.keys()] -def register(operation: Operation, callable: Callable): +def register(operator: Operator, callable: Callable): '''''' - global registered_operations - registered_operations[operation] = callable + global registered_operators + registered_operators[operator] = callable def is_registered_by_name(word): '''''' - global registered_operations - for registered_operation in registered_operations.keys(): - if registered_operation.word == word: + global registered_operators + for registered_operator in registered_operators.keys(): + if registered_operator.word == word: return True return False -def get_registered_operation_by_name(word): +def get_registered_operator_by_name(word): '''''' - global registered_operations - for registered_operation in registered_operations.keys(): - if registered_operation.word == word: - return registered_operation + global registered_operators + for registered_operator in registered_operators.keys(): + if registered_operator.word == word: + return registered_operator return None \ No newline at end of file diff --git a/pynars/Narsese/Parser/parser.py b/pynars/Narsese/Parser/parser.py index 5a9c25f..0b766e5 100644 --- a/pynars/Narsese/Parser/parser.py +++ b/pynars/Narsese/Parser/parser.py @@ -1,5 +1,5 @@ from pynars.Narsese import Term, Judgement, Tense, Statement, Copula, Truth, Stamp, Interval -from pynars.Narsese import Base, Operation, Budget, Task, Goal, Punctuation, Question, Quest, Sentence, VarPrefix, Variable, Connector, Compound, SELF +from pynars.Narsese import Base, Operator, Budget, Task, Goal, Punctuation, Question, Quest, Sentence, VarPrefix, Variable, Connector, Compound, SELF from pathlib import Path from datetime import datetime from pynars import Config, Global @@ -186,7 +186,7 @@ def atom_term(self, word: Token): @inline_args def op(self, word: Token): word = word.value - return Operation(word) + return Operator(word) @inline_args def interval(self, word: Token): @@ -213,7 +213,7 @@ def statement_term(self, statement): return statement @inline_args - def statement_operation1(self, op: Operation, *args: str): + def statement_operation1(self, op: Operator, *args: str): terms = (term for term in args) return Statement(Compound(Connector.Product, *terms, is_input=True), Copula.Inheritance, op, is_input=True) @@ -221,7 +221,7 @@ def statement_operation1(self, op: Operation, *args: str): def statement_operation2(self, word: Token, *args: str): op = word.value terms = (term for term in args) - return Statement(Compound(Connector.Product, *terms, is_input=True), Copula.Inheritance, Operation(op), is_input=True) + return Statement(Compound(Connector.Product, *terms, is_input=True), Copula.Inheritance, Operator(op), is_input=True) @inline_args def inheritance(self): diff --git a/pynars/Narsese/_py/Operation.py b/pynars/Narsese/_py/Operation.py index 6ce4d54..f6547ae 100644 --- a/pynars/Narsese/_py/Operation.py +++ b/pynars/Narsese/_py/Operation.py @@ -1,8 +1,8 @@ from .Term import Term -class Operation(Term): +class Operator(Term): - is_operation = True + is_operation = True # ? If it changed the type of statements also need to change, but if rename it, two properties with different names will occur. Same as 'is_mental_operation' def __init__(self, word, do_hashing=False, is_mental_operation=False) -> None: super().__init__(word, do_hashing=do_hashing) @@ -22,69 +22,69 @@ def do_hashing(self): self._hash_value = hash(str(self)) return self._hash_value -Anticipate = Operation('anticipate', True, is_mental_operation=True) -Evaluate = Operation('evaluate', True, is_mental_operation=True) +Anticipate = Operator('anticipate', True, is_mental_operation=True) +Evaluate = Operator('evaluate', True, is_mental_operation=True) # With reference to book NAL(2012) -Observe = Operation('observe', True, is_mental_operation=True) +Observe = Operator('observe', True, is_mental_operation=True) '''get an active task from the task buffer''' -Expect = Operation('expect', True, is_mental_operation=True) +Expect = Operator('expect', True, is_mental_operation=True) '''check the input for a given statement''' -Know = Operation('know', True, is_mental_operation=True) +Know = Operator('know', True, is_mental_operation=True) '''find the truth-value of a statement''' -Assess = Operation('assess', True, is_mental_operation=True) +Assess = Operator('assess', True, is_mental_operation=True) '''find the desire-value of a statement''' -Believe = Operation('believe', True, is_mental_operation=True) +Believe = Operator('believe', True, is_mental_operation=True) '''turn a statement into a task containing a judgment''' -Want = Operation('want', True, is_mental_operation=True) +Want = Operator('want', True, is_mental_operation=True) '''turn a statement into a task containing a goal''' -Wonder = Operation('wonder', True, is_mental_operation=True) +Wonder = Operator('wonder', True, is_mental_operation=True) '''turn a statement into a task containing a question''' -Remember = Operation('remember', True, is_mental_operation=True) +Remember = Operator('remember', True, is_mental_operation=True) '''turn a statement into a belief''' -Consider = Operation('consider', True, is_mental_operation=True) +Consider = Operator('consider', True, is_mental_operation=True) '''do inference on a concept''' -Remind = Operation('remind', True, is_mental_operation=True) +Remind = Operator('remind', True, is_mental_operation=True) '''activate a concept''' -Doubt = Operation('doubt', True, is_mental_operation=True) +Doubt = Operator('doubt', True, is_mental_operation=True) '''decrease the confidence of a belief''' -Hesitate = Operation('hesitate', True, is_mental_operation=True) +Hesitate = Operator('hesitate', True, is_mental_operation=True) '''decrease the confidence of a goal''' -Assume = Operation('assume', True, is_mental_operation=True) +Assume = Operator('assume', True, is_mental_operation=True) '''temporarily take a statement as a belief''' -Name = Operation('name', True, is_mental_operation=True) +Name = Operator('name', True, is_mental_operation=True) '''create a simple internal ID to a useful compound term''' -Wait = Operation('wait', True, is_mental_operation=True) +Wait = Operator('wait', True, is_mental_operation=True) '''pause the system’s action for a given number of working cycles''' -Repeat = Operation('repeat', True, is_mental_operation=True) +Repeat = Operator('repeat', True, is_mental_operation=True) '''execute an action repeatedly under a given condition''' -Tell = Operation('tell', True, is_mental_operation=True) +Tell = Operator('tell', True, is_mental_operation=True) '''produce an outgoing task containing a judgment''' -Demand = Operation('demand', True, is_mental_operation=True) +Demand = Operator('demand', True, is_mental_operation=True) '''produce an outgoing task containing a goal''' -Ask = Operation('ask', True, is_mental_operation=True) +Ask = Operator('ask', True, is_mental_operation=True) '''produce an outgoing task containing a question''' -Check = Operation('check', True, is_mental_operation=True) +Check = Operator('check', True, is_mental_operation=True) '''produce an outgoing task containing a query''' -Register = Operation('register', True, is_mental_operation=True) +Register = Operator('register', True, is_mental_operation=True) '''let a term be used as an operator'''