import random


def _randint(rng, low, high):
    if rng is None:
        return random.randint(low, high)
    if hasattr(rng, "integers"):
        return int(rng.integers(low, high + 1))
    return rng.randint(low, high)

class Node():
    """
    type: 
        0 for input
        1 for output
        2 for add
        3 for sub
        4 for mul
        5 for div
        6 for fma
        7 for constant
    value: value of the node
    next: list of next nodes
    prev: list of previous nodes
    grad: gradient of the node
    """
    def __init__(self,type = 0, rng=None):
        if type == 7:
            self.value = (-1)**_randint(rng, 0, 1)*(10**_randint(rng, -8, 0))
        else:
            self.value = 0.0
        self.type = type
        self.next = []
        self.prev = []
        self.grad = 0
        self.tmp_degree = 0


    def link(self,node):
        self.next.append(node)
        node.prev.append(self)
    
