/* SCCS - @(#)NslSum.java 1.3 --- 09/01/99 -- 00:18:13 */ // Copyright: Copyright (c) 1997 University of Southern California Brain Project. // Copyright: This software may be freely copied provided the toplevel // Copyright: COPYRIGHT file is included with each such copy. // Copyright: Email nsl@java.usc.edu. //////////////////////////////////////////////////////////// // // Summation routines // // /** Summation routines. There are two basic format for the evaluation method in this routine: 1, eval(a) -> c a is the parameter to evaluate the summation of a pointwise and the result is passed out as c 2. eval(dest, a) -> c a is the parameter of the evaluation function and dest is the temporary space to hold the result. The method returns the reference to dest. NslSum always returns a double. */ package nslj.src.math; import nslj.src.lang.*; public final class NslSum { //native 0d double public static double eval(double a) { return a; } //native 1d double public static double eval(double dest, double[]_data) { int i; dest=0; for (i=0; i<_data.length; i++) { dest=dest+_data[i]; } return dest; } public static double eval(double[] _data) { double dest=0; return (eval(dest,_data)); } //native 2d double public static double eval(double dest, double[][] _data) { int i, j; int size1 = _data.length; int size2 = _data[0].length; dest=0; for (i=0; i