| import math |
|
|
| from typing import Any, Callable, Mapping |
|
|
| DEFAULT_INT = ("INT", {"default": 0}) |
|
|
| INT_UNARY_OPERATIONS: Mapping[str, Callable[[int], int]] = { |
| "Abs": lambda a: abs(a), |
| "Neg": lambda a: -a, |
| "Inc": lambda a: a + 1, |
| "Dec": lambda a: a - 1, |
| "Sqr": lambda a: a * a, |
| "Cube": lambda a: a * a * a, |
| "Not": lambda a: ~a, |
| "Factorial": lambda a: math.factorial(a), |
| } |
|
|
| INT_UNARY_CONDITIONS: Mapping[str, Callable[[int], bool]] = { |
| "IsZero": lambda a: a == 0, |
| "IsNonZero": lambda a: a != 0, |
| "IsPositive": lambda a: a > 0, |
| "IsNegative": lambda a: a < 0, |
| "IsEven": lambda a: a % 2 == 0, |
| "IsOdd": lambda a: a % 2 == 1, |
| } |
|
|
| INT_BINARY_OPERATIONS: Mapping[str, Callable[[int, int], int]] = { |
| "Add": lambda a, b: a + b, |
| "Sub": lambda a, b: a - b, |
| "Mul": lambda a, b: a * b, |
| "Div": lambda a, b: a // b, |
| "Mod": lambda a, b: a % b, |
| "Pow": lambda a, b: a**b, |
| "And": lambda a, b: a & b, |
| "Nand": lambda a, b: ~a & b, |
| "Or": lambda a, b: a | b, |
| "Nor": lambda a, b: ~a & b, |
| "Xor": lambda a, b: a ^ b, |
| "Xnor": lambda a, b: ~a ^ b, |
| "Shl": lambda a, b: a << b, |
| "Shr": lambda a, b: a >> b, |
| "Max": lambda a, b: max(a, b), |
| "Min": lambda a, b: min(a, b), |
| } |
|
|
| INT_BINARY_CONDITIONS: Mapping[str, Callable[[int, int], bool]] = { |
| "Eq": lambda a, b: a == b, |
| "Neq": lambda a, b: a != b, |
| "Gt": lambda a, b: a > b, |
| "Lt": lambda a, b: a < b, |
| "Geq": lambda a, b: a >= b, |
| "Leq": lambda a, b: a <= b, |
| } |
|
|
|
|
| class IntUnaryOperation: |
| @classmethod |
| def INPUT_TYPES(cls) -> Mapping[str, Any]: |
| return { |
| "required": {"op": (list(INT_UNARY_OPERATIONS.keys()),), "a": DEFAULT_INT} |
| } |
|
|
| RETURN_TYPES = ("INT",) |
| FUNCTION = "op" |
| CATEGORY = "math/int" |
|
|
| def op(self, op: str, a: int) -> tuple[int]: |
| return (INT_UNARY_OPERATIONS[op](a),) |
|
|
|
|
| class IntUnaryCondition: |
| @classmethod |
| def INPUT_TYPES(cls) -> Mapping[str, Any]: |
| return { |
| "required": {"op": (list(INT_UNARY_CONDITIONS.keys()),), "a": DEFAULT_INT} |
| } |
|
|
| RETURN_TYPES = ("BOOL",) |
| FUNCTION = "op" |
| CATEGORY = "math/int" |
|
|
| def op(self, op: str, a: int) -> tuple[bool]: |
| return (INT_UNARY_CONDITIONS[op](a),) |
|
|
|
|
| class IntBinaryOperation: |
| @classmethod |
| def INPUT_TYPES(cls) -> Mapping[str, Any]: |
| return { |
| "required": { |
| "op": (list(INT_BINARY_OPERATIONS.keys()),), |
| "a": DEFAULT_INT, |
| "b": DEFAULT_INT, |
| } |
| } |
|
|
| RETURN_TYPES = ("INT",) |
| FUNCTION = "op" |
| CATEGORY = "math/int" |
|
|
| def op(self, op: str, a: int, b: int) -> tuple[int]: |
| return (INT_BINARY_OPERATIONS[op](a, b),) |
|
|
|
|
| class IntBinaryCondition: |
| @classmethod |
| def INPUT_TYPES(cls) -> Mapping[str, Any]: |
| return { |
| "required": { |
| "op": (list(INT_BINARY_CONDITIONS.keys()),), |
| "a": DEFAULT_INT, |
| "b": DEFAULT_INT, |
| } |
| } |
|
|
| RETURN_TYPES = ("BOOL",) |
| FUNCTION = "op" |
| CATEGORY = "math/int" |
|
|
| def op(self, op: str, a: int, b: int) -> tuple[bool]: |
| return (INT_BINARY_CONDITIONS[op](a, b),) |
|
|
|
|
| NODE_CLASS_MAPPINGS = { |
| "CM_IntUnaryOperation": IntUnaryOperation, |
| "CM_IntUnaryCondition": IntUnaryCondition, |
| "CM_IntBinaryOperation": IntBinaryOperation, |
| "CM_IntBinaryCondition": IntBinaryCondition, |
| } |
|
|