IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【C++】读取txt文件并对其中数据进行最小二乘线性拟合 -> 正文阅读

[C++知识库]【C++】读取txt文件并对其中数据进行最小二乘线性拟合


一、参考文章


C++文件类(文件流类)及用法详解

C++下string类型转double类型

最小二乘法求解直线方程系数

最小二乘法拟合直线-C++实现


二、文件流操作


3个文件流类,分别为:
ifstream:专用于从文件中读取数据;
ofstream:专用于向文件中写入数据;
fstream:既可用于从文件中读取数据,又可用于向文件中写入数据。
这 3 个文件流类都位于 fstream 头文件中。

继承关系
由上图可以看出,ifstream 类和 fstream 类是从 istream 类派生而来的。


打开文件可以通过以下两种方式:

  • 调用流对象的 open 成员函数打开文件。

在流对象上执行 open 成员函数,给出文件路径和打开模式,就可以打开文件。

	ifstream infile;
    infile.open("c:\\tmp\\test.txt", ios::in);
  • 定义文件流对象时,通过构造函数打开文件。

在构造函数中给出文件路径和打开模式也可以打开文件。

ifstream infile("c:\\tmp\\test.txt", ios::in);

判断文件打开是否成功,有两种方式:

  • 可以看 “对象名” 这个表达式的值是否为 true,如果为 true,则表示文件打开成功。
if (infile)
  • 也可以使用成员函数 fstream::is_open(),同样是返回一个bool值。
if (inflie.isopen())

当不再对打开的文件进行任何操作时,应及时调用 close() 成员方法关闭文件。

  • 调用 open() 方法打开文件,是文件流对象和文件之间建立关联的过程。
  • 调用 close() 方法关闭已打开的文件,是切断文件流对象和文件之间的关联。

附上代码:

	...

	string str;
	ifstream infile("data.txt", ios::in);	//写入文件 ros::out
	if (!infile) {
		cout << "文件读取失败!" << endl;
		return -1;
	}
	int num_point = 0;
	vector<double> xi, yi, xi2, xiyi;
	
	// istream& getline(?istream& is,?string& str,?char delim?)
	while (getline(infile, str)) {	// 读取一行的数据,并放入字符串 str 中	
		stringstream data_flow(str);	// 将整行字符串 str 读入到字符串流 data_flow 中
		string str_tmp;

		getline(data_flow, str_tmp, ',');
		xi.push_back(stod(str_tmp));	// stod 用于string 转 double
		xi2.push_back(pow(xi.back(), 2));

		getline(data_flow, str_tmp, '\0');
		yi.push_back(stod(str_tmp));
		xiyi.push_back(xi.back() * yi.back());

		num_point++;
	}
	infile.close();

	...

三、最小二乘法拟合


核心思想是使得估计出的模型与实际数据之间误差的平方和最小(趋于0),以“残差平方和最小”确定直线位置。
在误差方程的一阶导数等于0处,误差函数取得极值。具体公式可参考第三篇引用文章。

附上代码:

main.cpp

	...
	
	double tmp_xi = 0, tmp_yi = 0, tmp_xi2 = 0, tmp_xiyi = 0;
	for (int i = 0; i < xi.size(); i++) {
		tmp_xi += xi.at(i);
		tmp_yi += yi.at(i);
		tmp_xi2 += xi2.at(i);
		tmp_xiyi += xiyi.at(i);
	}
	
	Least_Squares LS(num_point, tmp_xi2, tmp_xi, tmp_xiyi, tmp_yi);

	double k, b;
	k = LS.compute_k();
	b = LS.compute_b();
	if (k == 0 && b == 0) {
		cout << "分母存在为0的情况" << endl;
	}

	cout << "k = " << k << "," << "b = " << b << endl;
	
	...

fitting.h

#ifndef _FITTING_H
#define _FITTING_H

#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <cmath>
#include <sstream>

using namespace std;

class Least_Squares {
public:
	Least_Squares(int num, double sum_xi2, double sum_xi, double sum_xiyi, double sum_yi);
	~Least_Squares() {};

	double compute_k();
	double compute_b();

private:
	int m_num;
	double m_sum_xi2;
	double m_sum_xi;
	double m_sum_xiyi;
	double m_sum_yi;
};

#endif // !_FITTING_H

fitting.cpp

#include "fitting.h"

Least_Squares::Least_Squares(int num, double sum_xi2, double sum_xi, double sum_xiyi, double sum_yi)
							:m_num(num), 
							m_sum_xi2(sum_xi2), 
							m_sum_xi(sum_xi),
							m_sum_xiyi(sum_xiyi), 
							m_sum_yi(sum_yi){

}

double Least_Squares::compute_k() {
	if ((m_sum_xi2 * m_num - m_sum_xi * m_sum_xi) != 0)
		return (m_sum_xiyi * m_num - m_sum_xi * m_sum_yi) / (m_sum_xi2 * m_num - m_sum_xi * m_sum_xi);
	else
		return 0;
}

double Least_Squares::compute_b() {
	if ((m_sum_xi2 * m_num - m_sum_xi * m_sum_xi) != 0)
		return (m_sum_xi2 * m_sum_yi - m_sum_xiyi * m_sum_xi) / (m_sum_xi2 * m_num - m_sum_xi * m_sum_xi);
	else
		return 0;
}

若有侵权,请联系我删除~
若有不足之处,还请多多指教!让我们共同进步吧!!

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-17 11:49:20  更:2021-10-17 11:50:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/15 7:45:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码