matlab cdf,Matlab 簡單計算PDF和CDF | 學步園

通信的魅力就是在于隨機性中蘊含的確定性,這也就是為什么你隨便拿出一本通信方面的教材,前面幾章都會大篇幅的講解隨機過程,隨機過程也是研究生必須深入了解的一門課,特別是對于信號處理以及通信專業的學生。

在實際工作中,通常會得到很多隨機的數,我們要分析它們的分布,最常見的就是用PDF和CDF來描述了。好了,還是舉出一個具體例子吧。

0_1328598509rrTf.gif

那么實際中我們要驗證是不是符合這樣的分布,首先看代碼再解釋:

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

% Author: ZXY

% Email: zxy_ee@163.com

% Version: 1.0

% Date: 2012-2-07

% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

close all;

clear all;

N = 100000;

x = randn(1,N);

y = randn(1,N);

r = sqrt(0.5*(x.^2 + y.^2));%每個分量的方差為0.5

step = 0.1;range = 0:step:3;

h = hist(r,range);

pr_approx_pdf = h/(step*sum(h));

pr_theory = (range/0.5).*exp(-range.^2);%0.5即為方差

figure(1)

plot(range,pr_approx_pdf,'ro',range,pr_theory,'gs-');hold on

plot(range,raylpdf(range,sqrt(0.5)),'bd')%用matlab自帶函數同樣能生成理論曲線。

xlabel('z'),ylabel('PDF'),title('The PDF of Rayleigh distribution')

legend('pr\_approx\_pdf','pr\_theory','pr\_theory\_matlab')

grid;

pr_approx_cdf = cumsum(h)/(sum(h));

figure(2)

plot(range,raylcdf(range,sqrt(0.5))),hold on

plot(range,pr_approx_cdf,'rs','LineWidth',2)

xlabel('z'),ylabel('CDF'),title('The CDF of Rayleigh distribution')

legend('pr\_theory\_matlab','pr\_approx\_cdf','Location','Best')

結果如圖:

0_1328601976hQ1u.gif

0_1328601949HnR3.gif

簡單解釋:我們用到了hist()函數來求結果,其實hist就是直方圖,小學都開始使用的計算概率的方法。hist結果是落入每個區間的個數,所以有如下的等式:

PDF = n/(n_total*step),表示了單位長度內的概率大小,而這就是概率密度!同樣,在求CDF的過程中,我們要求的是Pr(x<=X)的概率,所以我們就用了累積加函數cumsum()來獲得一個累積分布,然后在除以總個數,就得到了累積概率分布。

其實今天的寫作沖動來源于一篇博文在討論PAPR的時候,用到了CDF,我就萌生了寫點東西來總結下。同時,我想說的是,Rayleigh分布對于信道建模的重要性我就不用多說,衰落信號的包絡分布就是瑞利分布,原因我簡單解釋下(希望以后有時間展開講):我們收到的信號是由很多條獨立小徑構成的,對于窄帶信號,可以看成是乘性干擾,最后我們的信號是一個窄帶隨機過程,其同向分量與正交分量可以由中心極限定理得到是服從高斯分布的且相互獨立,那么我們就可以根據例題的定理知道,它的包絡服從瑞利分布。

PAPR的分布計算代碼:

paprSymboldB = 10*log10(paprSymbol);

[n x] = hist(paprSymboldB,[0:0.5:15]);

plot(x,cumsum(n)/nSymbol,'LineWidth',4)

xlabel('papr, x dB')

ylabel('Probability, X <=x')

title('CDF plots of PAPR from an IEEE 802.11a Tx with BPSK modulation')

grid on

結果如下:

0_1328602817tQZW.gif

后記:由于CSDN博客不支持matlab代碼,所以高亮有時很滑稽,建議大家直接view plain!

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

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

相關文章

leetcode 1232. 綴點成線

在一個 XY 坐標系中有一些點&#xff0c;我們用數組 coordinates 來分別記錄它們的坐標&#xff0c;其中 coordinates[i] [x, y] 表示橫坐標為 x、縱坐標為 y 的點。 請你來判斷&#xff0c;這些點是否在該坐標系中屬于同一條直線上&#xff0c;是則返回 true&#xff0c;否則…

mysql常用操作(一)

【數據庫設計的三大范式】1、第一范式&#xff08;1NF&#xff09;&#xff1a;數據表中的每一列&#xff0c;必須是不可拆分的最小單元。也就是確保每一列的原子性。 例如&#xff1a;userInfo:山東省煙臺市 18865518189 應拆分成 userAds山東省煙臺市 userTel188655181892、第…

pmp 成本估算準確高_如何更準確地估算JavaScript中文章的閱讀時間

pmp 成本估算準確高by Pritish Vaidya通過Pritish Vaidya 準確估算JavaScript中篇文章的閱讀時間 (Accurate estimation of read time for Medium articles in JavaScript) 介紹 (Introduction) Read Time Estimate is the estimation of the time taken by the reader to rea…

Android數據適配-ExpandableListView

Android中ListView的用法基本上學的時候都會使用&#xff0c;其中可以使用ArrayAdapter&#xff0c;SimpleAdapter&#xff0c;BaseAdapter去實現&#xff0c;這次主要使用的ExpandableListView展示一種兩層的效果&#xff0c;ExpandableListView是android中可以實現下拉list的…

JavaWeb 命名規則

命名規范命名規范命名規范命名規范 本規范主要針對java開發制定的規范項目命名項目命名項目命名項目命名 項目創建&#xff0c;名稱所有字母均小寫&#xff0c;組合方式為&#xff1a;com.company.projectName.component.hiberarchy。1. projectName&#xff1a;項目名稱2. com…

多元概率密度_利用多元論把握事件概率

多元概率密度Humans have plenty of cognitive strengths, but one area that most of us struggle with is estimating, explaining and preparing for improbable events. This theme underpins two of Nassim Taleb’s major works: Fooled by Randomness and The Black Swa…

nginx php訪問日志配置,nginx php-fpm 輸出php錯誤日志的配置方法

由于nginx僅是一個web服務器&#xff0c;因此nginx的access日志只有對訪問頁面的記錄&#xff0c;不會有php 的 error log信息。nginx把對php的請求發給php-fpm fastcgi進程來處理&#xff0c;默認的php-fpm只會輸出php-fpm的錯誤信息&#xff0c;在php-fpm的errors log里也看不…

阿里的技術愿景_技術技能的另一面:領域知識和長期愿景

阿里的技術愿景by Sihui Huang黃思慧 技術技能的另一面&#xff1a;領域知識和長期愿景 (The other side of technical skill: domain knowledge and long-term vision) When we first start our careers as software engineers, we tend to focus on improving our coding sk…

leetcode 721. 賬戶合并(并查集)

給定一個列表 accounts&#xff0c;每個元素 accounts[i] 是一個字符串列表&#xff0c;其中第一個元素 accounts[i][0] 是 名稱 (name)&#xff0c;其余元素是 emails 表示該賬戶的郵箱地址。 現在&#xff0c;我們想合并這些賬戶。如果兩個賬戶都有一些共同的郵箱地址&#…

es6重點筆記:數值,函數和數組

本篇全是重點&#xff0c;撿常用的懟&#xff0c;數值的擴展比較少&#xff0c;所以和函數放一起&#xff1a; 一&#xff0c;數值 1&#xff0c;Number.EPSILON&#xff1a;用來檢測浮點數的計算&#xff0c;如果誤差小于這個&#xff0c;就無誤 2&#xff0c;Math.trunc()&am…

SMSSMS垃圾郵件檢測器的專業攻擊

Note: The methodology behind the approach discussed in this post stems from a collaborative publication between myself and Irene Anthi.注意&#xff1a; 本文討論的方法背后的方法來自 我本人和 Irene Anthi 之間 的 合作出版物 。 介紹 (INTRODUCTION) Spam SMS te…

php pdo 緩沖,PDO支持數據緩存_PHP教程

/*** 作者&#xff1a;初十* QQ&#xff1a;345610000*/class myPDO extends PDO{public $cache_Dir null; //緩存目錄public $cache_expireTime 7200; //緩存時間&#xff0c;默認兩小時//帶緩存的查詢public function cquery($sql){//緩存存放總目錄if ($this->cache_Di…

mooc課程下載_如何使用十大商學院的免費課程制作MOOC“ MBA”

mooc課程下載by Laurie Pickard通過勞里皮卡德(Laurie Pickard) 如何使用十大商學院的免費課程制作MOOC“ MBA” (How to make a MOOC “MBA” using free courses from Top 10 business schools) Back when massive open online courses (MOOCs) were new, I started a proje…

leetcode 1584. 連接所有點的最小費用(并查集)

給你一個points 數組&#xff0c;表示 2D 平面上的一些點&#xff0c;其中 points[i] [xi, yi] 。 連接點 [xi, yi] 和點 [xj, yj] 的費用為它們之間的 曼哈頓距離 &#xff1a;|xi - xj| |yi - yj| &#xff0c;其中 |val| 表示 val 的絕對值。 請你返回將所有點連接的最小…

Nagios學習實踐系列

其實上篇Nagios學習實踐系列——基本安裝篇只是安裝了Nagios基本組件&#xff0c;雖然能夠打開主頁&#xff0c;但是如果不配置相關配置文件文件&#xff0c;那么左邊菜單很多頁面都打不開&#xff0c;相當于只是一個空殼子。接下來&#xff0c;我們來學習研究一下Nagios的配置…

在Salesforce中處理Email的發送

在Salesforce中可以用自帶的 Messaging 的 sendEmail 方法去處理Email的發送 請看如下一段簡單代碼&#xff1a; public boolean TextFormat {get;set;} public string EmailTo {get;set;} public string EmailCC {get;set;} public string EmailBCC {get;set;} public string …

kvm vnc的使用,鼠標漂移等

1.宿主機的vnc&#xff08;virtual Network Computing&#xff09;配置 安裝rpm包 yum install tigervnc-server -y 為了防止干擾直接關閉防火墻和selinux /etc/init.d/iptables stop setenforce 0 配置vnc密碼和啟動vncserver服務 vncpasswd vncserver 2.客戶機的vnc 在qemu…

php深淺拷貝,JavaScript 中的深淺拷貝

工作中經常會遇到需要復制 JavaScript 數據的時候&#xff0c;遇到 bug 時實在令人頭疼&#xff1b;面試中也經常會被問到如何實現一個數據的深淺拷貝&#xff0c;但是你對其中的原理清晰嗎&#xff1f;一起來看一下吧&#xff01;一、為什么會有深淺拷貝想要更加透徹的理解為什…

使用Python進行地理編碼和反向地理編碼

Geocoding is the process of taking input text, such as an address or the name of a place, and returning a latitude/longitude location. To put it simply, Geocoding is converting physical address to latitude and longitude.地理編碼是獲取輸入文本(例如地址或地點…

java開發簡歷編寫_如何通過幾個簡單的步驟編寫出色的初級開發人員簡歷

java開發簡歷編寫So you’ve seen your dream junior developer role advertised, and are thinking about applying. It’s time to write that Resume! Nothing better than sitting down to a blank piece of paper and not knowing how to start, right?因此&#xff0c;您…