- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
目前,脚本位于://rawgithub.com/phpepe/highcharts-regression/master/highcharts-regression.js 计算系列完整数据集的线性回归。是否可以修改它以根据范围内的数据计算线性回归。即 1 个月线性回归、3 个月线性回归...
function _linear(data, decimalPlaces, extrapolate) {
var sum = [0, 0, 0, 0, 0], n = 0, results = [], N = data.length;
for (; n < data.length; n++) {
if (data[n]['x'] != null) {
data[n][0] = data[n].x;
data[n][1] = data[n].y;
}
if (data[n][1] != null) {
sum[0] += data[n][0]; //Σ(X)
sum[1] += data[n][1]; //Σ(Y)
sum[2] += data[n][0] * data[n][0]; //Σ(X^2)
sum[3] += data[n][0] * data[n][1]; //Σ(XY)
sum[4] += data[n][1] * data[n][1]; //Σ(Y^2)
} else {
N -= 1;
}
}
我可以看到它当前正在计算完整数据长度的线性回归。如何将数据长度设置在所选范围内。我想要每条单独的回归线,而不是一条回归线。
参见jsfiddle:http://jsfiddle.net/x0pya5gt/
最佳答案
highcharts-regression默认没有此功能。您可以更改 regression.js 并添加此功能。您应该首先下载代码(显然)并将其放在某处并将该文件包含在您的代码中。那么你应该像这样更改 processSerie 函数:
var processSerie = function (s, method, chart) {
if (s.regression && !s.rendered) {
s.regressionSettings = s.regressionSettings || {};
s.regressionSettings.tooltip = s.regressionSettings.tooltip || {};
s.regressionSettings.dashStyle = s.regressionSettings.dashStyle || 'solid';
s.regressionSettings.decimalPlaces = s.regressionSettings.decimalPlaces || 2;
s.regressionSettings.useAllSeries = s.regressionSettings.useAllSeries || false;
s.regressionSettings.selectedRange = s.regressionSettings.selectedRange || []; // Add selectedRange for passing the range to regression.
var regressionType = s.regressionSettings.type || "linear";
var regression;
var extraSerie = {
data: [],
color: s.regressionSettings.color || '',
yAxis: s.yAxis,
lineWidth: s.regressionSettings.lineWidth || 2,
marker: {enabled: false},
isRegressionLine: true,
visible: s.regressionSettings.visible,
type: s.regressionSettings.linetype || 'spline',
name: s.regressionSettings.name || "Equation: %eq",
id: s.regressionSettings.id,
dashStyle: s.regressionSettings.dashStyle || 'solid',
showInLegend: !s.regressionSettings.hideInLegend,
tooltip: {
valueSuffix: s.regressionSettings.tooltip.valueSuffix || ' '
}
};
if (typeof s.regressionSettings.index !== 'undefined') {
extraSerie.index = s.regressionSettings.index;
}
if (typeof s.regressionSettings.legendIndex !== 'undefined') {
extraSerie.legendIndex = s.regressionSettings.legendIndex;
}
var mergedData = s.data;
if (s.regressionSettings.useAllSeries) {
mergedData = [];
for (di = 0; di < series.length; di++) {
var seriesToMerge = series[di];
mergedData = mergedData.concat(seriesToMerge.data);
}
}
if (regressionType == "linear") {
var extrapolate = s.regressionSettings.extrapolate || 0;
regression = _linear(mergedData, s.regressionSettings.decimalPlaces, extrapolate, s.regressionSettings.selectedRange); // Here you add selectedRange parameter for _linear function
extraSerie.type = "line";
} else if (regressionType == "exponential") {
var extrapolate = s.regressionSettings.extrapolate || 0;
regression = _exponential(mergedData, extrapolate);
}
else if (regressionType == "polynomial") {
var order = s.regressionSettings.order || 2;
var extrapolate = s.regressionSettings.extrapolate || 0;
regression = _polynomial(mergedData, order, extrapolate);
} else if (regressionType == "power") {
var extrapolate = s.regressionSettings.extrapolate || 0;
regression = _power(mergedData, extrapolate);
} else if (regressionType == "logarithmic") {
var extrapolate = s.regressionSettings.extrapolate || 0;
regression = _logarithmic(mergedData, extrapolate);
} else if (regressionType == "loess") {
var loessSmooth = s.regressionSettings.loessSmooth || 25;
regression = _loess(mergedData, loessSmooth / 100);
} else {
console.error("Invalid regression type: ", regressionType);
return;
}
regression.rSquared = coefficientOfDetermination(mergedData, regression.points);
regression.rValue = _round(Math.sqrt(regression.rSquared), s.regressionSettings.decimalPlaces);
regression.rSquared = _round(regression.rSquared, s.regressionSettings.decimalPlaces);
regression.standardError = _round(standardError(mergedData, regression.points), s.regressionSettings.decimalPlaces);
extraSerie.data = regression.points;
extraSerie.name = extraSerie.name.replace("%r2", regression.rSquared);
extraSerie.name = extraSerie.name.replace("%r", regression.rValue);
extraSerie.name = extraSerie.name.replace("%eq", regression.string);
extraSerie.name = extraSerie.name.replace("%se", regression.standardError);
if (extraSerie.visible === false) {
extraSerie.visible = false;
}
extraSerie.regressionOutputs = regression;
return extraSerie;
}
}
考虑添加的行:
s.regressionSettings.selectedRange = s.regressionSettings.selectedRange || []; // Add selectedRange for passing the range to regression.
这一行已更改:
regression = _linear(mergedData, s.regressionSettings.decimalPlaces, extrapolate, s.regressionSettings.selectedRange); // Here you add selectedRange parameter for _linear function
然后在 _线性 函数中,您应该添加以下更改:
function _linear(data, decimalPlaces, extrapolate, selectedRange) {
var sum = [0, 0, 0, 0, 0], n = 0, i = 0, results = [], N = data.length;
for (; i < data.length; i++) {
if (selectedRange.length == 2)
if (i < selectedRange[0] || i > selectedRange[1])
continue;
if (data[n]['x'] != null) {
data[n][0] = data[n].x;
data[n][1] = data[n].y;
}
if (data[n][1] != null) {
sum[0] += data[n][0]; //Σ(X)
sum[1] += data[n][1]; //Σ(Y)
sum[2] += data[n][0] * data[n][0]; //Σ(X^2)
sum[3] += data[n][0] * data[n][1]; //Σ(XY)
sum[4] += data[n][1] * data[n][1]; //Σ(Y^2)
} else {
N -= 1;
}
n++;
}
}
再次考虑将 selectedRange 添加到函数参数并添加以下行:
if (selectedRange.length == 2)
if (i < selectedRange[0] || i > selectedRange[1])
continue;
并且i = 0
和n++
。
最后,要使用它,您可以在系列中使用的 regressionSetting 对象中传递 selectedRange 属性。
关于javascript - 基于范围内的数据而不是完整数据集计算线性回归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54897430/
我有三个 td,并且正在尝试将每个内部的函数限制为仅该 td。我该怎么做呢?使用此代码,它会获取所有 3 个图像并将它们全部插入到 h2 之前: jQuery("td.frontpage_news")
这是所需的通用公式:if((b2-b1)=c1,True,False但是,我需要 b2-b1约等于 c1 , 在 5 内大约单位(在本例中为秒)。有没有可以处理这个的函数? 最佳答案 你也可以试试这个
我有三个整数,作为命令行参数传入后赋值给变量。我想验证每个整数都在 1-5 范围内。有没有一种方法可以在不使用如下所示的 if 语句的情况下在 Java 中完成此操作?我想避免这样做(注意伪代码):
检查某个变量 X 是否在某个变量 Z 的 n 个数字之内的最简洁方法是什么。n 是任意定义的数字(即 3)。 所以我想要 if (z {something} x){ // run code i
我的顶级 build.gradle (Gradle 2.2) 中有类似的东西 ext.repo = "https://my-artifactory-repo" buildscript { re
我只是在我的 jsp 页面中进行随机技巧和测试。我想使用 Attributes 将 request 范围对象存储在 session 范围对象中。存储后,当尝试从请求属性中提取值(存储在 session
我正在使用 Spring 。我有一个外部化属性文件。我正在按如下方式加载它。 现在我如何将 session 中的属性作为键值对保存? 我尝试编写一个扩展 ServletContextListene
我有以下范围: scope :billable, -> (range_start = nil, range_end = nil) { joins(:bids) .where("au
请看我的示例代码: var testObject = new SomeClass(); using (testObject) { //At this point how can the te
我目前在保持在 vector 范围内时遇到一些问题。 在下面的代码中,我试图检查正在检查的数字是否小于或等于它后面的数字 #include #include #include bool fun(
有人可以帮我解决下面的(简化的)代码吗?我试图从幻灯片事件函数中调用 doTheSlide() 函数。我对 JS 范围的理解仍然有点可疑。 实现这一目标的正确方法是什么?我收到此错误: Uncaugh
如何在 Swift 中检查时间是否在下午 6 点到晚上 11 点之间?我在使用 NSDateFormatter 时遇到了困难,我觉得一定有更简单的方法。 最佳答案 使用NSCalendar: let
我目前正在尝试创建一个 2D 横向滚动条,并且我目前有我的“世界”绘图(暂时是一个大白框),但我无法弄清楚世界地图的边缘与边缘之间的任何关系确保视口(viewport)始终完全被 map 覆盖。 我的
我正在学习李普曼,而且我只是在学习。我在这里尝试编写一个代码,该代码将返回 vector 中的最小元素。当我在 Codeblocks 中编译我的代码时,它说:“模板声明不能出现在 block 范围内”
我有三个日期对象。我该如何比较它们才能确定它们之间的相对差异。 oldDate = newDate() - 5; midDate = newDate() - 2.5; newDate = newDat
我需要检查对象“objCR”是否存在于当前范围内。我尝试使用以下代码。 if(objCR == null) alert("object is not defined"); 让我知道哪里错了。 最佳答案
如何检查 IP 地址是否属于私有(private)类别? if(isPrivateIPAddress(ipAddress)) { //do something } 如有
我正在开发一个 Firefox 插件,它可以转换用户通过用户选择突出显示的屏幕温度。转换后,用户选择将替换为 ID 为 alreadyconverted 的 span HTML 元素,其中包含原始温度
我正在开发一个邮资应用程序,该应用程序需要根据多个邮政编码范围检查整数邮政编码,并根据邮政编码匹配的范围返回不同的代码。 每个代码都有多个邮政编码范围。例如,如果邮政编码在 1000-2429、254
我正在使用 excel 范围进行连接:Set rng = Range("A1:A8")如果范围内的单元格之一为空,则会添加一个空格。 你如何阻止这个空间被添加? 最佳答案 假设您在那些非空单元格中有常
我是一名优秀的程序员,十分优秀!