当前位置:首页 > JavaScript

用js实现线性回归

2026-03-01 18:54:18JavaScript

实现线性回归的基本原理

线性回归通过最小化预测值与真实值之间的平方误差(最小二乘法),拟合出最佳直线方程 $y = mx + b$。在JavaScript中可以通过以下步骤实现:

计算斜率和截距

斜率 $m$ 和截距 $b$ 的计算公式如下: $$ m = \frac{n\sum xy - (\sum x)(\sum y)}{n\sum x^2 - (\sum x)^2} $$ $$ b = \frac{\sum y - m \sum x}{n} $$

用js实现线性回归

function linearRegression(x, y) {
    const n = x.length;
    let sumX = 0, sumY = 0, sumXY = 0, sumXX = 0;

    for (let i = 0; i < n; i++) {
        sumX += x[i];
        sumY += y[i];
        sumXY += x[i] * y[i];
        sumXX += x[i] * x[i];
    }

    const m = (n * sumXY - sumX * sumY) / (n * sumXX - sumX * sumX);
    const b = (sumY - m * sumX) / n;

    return { m, b };
}

使用示例

const x = [1, 2, 3, 4, 5];
const y = [2, 4, 5, 4, 5];

const { m, b } = linearRegression(x, y);
console.log(`回归方程: y = ${m}x + ${b}`); // 输出如 y = 0.6x + 2.2

预测新数据点

利用拟合的方程进行预测:

function predict(x, m, b) {
    return m * x + b;
}

console.log(predict(6, m, b)); // 预测x=6时的y值

可视化实现(可选)

结合Canvas或图表库(如Chart.js)绘制数据点和回归线:

用js实现线性回归

const ctx = document.getElementById('chart').getContext('2d');
new Chart(ctx, {
    type: 'scatter',
    data: {
        datasets: [{
            label: '原始数据',
            data: x.map((val, i) => ({x: val, y: y[i]})),
            backgroundColor: 'red'
        }, {
            label: '回归线',
            data: [{x: Math.min(...x), y: predict(Math.min(...x), m, b)},
                   {x: Math.max(...x), y: predict(Math.max(...x), m, b)}],
            type: 'line',
            borderColor: 'blue'
        }]
    }
});

性能优化

对于大数据集,可使用矩阵运算库(如math.js)加速计算:

const math = require('mathjs');
function matrixRegression(x, y) {
    const X = math.concat(math.ones([x.length, 1]), math.transpose([x]));
    const coeff = math.multiply(
        math.multiply(math.inv(math.multiply(math.transpose(X), X)), math.transpose(X)),
        y
    );
    return { m: coeff[1], b: coeff[0] };
}

注意事项:

  • 输入数组x和y的长度需一致
  • 极端值(如全零)可能导致计算错误
  • 对于非线性数据,需考虑多项式回归或其他模型

标签: 线性js
分享给朋友:

相关文章

js实现倒计时

js实现倒计时

使用 setInterval 实现倒计时 通过 setInterval 定时器每秒更新剩余时间,适用于简单倒计时场景。 function countdown(seconds, callback) {…

js如何实现继承

js如何实现继承

原型链继承 通过将子类的原型指向父类的实例实现继承。子类实例能够访问父类原型上的属性和方法。 function Parent() { this.name = 'parent'; } Parent…

jquery.js

jquery.js

jQuery 是一个快速、简洁的 JavaScript 库,简化了 HTML 文档遍历、事件处理、动画设计和 Ajax 交互等操作。以下是关于 jQuery.js 的核心信息和使用方法: 获取 jQ…

js分组实现

js分组实现

分组实现方法 在JavaScript中,可以通过多种方式实现数组或对象的分组操作。以下是几种常见的方法: 使用Array.prototype.reduce() 通过reduce方法可以轻松实现数组分…

js实现祖玛

js实现祖玛

实现祖玛游戏的核心思路 祖玛游戏的核心玩法是发射彩色珠子,形成三个或以上相同颜色的珠子即可消除。以下是使用JavaScript实现的基本框架。 游戏初始化 创建画布并初始化游戏状态: const…

vue实现js休眠

vue实现js休眠

实现 JavaScript 休眠的方法 在 Vue 中实现 JavaScript 休眠(延迟执行)可以通过以下方式实现。由于 JavaScript 本身没有内置的 sleep 函数,通常使用 Prom…