Skip to content

ADD

The ADD node adds two or more numeric arrays, matrices, dataframes, or constants element-wise.When a constant is added to an array or matrix, each element in the array or matrix will be increased by the constant value. If two arrays or matrices of different sizes are added, the output will be the size of the larger array or matrix with only the overlapping elements changed.Params:a : OrderedPair|Scalar|VectorThe input a use to compute the sum of a and b.b : OrderedPair|Scalar|VectorThe input b use to compute the sum of a and b.Returns:out : OrderedPair|Scalar|VectorOrderedPair if a is an OrderedPair. x: the x-axis of input a. y: the sum of input a and input b. Scalar if a is a Scalar. c: the sum of input a and input b. Vector if a is a Vector. v: the sum of input a and input b.
Python Code
from functools import reduce

import numpy as np
from flojoy import OrderedPair, Scalar, Vector, flojoy

from nodes.TRANSFORMERS.ARITHMETIC.utils.arithmetic_utils import get_val


@flojoy
def ADD(
    a: OrderedPair | Scalar | Vector, b: list[OrderedPair | Scalar | Vector]
) -> OrderedPair | Scalar | Vector:
    """The ADD node adds two or more numeric arrays, matrices, dataframes, or constants element-wise.

    When a constant is added to an array or matrix, each element in the array or matrix will be increased by the constant value.

    If two arrays or matrices of different sizes are added, the output will be the size of the larger array or matrix with only the overlapping elements changed.

    Parameters
    ----------
    a : OrderedPair|Scalar|Vector
        The input a use to compute the sum of a and b.
    b : OrderedPair|Scalar|Vector
        The input b use to compute the sum of a and b.

    Returns
    -------
    OrderedPair|Scalar|Vector
        OrderedPair if a is an OrderedPair.
        x: the x-axis of input a.
        y: the sum of input a and input b.

        Scalar if a is a Scalar.
        c: the sum of input a and input b.

        Vector if a is a Vector.
        v: the sum of input a and input b.
    """

    initial = get_val(a)
    seq = map(lambda dc: get_val(dc), b)
    y = reduce(lambda u, v: np.add(u, v), seq, initial)

    match a:
        case OrderedPair():
            return OrderedPair(x=a.x, y=y)
        case Vector():
            return Vector(v=y)
        case Scalar():
            return Scalar(c=y)

Find this Flojoy Block on GitHub

Example

Having problem with this example app? Join our Discord community and we will help you out!
React Flow mini map

In this example, LINSPACE generates an array from 0 to 10 that has a length of 1000.

This array is then passed to the SINE nodes, which compute numpy.sine(). They are added through ADD node and the output is visualized through SCATTER node.