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

        歡迎訪問 生活随笔!

        生活随笔

        當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

        编程问答

        R学习_multitaper包解析1:子函数centre,dpss

        發布時間:2025/3/15 编程问答 29 豆豆
        生活随笔 收集整理的這篇文章主要介紹了 R学习_multitaper包解析1:子函数centre,dpss 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

        前言

        之前講了MTM(多錐形窗譜估計)的相關原理,現在來分析一下它的R語言的實現,這個實現是提出人的學生寫的,和matlab的實現進行對照分析,加深理解,提高大家對這門技術的掌握程度。

        想要復習的可以參考一下之前的文件:

        mtm原理:現代譜估計:多窗口譜
        想要復習一下如何實現的可以參考:
        MTM:matlab實現1MTM:matlab實現1
        MTM:matlab實現2參數解析MTM參數解析
        MTM:matlab實現3譜功率計算MTM譜功率計算
        MTM:matlab實現4主函數解析MTM 主函數

        目錄

        • 前言
        • 目錄
        • centre函數
        • DPSS函數

        centre函數

        該函數負責對輸入的時間序列進行處理,使其滿足零均值條件

        ######################################################################### ## ## centre ## ## Takes a time series and converts to zero-mean using one of three ## methods: Slepian projection, arithmetic mean, or trimmed mean. ## ######################################################################### r里面的賦值采用<-格式 輸入參數 時間序列x nw生成幾階dpss序列 k使用的窗口數 deltat 采樣間隔 trim截尾平均時丟掉的點數 centre <- function(x, nw=NULL, k=NULL, deltaT=NULL, trim=0) { 判斷x是否有非數值na.fail(x)初始化結果res <- NULL如果沒有輸入dpss參數的話,則默認為截尾平均if(is.null(nw) && is.null(k) ) {res <- x - mean(x, trim=trim)如果有dpss參數,則使用slepian投影,截尾數舍棄} else {if(trim != 0) {warning(paste("Ignoring trim =", trim))}如果采用dpss方法,且相關參數不符合條件,則停止函數stopifnot(nw >= 0.5, k >= 1, nw <= 500, k <= 1.5+2*nw)如果dpss階數和長度之比不合適,停止運算if (nw/length(x) > 0.5) { stop("half-bandwidth parameter (w) is greater than 1/2")}如果,deltat沒有值且x是時間序列,則獲得它的采樣間隔,否則,默認為1if(is.null(deltaT)) {if(is.ts(x)) {deltaT <- deltat(ts)} else {warning("deltaT not specified; using deltaT=1.")deltaT <- 1.0}}獲得時間序列x的長度nn <- length(x)獲得生成的DPSS序列結果,輸入參數為n,k,nw,返回特征值dpssRes <- dpss(n, k=k, nw=nw,returnEigenvalues=TRUE)dw值等于返回結果中的特征值*采樣間隔的單位根dw <- dpssRes$v*sqrt(deltaT)ev值等于返回結果中的特征加窗矩陣,每一列對應第k個。ev <- dpssRes$eigenswz是特征向量的列值和swz <- apply(dw, 2, sum)## zero swz where theoretically zero; odd tapers如果k》2則swz偶數位的值是0if(k >=2) {swz[seq(2,k,2)] <- 0.0}ssqswz是幅頻率功率之和。ssqswz <- sum(swz^2)如果不是復值x,對x采取meave函數進行處理if(!is.complex(x)) {res <- .mweave(x, dw, swz,n, k, ssqswz, deltaT)res <- x - res$cntr} else {res.r <- .mweave(Re(x), dw, swz,n, k, ssqswz, deltaT)res.i <- .mweave(Im(x), dw, swz,n, k, ssqswz, deltaT)res <- x - complex(real=res.r$cntr, imaginary=res.i$cntr)}}return(res) }

        DPSS函數

        負責生成給定的k個正交的離散扁球序列,即用來加權的窗
        使用對角法生成。
        參照論文和譜分析教材那本書,會講如何得出給定的值

        ########################################################## ## ## dpss ## ## Generates k orthogonal discrete prolate spheroidal ## sequences (dpss) using the tridiagonal method. See ## Slepian (1978) page 1379 and Percival and Walden ## chapter 8.4 ## ########################################################## 函數dpss 輸入 n值序列個數 k值加窗個數 nw值窗口給定值 ReturnEigenvalues=true真 返回特征值dpss <- function(n, k, nw, returnEigenvalues=TRUE) { 如果不滿足條件停止計算stopifnot(n >= 1, nw/n >0, nw/n < 0.5, k >= 1)將k變成一個整數。## if k is passed in as floating point, the cast to ## as.integer() in the Fortran call does not quite work properlyif(!is.integer(k)) {k<-as.integer(floor(k));} 使用專門的包計算特征值##eigen is of length for use by lapack functoins.## this will use lapack functions in place of the## eispack functions referenced in Percival and Waldern輸入相應參數,得到相應的結果out <- .Fortran("fdpss", as.integer(n), as.integer(k),as.double(nw), v=double(n*k), eigen=double(k),PACKAGE='multitaper')輸出v值矩陣 out$v <- matrix(data=out$v, nrow=n, ncol=k, byrow=FALSE)如果返回特征值為真if(returnEigenvalues) {輸出的特征值利用特定子函數生成out$eigen <- dpssToEigenvalues(out$v, nw)} else {特征值由對稱公式返回## eigen values returned from the tridiagonal formulation## Slepian eqn #13 (1978)out$eigen <- out$eigen}結果是輸出的v和特征值res <- list(v=out$v,eigen=out$eigen)結果類型 dpss? class(res) <- "dpss"return(res) }########################################################## ## ## dpssToEigenvalues ## 給定一個離散扁球窗,找到對應生成dpss序列的特征值 ## Given a set of dpss tapers, find the eigenvalues corresponding ## to the generated dpss's ## ## See Percival and Walden (1993) exercise 8.4, and ## associated LISP code. ## ##########################################################dpss序列到特征值矩陣 輸入 v nwdpssToEigenvalues <- function(v, nw) { 將v矩陣化v <- as.matrix(v)獲得v的第一維序列長度n <- length(v[,1])獲得v的第二維,k值k <- length(v[1,])獲得窗口百分比w <- nw/n找到序列長度最接近的2的次方的npot數量npot <- 2**(ceiling(log2(2*n)))## pad生成v值矩陣scratch <- rbind(v, matrix(data=0, nrow=npot-n, ncol=k))## n * acvs矩陣的值是對應特偵序列的功率。scratch <- Re(mvfft(abs(mvfft(scratch))**2))/npotj <- 1:(n-1)生成比率向量vectorOfRatios <- c(2*w, sin(2*pi*w*j)/(pi*j))這兩個矩陣都隨著序號的上升,幅值下降## Note: both vector of ratios and scratch## roughy decrease in amplitude with increasing index,## so sum things up in reverse order特征值為空eigenvalues <- NULL如果k大于1if(k>1) {特征值按列相乘假和eigenvalues <- apply(scratch[n:2,] * vectorOfRatios[n:2], 2, sum)} else {其他情況下不用加eigenvalues <- sum(scratch[n:2,] * vectorOfRatios[n:2])}返回特征向量加上第一列的和。return(2*eigenvalues +vectorOfRatios[1]*scratch[1,1:k]) }

        總結

        以上是生活随笔為你收集整理的R学习_multitaper包解析1:子函数centre,dpss的全部內容,希望文章能夠幫你解決所遇到的問題。

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

        主站蜘蛛池模板: av黄| 香蕉视频1024 | 日本人毛片 | 伊人毛片 | 尤物视频在线观看国产性感 | 午夜欧美在线 | 日本在线激情 | 网友自拍第一页 | 噼里啪啦动漫高清在线观看 | 外国毛片| 国产第一页屁屁影院 | 男人综合网 | 日韩精品一区二区三区 | 大肉大捧一进一出好爽视频动漫 | 四虎影视成人永久免费观看亚洲欧美 | av在线天堂网 | 日本免费黄色 | 午夜成人免费影院 | 成人黄色录像 | 国产精品美女在线观看 | 波多野结衣网址 | 制服丝袜一区在线 | 伦伦影院午夜理伦片 | 成人免费视频国产免费 | 国产日韩片 | 视频免费在线观看 | 国产超碰人人爽人人做人人爱 | 国产福利小视频在线 | 久久性感美女视频 | 久久久久久91香蕉国产 | av网站国产 | 亚洲最大视频网 | 免费不卡的av | 国产福利91 | 国产成人无码a区在线观看视频 | 一级免费看片 | 免费黄色小说视频 | 日韩性xxx | 我们的生活第五季在线观看免费 | 狠狠干2020 | 国产97色在线 | 日韩 | 91丨porny在线 | 中文字幕无码精品亚洲资源网久久 | 中文字幕亚洲色图 | 天天干天天噜 | 枫可怜av| 亚洲成熟女性毛茸茸 | 日韩欧美一区二区三区久久婷婷 | 极品少妇一区二区 | av射进来| 国产精品一区二区免费视频 | 日韩欧美中文在线 | 手机在线免费看av | 国产精品黄 | 亚洲视频天天射 | 国产探花精品一区二区 | 色狠狠一区二区 | 免费观看毛片 | 日本免费在线一区 | 亚洲精品h| 爱爱免费视频 | 国产精品国产一区 | 美女靠逼app | 国产精品女人久久久 | 99re这里都是精品 | 伦理片一区二区 | 成人欧美在线 | 狠狠爱天天干 | 小箩莉末发育娇小性色xxxx | 18岁成年人网站 | 禁片天堂 | 亚洲精品乱码久久久久 | 欧美日韩亚洲在线 | 亚洲一区精品在线 | 91精品国产乱码久久 | 日本欧美色图 | 影视先锋av资源 | 落日余晖 | 澳门黄色录像 | 亚洲 欧美 日韩 国产综合 在线 | 日韩一区二区在线观看 | 免费的黄色小视频 | 一区二区成人精品 | 激情五月综合 | 美女露出粉嫩尿囗让男人桶 | 丁香激情六月 | 57pao国产成永久免费视频 | 国产精品免费一区二区三区在线观看 | 特一级黄色大片 | 高清国产mv在线观看 | 伊人夜色 | 日韩最新视频 | 欧美视频久久久 | 日韩影视在线 | 日韩一级影片 | 韩国黄色视屏 | 森泽佳奈中文字幕 | 粉嫩久久99精品久久久久久夜 | 超级变态重口av番号 |