日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

stm32CAN波特率计算小程序(QT源码)

發布時間:2024/10/14 c/c++ 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 stm32CAN波特率计算小程序(QT源码) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
  • 軟件:Qt Creator
  • 開發環境:Window7

用qt做得一個計算波特率的小程序,在實際的應用中我們設置波特率的時候是通過以下參數來定的:

CAN_InitStructure.CAN_SJW=CAN_SJW_1tq; CAN_InitStructure.CAN_BS1=CAN_BS1_9tq; CAN_InitStructure.CAN_BS2=CAN_BS2_6tq; CAN_InitStructure.CAN_Prescaler=5;

波特率計算小程序的截圖:

根據所需的的采樣點、波特率以及錯誤率得到以上外設初始化所需的參數。

據網上資料,采樣點的設置有以下規律:

75% when 波特率 > 800K 80% when 波特率 > 500K 87.5% when 波特率 <= 500K

下面附上部分qt的源代碼:

#include "mainwindow.h" #include "ui_mainwindow.h" #include <QStandardItemModel> #include <qDebug>MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow) {ui->setupUi(this);m_model=new QStandardItemModel;m_model->setColumnCount(6);/*設置表頭信息*/m_model->setHeaderData(0,Qt::Horizontal,QString::fromUtf8("BS1"));m_model->setHeaderData(1,Qt::Horizontal,QString::fromUtf8("BS2"));m_model->setHeaderData(2,Qt::Horizontal,QString::fromUtf8("BRP"));m_model->setHeaderData(3,Qt::Horizontal,QString::fromUtf8("Sample Point"));m_model->setHeaderData(4,Qt::Horizontal,QString::fromUtf8("Baud Rate"));m_model->setHeaderData(5,Qt::Horizontal,QString::fromUtf8("Error"));ui->tableView->setModel(m_model);//將這個model套用到tableview上ui->tableView->setSelectionBehavior(QAbstractItemView::SelectRows);//鼠標點擊就會選中整行ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);//列表內容不可編輯}MainWindow::~MainWindow() {delete ui,m_model; }int MainWindow::getUsrValue(QString str)//提取控件當前text字符串中的數字 {QString tmp;for(int j = 0; j < str.length(); j++){if(str[j] >= '0' && str[j] <= '9')tmp.append(str[j]);}return tmp.toInt(); } float MainWindow::getAbsolutevalue(float num1,float num2)//求絕對值 {return (num1>num2)?(num1-num2):(num2-num1); } void MainWindow::putResult_Row(int i,int j,int tempBrp,float SamplePoint,float BaudRate,float Error)//輸出打印一行的結果 {m_model->setItem(row,0,new QStandardItem(QString("CAN_BS1_%1tq").arg(i)));m_model->setItem(row,1,new QStandardItem(QString("CAN_BS2_%1tq").arg(j)));m_model->setItem(row,2,new QStandardItem(QString::number(tempBrp)));m_model->setItem(row,3,new QStandardItem(QString::number(SamplePoint*100,'f',1)+"%"));m_model->setItem(row,4,new QStandardItem(QString::number(BaudRate,'f',1)));m_model->setItem(row,5,new QStandardItem(QString::number(Error,'f',1)+"%"));row++; } void MainWindow::on_pushButton_clicked() //當按鈕按下時執行的函數 {int i,j,tempBrp,tempBrp1,tempBrp2;float SamplePoint,BaudRate,Error;row=0;m_model->removeRows(0,m_model->rowCount());UsrSP_value=this->getUsrValue(ui->comboBox->currentText());UsrER_value=this->getUsrValue(ui->comboBox_2->currentText());UsrAPB_value=ui->lineEdit->text().toFloat();UsrBR_value=ui->lineEdit_2->text().toFloat();for(i=1;i<17;i++) //BS1的范圍 1-16{for(j=1;j<9;j++) //BS2的范圍 1-8{SamplePoint=(1+i*1.0)/(1+i*1.0+j*1.0); //求出采樣點if((SamplePoint*100)>=(float)UsrSP_value) //滿足采樣點所設要求則進入下一步篩選{tempBrp=UsrAPB_value*1000/((1+i+j)*UsrBR_value); //求出分頻if(tempBrp>1){//qDebug() <<tempBrp <<i <<j;BaudRate=(UsrAPB_value*1000)/(tempBrp*(1+i+j)*1.0); //求出實際波特率//qDebug() <<BaudRate;Error=(this->getAbsolutevalue(BaudRate,UsrBR_value)/UsrBR_value)*100;//求出錯誤率//qDebug() <<Error <<"%" <<endl;if(Error>UsrER_value) continue; //如果錯誤率大于要求的 則放棄這一次循環輸出 直接跳到下一次循環this->putResult_Row(i,j,tempBrp,SamplePoint,BaudRate,Error);}tempBrp1=tempBrp;tempBrp2=tempBrp;/*分別向tempBrp正反方向拓展 尋找更多合適的tempBrp*/while(tempBrp1--){if(tempBrp1<2) break;//qDebug() <<tempBrp <<i <<j;BaudRate=(UsrAPB_value*1000)/(tempBrp1*(1+i+j)*1.0); //求出實際波特率//qDebug() <<BaudRate;Error=(this->getAbsolutevalue(BaudRate,UsrBR_value)/UsrBR_value)*100;//求出錯誤率//qDebug() <<Error <<"%" <<endl;if(Error>UsrER_value) break; //如果錯誤率大于要求的 則跳出while循環this->putResult_Row(i,j,tempBrp1,SamplePoint,BaudRate,Error);}while(tempBrp2++){//qDebug() <<tempBrp <<i <<j;BaudRate=(UsrAPB_value*1000)/(tempBrp2*(1+i+j)*1.0); //求出實際波特率//qDebug() <<BaudRate;Error=(this->getAbsolutevalue(BaudRate,UsrBR_value)/UsrBR_value)*100;//求出錯誤率//qDebug() <<Error <<"%" <<endl;if(Error>UsrER_value) break; //如果錯誤率大于要求的 則跳出循環this->putResult_Row(i,j,tempBrp2,SamplePoint,BaudRate,Error);}}}} }

所用到的計算公式該博客,點擊跳轉。
需要源代碼的,點擊可下載。

僅供參考,錯誤之處以及不足之處還望多多指教。

總結

以上是生活随笔為你收集整理的stm32CAN波特率计算小程序(QT源码)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 91麻豆成人精品国产免费网站 | 一区在线观看视频 | 欧美天堂网站 | 久久久久久9 | 毛片无遮挡高清免费观看 | 国产精品国产精品国产专区不卡 | 韩国av毛片| 日韩中文网 | 成人拍拍拍 | 欧美精品色呦呦 | 亚洲一区二区视频在线播放 | 美女的隐私免费看 | 成人羞羞国产免费游戏 | 国产一区二区在线观看视频 | 日韩黄色视屏 | 国产小视频你懂的 | 谁有毛片网站 | 变态另类一区二区 | 性高潮视频在线观看 | 五月天激情社区 | 中文字幕日韩三级片 | 国产aⅴ一区二区三区 | 免费在线h | 欧美人体一区二区三区 | 国产91边播边对白在线 | 91传媒视频在线观看 | 国产黄大片 | 自拍偷拍第2页 | 蜜臀av性久久久久蜜臀aⅴ | 青青偷拍视频 | 中文字幕一区二区三区人妻 | 日本福利小视频 | 538国产精品一区二区 | 中文在线观看高清视频 | 欧美性受xxxx黑人 | 中文字幕影院 | 漂亮人妻被黑人久久精品 | 午夜视频网站在线观看 | 播色网 | av最新版天堂资源在线 | 钻石午夜影院 | 亚洲综合久久婷婷 | 五月天婷婷在线播放 | 久久xx| 丁香婷婷色 | 又色又爽又高潮免费视频国产 | www麻豆| 婷婷的五月 | 97超碰成人 | 午夜成年人视频 | 国产欧美激情视频 | 中文字幕在线观看播放 | 免费a级黄色片 | 老汉av在线 | 欧美一级片a | 成人久久一区二区 | 日韩精品中文在线 | 中文字幕无线精品亚洲乱码一区 | 成年人免费网站 | 成人欧美一区二区三区黑人动态图 | 成人免费在线电影 | 国产又粗又猛又爽又黄91精品 | 麻豆精品久久久久久久99蜜桃 | va在线播放 | 性一交一乱一色一视频麻豆 | 欧美成人免费在线视频 | 色婷婷18| 中文字幕乱码在线 | 久久成人a | 欧美一级片在线观看 | 亚洲欧美国产视频 | 亚洲成人精品一区 | 日韩在线视频在线 | 中文字幕av一区二区三区人妻少妇 | 欧美乱妇在线观看 | 久草在| 潮见百合子 | 日日干天天 | a在线 | 国产精品无码一区二区三区免费 | 一级特黄色大片 | 欧美自拍偷拍一区二区 | 不卡欧美 | 深夜福利免费视频 | 72成人网| 国产精品久久婷婷六月丁香 | 中文字幕在线免费视频 | 超碰p| 奇米网狠狠干 | av一区三区| 四虎影视免费永久大全 | 欧美激情影音先锋 | 超碰caoprom| 伊人国产在线观看 | 天堂婷婷 | 91福利视频导航 | av毛片在线播放 | 69精品人人| 毛茸茸多毛bbb毛多视频 |