cts.linearModel( $values as cts.reference[], [$options as String[]], [$query as cts.query?], [$forestids as String[]] ) as math.linearModel?
Returns a linear model that fits the frequencyweighted data set.
The input data is a cooccurrence, formed from the specified value
lexicons. The length of the input lexicon sequence should be 2, as
currently only simple linear regression model is supported. The
first lexicon should be the value of the dependent variable while
the other lexicon should be the value of the independent variable.
This function works like math:linearmodel
except each
pair in the input lexicons is counted cts:frequency
times.
This function performs the calculation in parallel in all data nodes
then aggregates the values.
Parameters  

$values  References to two range indexes. The types of the range indexes must be numeric. If the size of this sequence is not 2, the function returns the empty sequence. 
$options 
Same as the "options" parameter in cts:aggregate .

$query 
Same as the "query" parameter in cts:aggregate .

$forestids 
Same as the "forestids" parameter in cts:aggregate .

// This query assumes range indexes of type unsignedLong // with positions are configured in the database for both // xval and yval. It generates some sample data and then // performs the aggregation in a separate transaction. // Generate data: declareUpdate(); for (x=1; x<11; x++) { const j = 2 * x + 1; const uri = fn.concat(x, ".json"); const vals = {xval:x, yval:j} const obj = {a:vals}; xdmp.documentInsert(uri, obj); }; ******* // Run the following query: cts.linearModel( [cts.jsonPropertyReference("yval", ["type=unsignedLong"]), cts.jsonPropertyReference("xval", ["type=unsignedLong"])], "itemfrequency"); => math.linearModel( <math:linearmodel intercept="0.352941176470588" coefficients="1.97058823529412" rsquared="0.995196571090748" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance" xmlns:math="http://marklogic.com/xdmp/math"/>)
Comments