C語言計算誤碼率

#include <stdio.h>
#include <stdlib.h>

bool dayin=true; //是否打印?

int main(){
?? ?
?? ?int i,k,g=0;
?? ?int n1=0,n2=0;
?? ?int good=0,bad=0;
?? ?double rate;
?? ?(dayin)? printf("打印具體數據\n"):printf("不打印具體數據\n\n");
?? ?FILE *fpRead=fopen("D:\\Alice.dat","r");
?? ?if(fpRead==NULL)
?? ?{
?? ??? ?return 111;
?? ?}
?? ?fseek(fpRead, 0, SEEK_END);
?? ?n1 = ftell(fpRead);
?? ?unsigned char *left = (unsigned char*)malloc(n1);
?? ?fseek(fpRead, 0, SEEK_SET);
?? ?fread(left, n1, 1, fpRead);

?? ?/*printf("left數組數據為:\n");
?? ?for(i=0;i<n1;i++){
?? ??? ?printf("%02X ", left[i]);
?? ?}*/
?? ?printf("\n共%d個\n\n",n1);
?? ?fclose(fpRead);
?? ?
?? ?FILE *fpRead2=fopen("D:\\Bob.dat","r");
?? ?if(fpRead2==NULL)
?? ?{
?? ??? ?free(left);
?? ??? ?return 222;
?? ?}
?? ?fseek(fpRead2, 0, SEEK_END);
?? ?n2 = ftell(fpRead2);
?? ?unsigned char *right = (unsigned char*)malloc(n2);
?? ?fseek(fpRead2, 0, SEEK_SET);
?? ?fread(right, n2, 1, fpRead2);
?? ?/*printf("right數組數據為:\n");
?? ?for(i=0;i<n2;i++){
?? ??? ?printf("%02X ", right[i]);
?? ?}*/
?? ?printf("\n共%d個\n\n",n2);
?? ?fclose(fpRead2);
?? ??? ?
?? ?
?? ?printf("檢查數據是否正確,按回車鍵進行下一步。\n");
?? ?getchar();
?? ?if(n1!=n2){
?? ??? ?printf("!兩邊數據個數不等!\n");
?? ??? ?free(left);
?? ??? ?free(right);
?? ??? ?return 333;
?? ?}?
?? ?if(n1%2!=0){
?? ??? ?printf("!二進制數據個數必須為偶數!\n");
?? ??? ?free(left);
?? ??? ?free(right);
?? ??? ?return 444;
?? ?}

?? ?printf("開始比對\n");
?? ?for(i=0;i<=n1-2;i++){ ?//有n1個數,對應編號left[n-1],為二進制中的第二個數,故只要循環至n1-2即可?
?? ??? ?if(i%2==1) ?continue; ?//每兩個01為一組?
?? ??? ?if(left[i]!=right[i]) { //若第一個數不同則跳過?
?? ??? ?g++;
?? ??? ?continue;
?? ??? ?} ?
?? ??? ?if(left[i+1]==right[i+1]) good++;
?? ??? ?else {
?? ??? ?bad++;
?? ??? ?if(dayin==true)printf("第%d組數不同,分別為%d%d和%d%d\n",i/2+1,left[i],left[i+1],right[i],right[i+1]);?
?? ?}
?? ?}
?? ?if((g+good+bad)!=(n1/2)){
?? ??? ?printf("比對過程中數據遺漏?");
?? ??? ?free(left);
?? ??? ?free(right);
?? ??? ?return 555;?
?? ?}?
?? ?
?? ?rate=(double)bad/(double)(good+bad)*100;
?? ?printf("結果:\n基不同的共%d組。相同的二進制共%d組,不同的有%d組,誤碼率為%g%%\n",g,good,bad,rate);
?? ?printf("比對結束\n");
?? ?free(left);
?? ?free(right);
?? ?system("pause");
?? ?return 666;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/718166.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/718166.shtml
英文地址,請注明出處:http://en.pswp.cn/news/718166.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

STM32-SPI通信協議

串行外設接口SPI&#xff08;Serial Peripheral Interface&#xff09;是由Motorola公司開發的一種通用數據總線。 在某些芯片上&#xff0c;SPI接口可以配置為支持SPI協議或者支持I2S音頻協議。 SPI接口默認工作在SPI方式&#xff0c;可以通過軟件把功能從SPI模式切換…

Python·算法·每日一題(3月4日)最長公共前綴

題目 編寫一個函數來查找字符串數組中的最長公共前綴。 如果不存在公共前綴&#xff0c;返回空字符串 “”。 示例 示例 1&#xff1a; 輸入&#xff1a;strs ["flower","flow","flight"] 輸出&#xff1a;"fl"示例 2&#xff1a;…

【數據結構與算法】常見排序算法(Sorting Algorithm)

文章目錄 相關概念1. 冒泡排序&#xff08;Bubble Sort&#xff09;2. 直接插入排序&#xff08;Insertion Sort&#xff09;3. 希爾排序&#xff08;Shell Sort&#xff09;4. 直接選擇排序&#xff08;Selection Sort&#xff09;5. 堆排序&#xff08;Heap Sort&#xff09;…

【腦科學相關合集】有關腦影像數據相關介紹的筆記及有關腦網絡的筆記合集

【腦科學相關合集】有關腦影像數據相關介紹的筆記及有關腦網絡的筆記合集 前言腦模板方面相關筆記清單 基于腦網絡的方法方面數據基本方面 前言 這里&#xff0c;我將展開有關我自己關于腦影像數據相關介紹的筆記及有關腦網絡的筆記合集。其中&#xff0c;腦網絡的相關論文主要…

【錯誤處理】【Hive】【Spark】ERROR FileFormatwriter: Aborting job null.

問題背景 近日&#xff0c;使用 Spark 在讀寫 Hive 表時發生了報錯&#xff1a;Aborting job null&#xff0c;如果怎么都使用不了那張表的話&#xff0c;大概率是那張表有臟數據&#xff0c;導致整張表無法正常使用。 ERROR FileFormatwriter: Aborting job null.解決方法 …

SpringBoot 如何快速過濾出一次請求的所有日志?

前言 在現網出現故障時&#xff0c;我們經常需要獲取一次請求流程里的所有日志進行定位。如果請求只在一個線程里處理&#xff0c;則我們可以通過線程ID來過濾日志&#xff0c;但如果請求包含異步線程的處理&#xff0c;那么光靠線程ID就顯得捉襟見肘了。 華為IoT平臺&#x…

《自然》:人工智能在創造性思維方面超越人類

發散性思維被認為是創造性思維的指標。ChatGPT-4 在三項有151名人類參與的**發散思維測試中&#xff0c;**展現出比人類更高水平的創造力&#xff0c;結果顯示人工智能在創意領域持續發展。 發散性思維的特點是能夠針對沒有預期解決方案的問題提出獨特的解決方案&#xff0c;例…

TOMCAT的安裝與基本信息

一、TOMCAT簡介 Tomcat 服務器是一個免費的開放源代碼的Web 應用服務器&#xff0c;屬于輕量級應用服務器&#xff0c;在中小型系統和并發訪問用戶不是很多的場合下被普遍使用&#xff0c;是開發和調試JSP 程序的首選。對于一個初學者來說&#xff0c;可以這樣認為&#xff0c…

IO 與 NIO

優質博文&#xff1a;IT-BLOG-CN 一、阻塞IO / 非阻塞NIO 阻塞IO&#xff1a;當一條線程執行read()或者write()方法時&#xff0c;這條線程會一直阻塞直到讀取到了一些數據或者要寫出去的數據已經全部寫出&#xff0c;在這期間這條線程不能做任何其他的事情。 非阻塞NIO&…

記錄踩過的坑-macOS下使用VS Code

目錄 切換主題 安裝插件 搭建Python開發環境 裝Python插件 配置解釋器 打開項目 打開終端 切換主題 安裝插件 方法1 方法2 搭建Python開發環境 裝Python插件 配置解釋器 假設解釋器已經通過Anaconda建好&#xff0c;只需要在VS Code中關聯。 打開項目 打開終端

ArmV8架構

Armv8/armv9架構入門指南 — Armv8/armv9架構入門指南 v1.0 documentation 上面只是給了一個比較好的參考文檔 其他內容待補充

網絡-httpclient調用https服務端繞過證書的方法

httpclient調用https服務端繞過證書的方法 在日常開發或者測試中&#xff0c;通常會遇到需要用httpclient客戶端調用對方http是服務器的場景&#xff0c;由于沒有證書&#xff0c;所以直接是無法調用的。采用下面的方法可以繞過證書驗證&#xff1a; TrustManager[] trustAll…

AutoSAR(基礎入門篇)13.5-Mcal Mcu時鐘的配置

目錄 一、EB的Mcu模塊結構 二、時鐘的配置 對Mcu的配置主要就是其時鐘樹的配置,但是EB將GTM、ERU等很多重要的模塊也都放在了Mcu里面做配置,所以這里的Mcu是一個很龐大的模塊, 我們目前只講時鐘樹的部分 一、EB的Mcu模塊結構 1. 所有的模塊都基本上是這么些配置類別,Mc…

單詞級文本攻擊—論文閱讀

TAAD2.2論文概覽 0.前言1-101.Bridge the Gap Between CV and NLP! A Gradient-based Textual Adversarial Attack Frameworka. 背景b. 方法c. 結果d. 論文及代碼 2.TextHacker: Learning based Hybrid Local Search Algorithm for Text Hard-label Adversarial Attacka. 背景b…

閱讀筆記 | Transformers in Time Series: A Survey

閱讀論文&#xff1a; Wen, Qingsong, et al. “Transformers in time series: A survey.” arXiv preprint arXiv:2202.07125 (2022). 這篇綜述主要對基于Transformer的時序建模方法進行介紹。論文首先簡單介紹了Transformer的基本原理&#xff0c;包括位置編碼、多頭注意力機…

OPENAI SORA:未來視頻創作的新引擎——淺析其背后的人工智能算法

Sora - 探索AI視頻模型的無限可能 隨著人工智能技術的飛速發展&#xff0c;AI視頻模型已成為科技領域的新熱點。而在這個浪潮中&#xff0c;OpenAI推出的首個AI視頻模型Sora&#xff0c;以其卓越的性能和前瞻性的技術&#xff0c;引領著AI視頻領域的創新發展。本文將探討SORA的…

回歸預測 | Matlab實現RIME-BP霜冰算法優化BP神經網絡多變量回歸預測

回歸預測 | Matlab實現RIME-BP霜冰算法優化BP神經網絡多變量回歸預測 目錄 回歸預測 | Matlab實現RIME-BP霜冰算法優化BP神經網絡多變量回歸預測預測效果基本描述程序設計參考資料 預測效果 基本描述 1.Matlab實現RIME-BP霜冰算法優化BP神經網絡多變量回歸預測&#xff08;完整…

自動化測試介紹、selenium用法(自動化測試框架+爬蟲可用)

文章目錄 一、自動化測試1、什么是自動化測試&#xff1f;2、手工測試 vs 自動化測試3、自動化測試常見誤區4、自動化測試的優劣5、自動化測試分層6、什么項目適合自動化測試 二、Selenuim1、小例子2、用法3、頁面操作獲取輸入內容模擬點擊清空文本元素拖拽frame切換窗口切換/標…

十五 超級數據查看器 講解稿 外觀設置

十五 超級數據查看器 講解稿 外觀設置 視頻講座地址 講解稿全文: 大家好&#xff0c;今天講解超級數據查看器,詳情界面的外觀設置。 首先&#xff0c;我們打開超級數據查看器。 本節課以成語詞典為例來做講述。 我們打開成語詞典這個表&#xff0c;隨便選一條記錄點擊&#x…

AutoSAR(基礎入門篇)13.4-Mcal Dio代碼分析

目錄 一、文件結構 二、動態代碼 1、arxml文件 2、Dio_Cfg.h 3、Dio_PBCfg.c 4、小結