当前位置: 首页 > news >正文

徐州网络建站模板成品网站软件大全下载

徐州网络建站模板,成品网站软件大全下载,wordpress前端工具箱,做网站空间放哪些文件夹背景#xff1a; 项目中需要实现数据的高斯拟合#xff0c;进而提取数据中标准差#xff0c;手头只有opencv库#xff0c;经过资料查找验证#xff0c;总结该方法。 基础知识#xff1a; 1、opencv中solve可以实现对矩阵参数的求解#xff1b; 2、线的拟合就是对多项…背景 项目中需要实现数据的高斯拟合进而提取数据中标准差手头只有opencv库经过资料查找验证总结该方法。 基础知识 1、opencv中solve可以实现对矩阵参数的求解 2、线的拟合就是对多项式参数求解的过程多项式可表示为矩阵形式 3、高斯公式中的指数幂可以通过取对数的方式转变成多项式的形式 求解思路 高斯公式-多项式公式-矩阵参数-调用solve求解 实现过程及代码 1、确定所选的高斯公式形式 G(x)a*exp(-((x-b)/c)^2); 2、对于给定的输入x1 ~ xn,有对输出y1 ~ yn。可以形成如下等式 对等式左右两边取对数并进行变换可形成如下形式 这里就形成了AX^2BXCY的形式其中 用A,B,C替换后后原等式可写作 此时我们只需要计算出A,B,C的值再通过ABC与abc的关系即可得到abc的值。(请读者自行推导abc的公式或见代码部分) 得到如上的多项式的形式后直接构造参数矩阵调用cv::solve(X,Y,A‘)接口即可得到参数矩阵A’其中即含有A,BC的值。 上代码 基础定义 typedef struct StructMultinomialParamt {double dB0;//多项式拟合的参数,数字表示幂次double dB1;double dB2; }S_MULTNMNL_PARAMT; typedef struct StructGaussParamT {double dA;//指定的高斯参数double dB;//中心点double dC;//标准差 }S_GAUS_PARAMT; void Gauss(S_GAUS_PARAMT sGsParamm, cv::Mat mX, cv::Mat mY) {cv::Mat mRslt Mat::zeros(mX.size(), mX.type());double dx 0;for (double i 0.; i mX.cols; i){for (double j 0.; j mX.rows; j){dx mX.atdouble(j, i);mRslt.atdouble(j, i) sGsParamm.dA * exp(-(pow((dx - sGsParamm.dB) / sGsParamm.dC, 2)));}}mY mRslt;return; }高斯参数求解函数 void GaussFitT(cv::Mat mX, cv::Mat mY, S_GAUS_PARAMT* psGsParamm) {//step1 构造参数矩阵mx与mycv::Mat X Mat::zeros(mX.rows, 3, CV_64FC1);for (size_t i 0; i mX.rows; i){for (size_t J 0; J 3; J){X.atdouble(i, J) pow(mX.atdouble(i, 0), 2 - J);}}cv::log(mY, mY);//对结果取对数//step2 多项式拟合cv::Mat A;//参数矩阵cv::solve(X, mY, A, cv::DECOMP_SVD);S_MULTNMNL_PARAMT sBparam;sBparam.dB2 A.atdouble(0);sBparam.dB1 A.atdouble(1);sBparam.dB0 A.atdouble(2);//step3 高斯参数计算ABC-》abcpsGsParamm-dA exp(sBparam.dB0 - pow(sBparam.dB1, 2) / (4 * sBparam.dB2));psGsParamm-dB -sBparam.dB1 / (2 * sBparam.dB2);psGsParamm-dC sqrt(-1 / sBparam.dB2);return; }# 测试代码 double dX[50];//输入数据X double dY[50];//输入数据Y std::vectorcv::Point pointsOri;for (int i 0; i 50; i) {dX[i] double(i);dY[i] -0.5 * pow((dX[i] - 25), 2) 320 i;pointsOri.push_back(cv::Point(dX[i], dY[i])); } //转换成求解函数输入需要的数据格式 cv::Mat mGsInputX Mat::zeros(50, 1, CV_64FC1); cv::Mat mGsInputY Mat::zeros(50, 1, CV_64FC1); for (size_t i 0; i 50; i) {mGsInputX.atdouble(i) dX[i];mGsInputY.atdouble(i) dY[i]; }S_GAUS_PARAMT sGsParamm;//求解结果 GaussFitT(mGsInputX, mGsInputY, sGsParamm);//结果对比 Mat mGsOutputY; Gauss(sGsParamm, mGsInputX, mGsOutputY); std::vectorcv::Point pointsNew;//拟合结果 for (int i 0; i 50; i) {pointsNew.push_back(cv::Point(dX[i], mGsOutputY.atdouble(i))); } cv::Mat img(450, 60, CV_8UC3, cv::Scalar(0, 0, 0)); cv::polylines(img, std::vectorstd::vectorcv::Point{pointsOri}, false, cv::Scalar(0, 0, 255), 2); cv::polylines(img, std::vectorstd::vectorcv::Point{pointsNew}, false, cv::Scalar(255, 255, 255), 0.5);// 显示图像 cv::imshow(Line Chart, img); cv::waitKey(0);运行输出 红色的为原始数据分布白色的为拟合计算结果。 而我需要的标准差则为sGsParamm.dC。 参考:https://blog.csdn.net/guangjie2333/article/details/115629152 https://blog.csdn.net/KYJL888/article/details/103073956 https://blog.csdn.net/qq_35097289/article/details/103910984 后记 调用solve的接口求解时OPENCV提供了以下六种方式以对应不同的情况。对于多项式的求解也可以采用最小二乘法的逼近不再调用solve方法这块后面再填坑吧。 cv::DECOMP_LU 高斯消元法LU分解 cv::DECOMP_SVD 奇异值分解SVD cv::DECOMP_CHOLESKY 对于对称正定矩阵 cv::DECOMP_EIG 特征值分解只用于对称矩阵 cv::DECOMP_QR QR因式分解 cv::DECOMP_NORMAL 可选附加标志表示要求解标准方程
http://www.dnsts.com.cn/news/24486.html

相关文章:

  • 百度网网站建设的目标成都哪家做网站建设比较好
  • 网上购物网站开发的背景金峰辉网站建设
  • 外贸营销网站制作上海百度推广平台
  • 常熟的彩钢板 中企动力做的网站人员证书查询
  • 网站开发的语言有什么软件广西省建设厅网站
  • 商务网站建设实训报告甘肃省住房和建设厅网站首页
  • 建网站花多少钱如何在网站上做网盘
  • 网站上线多久才能百度360网站 备案
  • 网站运营经验找公司做网站要注意什么问题
  • app制作简易网站河南一般建一个网站需要多少钱
  • 网站项目案例深圳手机网站建设价格
  • 怎么做装球的网站郑州注册公司费用
  • 上海网站运营成都 做网站
  • 网站维护 内容四举措加强网站建设
  • 一站式手机网站制作苏州建筑工程有限公司
  • 上饶哪里做网站公司想做个自己的网站怎么做的
  • 网站建设费应怎样做会计分录品牌app定制
  • 做网站有哪些流程同仁seo排名优化培训
  • 重庆建设网站公司简介查询网站的二级域名
  • 注册域名的网站重庆网站开发哪家专业
  • 中国公司100强排名淄博seo网络公司
  • 宁波网站建设流程图漳州市城乡住房建设局网站
  • 老河口网站建设python做网站和php
  • 深圳做公司网站长沙室内设计
  • 蚌埠集团网站建设wordpress中文模版
  • 山西网站制作十大电脑必玩大型免费网游
  • 网站做多长时间才会有流量多少个网站
  • 哪些做任务可以赚钱的网站wordpress建站程序
  • 仁怀哪里可以做网站游戏网站开发难度
  • 广东seo网站推广代运营wordpress 老萨