亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++ Eigen庫實現(xiàn)最小二乘擬合的示例代碼

 更新時間:2023年07月19日 14:24:23   作者:RockWang.  
Eigen 是一個線性算術的 C++ 模板庫,功能強大、快速、優(yōu)雅以及支持多平臺,本文主要為大家介紹了C++利用Eigen庫實現(xiàn)最小二乘擬合的示例代碼,希望對大家有所幫助

前言

入職第二周的任務是將導師的Python代碼C化,發(fā)現(xiàn)Python中存在Numpy包直接調(diào)用np.polyfit就好了,但是C++不存在需要造輪子。

示例代碼

#include <iostream>
#include <cmath>
#include <vector>
#include <Eigen/QR>
#include "xtensor/xarray.hpp"
void polyfit(	const std::vector<double> &t,
                 const std::vector<double> &v,
                 std::vector<double> &coeff,
                 int order

)
{
    // Create Matrix Placeholder of size n x k, n= number of datapoints, k = order of polynomial, for exame k = 3 for cubic polynomial
    Eigen::MatrixXd T(t.size(), order + 1);
    Eigen::VectorXd V = Eigen::VectorXd::Map(&v.front(), v.size());
    //std::cout<<"ceshi"<<std::endl;
    //std::cout<<V<<std::endl;
    Eigen::VectorXd result;

    // check to make sure inputs are correct
    assert(t.size() == v.size());
    assert(t.size() >= order + 1);
    // Populate the matrix
    for(size_t i = 0 ; i < t.size(); ++i)
    {
        for(size_t j = 0; j < order + 1; ++j)
        {
            T(i, j) = pow(t.at(i), j);
        }
    }
    std::cout<<T<<std::endl;

    // Solve for linear least square fit
    result  = T.householderQr().solve(V);
    coeff.resize(order+1);
    for (int k = 0; k < order+1; k++)
    {
        coeff[k] = result[k];
    }

}

int main()
{
    // time value
    std::vector<double> time = {-2, 4, 6, 7, 9};
    std::vector<double> velocity = {5, 17, 37, 49, 82};

    // placeholder for storing polynomial coefficient
    std::vector<double> coeff ;
    polyfit(time, velocity, coeff, 2);
    xt::xarray<double> c = xt::zeros<double>({3});
    for(int i = 0; i < coeff.size(); i++)
    {
        c[i] = coeff[i];
    }
    
    std::vector<double> fitted_velocity;
    std::cout<< "Printing fitted values" << std::endl;
    for(int p = 0; p < time.size(); ++ p)
    {
        double vfitted = coeff[0] + coeff[1]*time.at(p) + coeff[2]*(pow(time.at(p), 2)) ;
        std::cout<< vfitted<<", ";
        fitted_velocity.push_back(vfitted);
    }
    std::cout<<std::endl;
    for(int i  = 0; i < c.size(); i++)
    {
        std::cout<<c[i]<<std::endl;
    }
    std::cout<<std::endl;


    return 0;
}

輸出結果

到此這篇關于C++ Eigen庫實現(xiàn)最小二乘擬合的示例代碼的文章就介紹到這了,更多相關C++ Eigen內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C++lambda表達式使用介紹

    C++lambda表達式使用介紹

    Lambda 表達式(lambda expression)是一個匿名函數(shù),Lambda表達式基于數(shù)學中的λ演算得名。本文就來為大家詳細講講C++中Lambda表達式的使用,需要的可以參考一下
    2022-08-08
  • C++實現(xiàn)學生考勤信息管理系統(tǒng)

    C++實現(xiàn)學生考勤信息管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)學生考勤信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • QT5中使用QRegularExpression代替QRegExp方法代碼

    QT5中使用QRegularExpression代替QRegExp方法代碼

    這篇文章主要給大家介紹了關于QT5中使用QRegularExpression代替QRegExp的相關資料,正則表達式(regep)是處理字符串和文本的強大工具,驗證regexp可以測試子字符串是否滿足某些條件,例如是整數(shù)或不包含空格,需要的朋友可以參考下
    2024-04-04
  • c++只保留float型的小數(shù)點后兩位問題

    c++只保留float型的小數(shù)點后兩位問題

    這篇文章主要介紹了c++只保留float型的小數(shù)點后兩位問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C語言 指針變量作為函數(shù)參數(shù)詳解

    C語言 指針變量作為函數(shù)參數(shù)詳解

    本文主要介紹C語言 指針變量作為函數(shù)參數(shù),這里整理了相關資料和示例代碼,以便大家學習參考理解知識點,有需要的小伙伴可以參考下
    2016-08-08
  • C語言中結構體(struct)的幾種初始化方法

    C語言中結構體(struct)的幾種初始化方法

    相信大家都知道struct結構體是C語言中非常重要的復合類型,初始化的方法很多,那么小編下面對這些方法進行總結,便于自己和大家以后查閱,有需要的可以參考借鑒。
    2016-08-08
  • 淺談C++不同繼承之間的關系

    淺談C++不同繼承之間的關系

    本文主要介紹了淺談C++不同繼承之間的關系,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • 基于c的for循環(huán)中改變變量值的問題

    基于c的for循環(huán)中改變變量值的問題

    本篇文章是對c語言的for循環(huán)中改變變量值的問題進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++對象的動態(tài)建立與釋放詳解

    C++對象的動態(tài)建立與釋放詳解

    我們知道可以用new運算符可以動態(tài)的分配內(nèi)存,用delete運算符可以釋放這些內(nèi)存。當我們使用new運算符動態(tài)的分配一個內(nèi)存之后,會自動返回一個該內(nèi)存段的起始地址,也就是指針。
    2013-10-10
  • C語言實現(xiàn)隊列的示例詳解

    C語言實現(xiàn)隊列的示例詳解

    隊列是一種特殊的線性表,特殊之處在于它只允許在表的前端(head)進行刪除操作,而在表的后端(tail)進行插入操作。本文將用C語言實現(xiàn)隊列,感興趣的可以了解一下
    2022-06-06

最新評論