亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁(yè) > 知識(shí)庫(kù) > 詳解Python牛頓插值法

詳解Python牛頓插值法

熱門標(biāo)簽:公司電話機(jī)器人 激戰(zhàn)2地圖標(biāo)注 哈爾濱ai外呼系統(tǒng)定制 海南400電話如何申請(qǐng) 唐山智能外呼系統(tǒng)一般多少錢 白銀外呼系統(tǒng) 廣告地圖標(biāo)注app 陜西金融外呼系統(tǒng) 騰訊外呼線路

一、牛頓多項(xiàng)式

拉格朗日多項(xiàng)式的公式不具備遞推性,每個(gè)多項(xiàng)式需要單獨(dú)構(gòu)造。但很多時(shí)候我們需要從若干個(gè)逼近多項(xiàng)式選擇一個(gè)。這個(gè)時(shí)候我們就需要一個(gè)具有遞推關(guān)系的方法來構(gòu)造——牛頓多項(xiàng)式

這里的的a0,a1…等可以通過逐一帶入點(diǎn)的值來求得。但是當(dāng)項(xiàng)數(shù)多起來時(shí),會(huì)發(fā)現(xiàn)式子變得很大,這個(gè)時(shí)候我們便要引入差商的概念(利用差分思想)具體見式子能更好理解


這里在編程實(shí)現(xiàn)中我們可以推出相應(yīng)的差商推導(dǎo)方程

d(k,0)=y(k)
d(k,j)=(d(k,j-1)-d(k-1,j-1)) / (x(k)-x(k-j))

二、例題

【問題描述】考慮[0,3]內(nèi)的函數(shù)y=f(x)=cos(x)。利用多個(gè)(最多為6個(gè))節(jié)點(diǎn)構(gòu)造牛頓插值多項(xiàng)式。
【輸入形式】在屏幕上依次輸入在區(qū)間[0,3]內(nèi)的一個(gè)值x*,構(gòu)造插值多項(xiàng)式后求其P(x*)值,和多個(gè)節(jié)點(diǎn)的x坐標(biāo)。
【輸出形式】輸出牛頓插值多項(xiàng)式系數(shù)向量,差商矩陣,P(x*)值(保留6位有效數(shù)字),和與真實(shí)值的絕對(duì)誤差(使用科學(xué)計(jì)數(shù)法,保留小數(shù)點(diǎn)后6位有數(shù)字)。
【樣例1輸入】
0.8
0 0.5 1
【樣例1輸出】
-0.429726
-0.0299721
1
1 0 0
0.877583 -0.244835 0
0.540302 -0.674561 -0.429726
0.700998
4.291237e-03
【樣例1說明】
輸入:x為0.8,3個(gè)節(jié)點(diǎn)為(k, cos(k)),其中k = 0, 0.5, 1。
輸出:
牛頓插值多項(xiàng)式系數(shù)向量,表示P2(x)=-0.429726x^2 - 0.0299721x + 1;
3行3列的差商矩陣;
當(dāng)x
為0.8時(shí),P2(0.8)值為0.700998
與真實(shí)值的絕對(duì)誤差為:4.291237*10^(-3)
【評(píng)分標(biāo)準(zhǔn)】根據(jù)輸入得到的輸出準(zhǔn)確

三、ACcode:

C++(后面還有python代碼)

/*
 * @Author: csc
 * @Date: 2021-04-30 08:52:45
 * @LastEditTime: 2021-04-30 11:57:46
 * @LastEditors: Please set LastEditors
 * @Description: In User Settings Edit
 * @FilePath: \code_formal\course\cal\newton_quo.cpp
 */
#include bits/stdc++.h>
#define pr printf
#define sc scanf
#define for0(i, n) for (i = 0; i  n; i++)
#define for1n(i, n) for (i = 1; i = n; i++)
#define forab(i, a, b) for (i = a; i = b; i++)
#define forba(i, a, b) for (i = b; i >= a; i--)
#define pb push_back
#define eb emplace_back
#define fi first
#define se second
#define int long long
#define pii pairint, int>
#define vi vectorint>
#define vii vectorvectorint>>
#define vt3 vectortupleint, int, int>>
#define mem(ara, n) memset(ara, n, sizeof(ara))
#define memb(ara) memset(ara, false, sizeof(ara))
#define all(x) (x).begin(), (x).end()
#define sq(x) ((x) * (x))
#define sz(x) x.size()
const int N = 2e5 + 100;
const int mod = 1e9 + 7;
namespace often
{
    inline void input(int res)
    {
        char c = getchar();
        res = 0;
        int f = 1;
        while (!isdigit(c))
        {
            f ^= c == '-';
            c = getchar();
        }
        while (isdigit(c))
        {
            res = (res  3) + (res  1) + (c ^ 48);
            c = getchar();
        }
        res = f ? res : -res;
    }
    inline int qpow(int a, int b)
    {
        int ans = 1, base = a;
        while (b)
        {
            if (b  1)
                ans = (ans * base % mod + mod) % mod;
            base = (base * base % mod + mod) % mod;
            b >>= 1;
        }
        return ans;
    }
    int fact(int n)
    {
        int res = 1;
        for (int i = 1; i = n; i++)
            res = res * 1ll * i % mod;
        return res;
    }
    int C(int n, int k)
    {
        return fact(n) * 1ll * qpow(fact(k), mod - 2) % mod * 1ll * qpow(fact(n - k), mod - 2) % mod;
    }
    int exgcd(int a, int b, int x, int y)
    {
        if (b == 0)
        {
            x = 1, y = 0;
            return a;
        }
        int res = exgcd(b, a % b, x, y);
        int t = y;
        y = x - (a / b) * y;
        x = t;
        return res;
    }
    int invmod(int a, int mod)
    {
        int x, y;
        exgcd(a, mod, x, y);
        x %= mod;
        if (x  0)
            x += mod;
        return x;
    }
}
using namespace often;
using namespace std;

int n;

signed main()
{
    auto polymul = [](vectordouble> v, double er) {
        v.emplace_back(0);
        vectordouble> _ = v;
        int m = sz(v);
        for (int i = 1; i  m; i++)
            v[i] += er * _[i - 1];
    };
    auto polyval = [](vectordouble> const c, double const _x) -> double {
        double res = 0.0;
        int m = sz(c);
        for (int ii = 0; ii  m; ii++)
            res += c[ii] * pow(_x, (double)(m - ii - 1));
        return res;
    };

    int __ = 1;
    //input(_);
    while (__--)
    {
        double _x, temp;
        cin >> _x;
        vectordouble> x, y;
        while (cin >> temp)
            x.emplace_back(temp), y.emplace_back(cos(temp));
        n = x.size();
        vectorvectordouble>> a(n, vectordouble>(n));
        int i, j;
        for0(i, n) a[i][0] = y[i];
        forab(j, 1, n - 1) forab(i, j, n - 1) a[i][j] = (a[i][j - 1] - a[i - 1][j - 1]) / (x[i] - x[i - j]);
        vectordouble> v;
        v.emplace_back(a[n - 1][n - 1]);
        forba(i, 0, n - 2)
        {
            polymul(v, -x[i]);
            int l = sz(v);
            v[l - 1] += a[i][i];
        }

        for0(i, n)
            pr("%g\n", v[i]);
        for0(i, n)
        {
            for0(j, n)
                pr("%g ", a[i][j]);
            puts("");
        }
        double _y =  polyval(v, _x);
        pr("%g\n", _y);
        pr("%.6e",fabs(_y-cos(_x)));
    }

    return 0;
}

python代碼

'''
Author: csc
Date: 2021-04-29 23:00:57
LastEditTime: 2021-04-30 09:58:07
LastEditors: Please set LastEditors
Description: In User Settings Edit
FilePath: \code_py\newton_.py
'''
import numpy as np


def difference_quotient(x, y):
    n = len(x)
    a = np.zeros([n, n], dtype=float)
    for i in range(n):
        a[i][0] = y[i]
    for j in range(1, n):
        for i in range(j, n):
            a[i][j] = (a[i][j-1]-a[i-1][j-1])/(x[i]-x[i-j])
    return a


def newton(x, y, _x):
    a = difference_quotient(x, y)
    n = len(x)
    s = a[n-1][n-1]
    j = n-2
    while j >= 0:
        s = np.polyadd(np.polymul(s, np.poly1d(
            [x[j]], True)), np.poly1d([a[j][j]]))
        j -= 1
    for i in range(n):
        print('%g' % s[n-1-i])
    for i in range(n):
        for j in range(n):
            print('%g' % a[i][j], end=' ')
        print()
    _y = np.polyval(s, _x)
    print('%g' % _y)
    # re_err
    real_y = np.cos(_x)
    err = abs(_y-real_y)
    print('%.6e' % err)


def main():
    _x = float(input())
    x = list(map(float, input().split()))
    y = np.cos(x)
    newton(x, y, _x)


if __name__ == '__main__':
    main()

到此這篇關(guān)于詳解Python牛頓插值法的文章就介紹到這了,更多相關(guān)Python牛頓插值法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python排序算法的簡(jiǎn)單實(shí)現(xiàn)方法
  • Python實(shí)現(xiàn)K-means聚類算法并可視化生成動(dòng)圖步驟詳解
  • 用Python給圖像算法做個(gè)簡(jiǎn)單應(yīng)用界面
  • python利用K-Means算法實(shí)現(xiàn)對(duì)數(shù)據(jù)的聚類案例詳解
  • Python機(jī)器學(xué)習(xí)之Kmeans基礎(chǔ)算法
  • Python自然語(yǔ)言處理之切分算法詳解
  • python入門之算法學(xué)習(xí)
  • python實(shí)現(xiàn)線性回歸算法
  • 盤點(diǎn)Python加密解密模塊hashlib的7種加密算法(推薦)
  • Python實(shí)現(xiàn)七大查找算法的示例代碼

標(biāo)簽:常德 黔西 鷹潭 四川 益陽(yáng) 惠州 上海 黑龍江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Python牛頓插值法》,本文關(guān)鍵詞  詳解,Python,牛頓,插值,法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解Python牛頓插值法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于詳解Python牛頓插值法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产伦久视频免费观看视频| 欧美激情一区二区三区视频 | 免费国产一级特黄aa大片在线| 精品国产一区二区三区精东影业| 久久国产精品只做精品| 日本免费看视频| 麻豆午夜视频| 美国一区二区三区| 久久99爰这里有精品国产| 青草国产在线| 精品国产一区二区三区久久久蜜臀| 国产一区二区精品在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产香蕉在线播出 | 精品国产亚一区二区三区| 精品毛片视频| 日韩专区第一页| 精品视频在线观看视频免费视频 | 免费的黄色小视频| 亚洲精品影院一区二区| 天堂网中文在线| 国产麻豆精品视频| 国产不卡高清在线观看视频| 999久久久免费精品国产牛牛| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产不卡高清在线观看视频| 精品国产一区二区三区久久久蜜臀| 深夜做爰性大片中文| 欧美国产日韩久久久| 精品国产香蕉在线播出 | 精品国产三级a| 国产视频久久久久| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 99热精品在线| 国产视频一区二区三区四区| 高清一级片| 日韩av成人| 九九热精品免费观看| 可以免费看毛片的网站| 国产美女在线一区二区三区| 青青青草影院 | 久久国产精品只做精品| 日本特黄特黄aaaaa大片| 九九久久国产精品| 国产91精品一区| 91麻豆精品国产综合久久久| 四虎影视库| 99久久网站| 99久久网站| a级毛片免费全部播放| 在线观看成人网| 欧美另类videosbestsex| 色综合久久天天综合绕观看| 999精品影视在线观看| 黄色免费三级| 亚洲精品影院一区二区| 可以免费看毛片的网站| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩综合| 亚洲精品影院一区二区| 欧美另类videosbestsex久久| 精品视频一区二区三区免费| 97视频免费在线观看| 999精品影视在线观看| 欧美大片a一级毛片视频| 精品视频在线观看视频免费视频 | 日本特黄特色aa大片免费| 国产国语在线播放视频| 99热精品在线| 国产一区二区精品| 午夜在线观看视频免费 成人| 国产国语在线播放视频| 成人a大片在线观看| 成人免费一级纶理片| 亚州视频一区二区| 国产伦精品一区二区三区在线观看| 久久国产精品只做精品| 国产一区二区精品久久| 四虎久久影院| 国产一区精品| 一级片片| 午夜激情视频在线观看| 精品久久久久久中文| 亚洲精品影院一区二区| 久草免费在线视频| 精品视频免费观看| 91麻豆精品国产综合久久久| 精品国产一区二区三区久久久狼 | 日韩女人做爰大片| 日本特黄特黄aaaaa大片| 亚洲精品中文一区不卡 | 可以在线看黄的网站| 国产麻豆精品视频| 免费一级生活片| 日韩免费片| 国产网站免费观看| 尤物视频网站在线观看| 可以免费看毛片的网站| 日本特黄特色aa大片免费| 国产精品自拍在线观看| 日韩欧美一及在线播放| 精品视频在线看 | 日韩在线观看视频免费| 可以在线看黄的网站| 美女免费精品高清毛片在线视| 成人免费网站久久久| a级毛片免费全部播放| 精品视频在线观看一区二区三区| 99久久精品国产免费| 免费国产在线观看不卡| 欧美爱色| 高清一级片| 九九干| 久久精品欧美一区二区| 国产视频久久久久| 欧美激情一区二区三区在线播放| 美国一区二区三区| 精品视频一区二区三区免费| 免费国产在线观看不卡| 精品久久久久久中文| 99久久精品费精品国产一区二区| 国产不卡高清在线观看视频| 日韩av成人| 999久久久免费精品国产牛牛| 欧美a级v片不卡在线观看| 亚洲精品影院| 成人免费网站久久久| 久久国产精品自由自在| 九九免费高清在线观看视频| 青青久久精品国产免费看| 九九干| 美国一区二区三区| 九九免费高清在线观看视频| 毛片的网站| 日韩在线观看免费完整版视频| 中文字幕一区二区三区 精品| 国产高清在线精品一区a| 99色吧| 国产一区二区精品| 久久成人亚洲| 国产成人欧美一区二区三区的| 欧美a级v片不卡在线观看| 欧美一级视| 欧美一级视| 亚洲天堂一区二区三区四区| 欧美18性精品| 欧美激情伊人| 国产精品1024永久免费视频 | 日韩欧美一及在线播放| 欧美大片a一级毛片视频| 精品视频在线看 | 久久国产精品永久免费网站| 日本特黄特色aa大片免费| 高清一级片| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美另类videosbestsex视频 | 麻豆午夜视频| 成人免费一级纶理片| 日日爽天天| 97视频免费在线观看| 亚洲精品影院| 亚洲女初尝黑人巨高清在线观看| 国产精品1024永久免费视频 | 欧美一区二区三区性| 九九九在线视频| 亚飞与亚基在线观看| 成人影院一区二区三区| 成人免费观看的视频黄页| 欧美一级视| 国产美女在线一区二区三区| 毛片的网站| 国产不卡在线观看| 久久99中文字幕| 日本特黄特色aa大片免费| 精品国产三级a| 欧美另类videosbestsex久久| 国产一级生活片| 成人a大片在线观看| 久草免费在线视频| 国产精品自拍在线观看| 日本在线不卡视频| 日本特黄特色aa大片免费| 国产一区二区精品久久| 日韩综合| 亚飞与亚基在线观看| 国产精品免费久久| 国产视频一区二区在线播放| 精品国产一区二区三区久久久蜜臀| 国产一区二区精品久久91| 免费国产在线观看不卡| 国产麻豆精品视频| 亚洲精品中文一区不卡 | 人人干人人草| 日本在线不卡视频| 国产精品自拍在线观看| 久久国产精品自由自在| 欧美激情影院| 亚洲天堂一区二区三区四区| 国产一区二区高清视频| 深夜做爰性大片中文|