[STM32] 智能温室监控系统用拉格朗日插值算法 2

[复制链接]
 楼主| 丙丁先生 发表于 2024-1-27 11:08 | 显示全部楼层 |阅读模式
以下是使用C语言实现的智能温室监控系统中的拉格朗日插值算法:

#```c
#include <stdio.h>

// 计算拉格朗日插值多项式在x处的值
float lagrange_interpolation(float x[], float y[], int n, float x0) {
    float result = 0;
    for (int i = 0; i < n; i++) {
        float term = y[i];
        for (int j = 0; j < n; j++) {
            if (j != i) {
                term *= (x0 - x[j]) / (x[i] - x[j]);
            }
        }
        result += term;
    }
    return result;
}

int main() {
    // 已知数据点
    float x[] = {1, 2, 3, 4, 5};
    float y[] = {2, 4, 6, 8, 10};
    int n = sizeof(x) / sizeof(x[0]);

    // 需要插值的点
    float x0 = 2.5;

    // 计算插值结果
    float result = lagrange_interpolation(x, y, n, x0);
    printf("插值结果为:%f\n", result);

    return 0;
}
#```

这段代码定义了一个名为`lagrange_interpolation`的函数,接受四个参数:已知数据点的横坐标数组`x`、纵坐标数组`y`、数据点个数`n`和需要插值的横坐标`x0`。函数通过遍历已知数据点,计算拉格朗日插值多项式在`x0`处的值,并返回结果。在`main`函数中,我们定义了已知数据点和需要插值的点,然后调用`lagrange_interpolation`函数计算插值结果,并输出结果。
zwsam 发表于 2024-2-9 14:22 | 显示全部楼层
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1237

主题

4918

帖子

8

粉丝
快速回复 返回顶部 返回列表