三次样条插值法的C代码

给定一组数据(xi,yi)(i=0,1,2,...,n),以及边界条件S(x0)=M0,S(xn)=Mn,用三次样条插值方法计算在插值点x处的S(x)值,n+1表示节点个数。

三次样条插值法

#include "stdio.h"
#define n 3
main()
{
    int i, j, k;
    float F[n + 1], X[n + 1], M[n + 1], h[n], A[n - 1], B[n - 1], C[n - 1], d[n - 1], xx, yy;
    printf("输入插值节点");
    for (i = 0; i <= n; i++)
    {
        printf("X[%d]=", i); scanf("%f", &X[i]);
    }
    printf("输入函数值");
    for (int i = 0; i < n; i++)
    {
        printf("F[%d]=", i); scanf("%f", &F[i]);
    }
    printf("输入边界条件");
    printf("M[0]="); scanf("%f", &M[0]);
    printf("M[n]="); scanf("%f", &M[n]);
    printf("输入插值点");
    printf("xx="); scanf("%f", &xx);
    for (i = 0; i < n - 1; i++)
    {
        d[i] = 6 * ((F[i + 2] - F[i]) / (h[i + 1] + h[i]) - (F[i + 1] - F[i]) / h[i]) / h[i + 1];
        A[i] = h[i] / (h[i + 1] + h[i]);
        C[i] = h[i + 1] / (h[i + 1] + h[i]);
        B[i] = 2.0;
    }
    d[0] = d[0] - A[0] * M[0];
    d[n - 2] = d[n - 2] - C[n - 2] * M[n];
    //用追赶法解三对角线性方程组
    M[1] = d[0];
    for (i = 0; i < n - 1; i++)
    {
        A[i] = A[i] / B[i - 1];
        B[i] = B[i] - A[i] * C[i - 1];
        M[i + 1] = d[i] - A[i] * M[i];
    }
    M[n - 2] = M[n - 2] / B[n - 2];
    for (i = n - 3; i >= 0; i--)
        M[i] = (M[i] - C[i] * M[i + 1]) / B[i];
    for (i = 0; i < n; i++)
    {
        if (xx > X[i] && xx < X[i + 1])
        {
            yy =  pow(M[i] *(X[i + 1] - xx),3 )/ (6 * h[i]) + (F[i] - pow(M[i] * h[i],2) / 6)*(X[i + 1] - xx) / h[i];
            yy = yy + (F[i + 1] -  pow(M[i + 1] * h[i],2) / 6)*(xx - X[i]) / h[i] +  pow(M[i + 1] * (xx - X[i]),3) / (6 * h[i]);
        }
        
    }
    printf("输出结果 yy=%f", yy);
}
  • 1
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值