数组的线性拟合或者叫线性回归,判断数据趋势

By admin at 2019-05-10 • 0人收藏 • 1648人看过
import console; 
var shuju = {};
var linearRegression = function(y,x){
	var lr = {};
	var n = #y;
	var sum_x = 0;
	var sum_y = 0;
	var sum_xy = 0;
	var sum_xx = 0;
	var sum_yy = 0;
	for(i=1;n;1){
		sum_x += x[i];
		sum_y += y[i];
		sum_xy += (x[i] * y[i]);
		sum_xx += (x[i] * x[i]);
		sum_yy += (y[i] * y[i]);
	}
	lr['倾斜度'] = (n * sum_xy - sum_x * sum_y) / (n * sum_xx - sum_x * sum_x);
	lr['差值'] = (sum_y - lr.倾斜度 * sum_x) / n;
	lr['拟合误差'] = ((n * sum_xy - sum_x * sum_y) / math.sqrt((n * sum_xx - sum_x * sum_x) * (n * sum_yy - sum_y * sum_y))) ** 2;
	
	return lr;
}


var ret = linearRegression( {20;36;43;81;4;84},{33;60;4;82;89;83}  );


console.log("F(X) = "++ret.倾斜度++"*X"++" + "+ret.差值,"误差为:"++ret.拟合误差);
console.pause(true);

image.png

1 个回复 | 最后更新于 2019-05-10
2019-05-10   #1

如果X轴是连续的数字, 而且你只需要的是趋势,那么可以省略x参数,函数如下:

var linearRegression = function(y){
	var lr = {};
	var n = #y;
	var sum_x = 0;
	var sum_y = 0;
	var sum_xy = 0;
	var sum_xx = 0;
	var sum_yy = 0;
	
	for(i=1;n;1){
		sum_x += i;
		sum_y += y[i];
		sum_xy += (i * y[i]);
		sum_xx += (i * i);
		sum_yy += (y[i] * y[i]);
	}
	lr['倾斜度'] = (n * sum_xy - sum_x * sum_y) / (n * sum_xx - sum_x * sum_x);
	lr['差值'] = (sum_y - lr.倾斜度 * sum_x) / n;
	lr['拟合误差'] = ((n * sum_xy - sum_x * sum_y) / math.sqrt((n * sum_xx - sum_x * sum_x) * (n * sum_yy - sum_y * sum_y))) ** 2;
	
	return lr;
}


登录后方可回帖

登 录
信息栏
 私人小站

本站域名

ChengXu.XYZ

投诉联系:  popdes@126.com



快速上位机开发学习,本站主要记录了学习过程中遇到的问题和解决办法及上位机代码分享

这里主要专注于学习交流和经验分享.
纯私人站,当笔记本用的,学到哪写到哪.
如果侵权,联系 Popdes@126.com

友情链接
Aardio官方
Aardio资源网


才仁机械


网站地图SiteMap

Loading...