All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jscl.math.operator.vector.Divergence Maven / Gradle / Ivy

package jscl.math.operator.vector;

import jscl.math.Generic;
import jscl.math.JsclVector;
import jscl.math.Variable;
import jscl.math.operator.Operator;
import jscl.math.operator.VectorOperator;
import jscl.mathml.MathML;
import org.jetbrains.annotations.NotNull;

public class Divergence extends VectorOperator {

    public static final String NAME = "diverg";

    public Divergence(Generic vector, Generic variable) {
        super(NAME, new Generic[]{vector, variable});
    }

    private Divergence(@NotNull Generic parameter[]) {
        super(NAME, parameter);
    }

    @Override
    public int getMinParameters() {
        return 2;
    }

    public Generic selfExpand() {
        Variable variable[] = toVariables((JsclVector) parameters[1]);
        if (parameters[0] instanceof JsclVector) {
            JsclVector vector = (JsclVector) parameters[0];
            return vector.divergence(variable);
        }
        return expressionValue();
    }

    @NotNull
    @Override
    public Operator newInstance(@NotNull Generic[] parameters) {
        return new Divergence(parameters);
    }

    protected void bodyToMathML(MathML element) {
        operator(element, "nabla");
        parameters[0].toMathML(element, null);
    }

    @NotNull
    public Variable newInstance() {
        return new Divergence(null, null);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy