パワー スペクトルから信号の帯域幅を測定しようとしています。相対振幅値を指定して、最小値と最大値を抽出できるようにしたいと考えています。私は「seewave」を使用してパワースペクトルを計算しており、密度プロットを作成してアブラインを提供できますが、アブラインがプロットと交差する場所をRに教えてもらう方法がわかりません。信号の品質に応じて、関心のある相対振幅値を変更する必要がありますが、R を使用して帯域幅を測定する簡単な方法を見つけたいと考えています。よろしくお願いします!
power.spec <- spec(IBK.trill.1, flim=c(0,2))
pow.spec <- as.matrix(power.spec)
head(pow.spec)
# x y
# [1,] 0.000000000 0.007737077
# [2,] 0.007470703 0.029795630
# [3,] 0.014941406 0.021248476
# [4,] 0.022412109 0.015603801
# [5,] 0.029882813 0.014103307
# [6,] 0.037353516 0.014584454
freq <- pow.spec[1:2941,1]
head(freq)
# [1] 0.000000000 0.007470703 0.014941406 0.022412109 0.029882813 0.037353516
ampl <- pow.spec[,2]
head(ampl)
# [1] 0.007737077 0.029795630 0.021248476 0.015603801 0.014103307 0.014584454
plot(ampl ~ freq, type="l",xlim=c(0,2))
abline(h=0.45)