信號下的基本時域頻域特征(下)

很久之前寫了一篇信號下的基本時域頻域特征(上),后來一直催更,直到今天才更新,實在是不好意思食零,理解萬歲。

這次將所有我平時用的16個時域特征10個頻域特征的程序都放到這里

)了寂屏,另外這次單獨列出頻域的公式供大家參考贰谣。


圖1:十個頻域特征計算圖

程序如下:大家可以對照公式看程序,如果有錯誤迁霎,歡迎指出交流

# ======================= STATISTICAL FEATURES IN TIME DOMAIN =======================
# def fft_fft(sequence_data):
#   fft_trans = np.abs(np.fft.fft(sequence_data))
#   dc = fft_trans[0]
#   freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
#   freq_sum_ = np.sum(freq_spectrum)
#   return dc, freq_spectrum, freq_sum_

def fft_mean(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    return np.mean(freq_spectrum)

def fft_var(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    return np.var(freq_spectrum)

# def fft_std(sequence_data):
#   def fft_fft(sequence_data):
#       fft_trans = np.abs(np.fft.fft(sequence_data))
#       # dc = fft_trans[0]
#       freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
#       _freq_sum_ = np.sum(freq_spectrum)
#       return freq_spectrum, _freq_sum_
#   freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
#   return np.std(freq_spectrum)

def fft_entropy(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    pr_freq = freq_spectrum * 1.0 / _freq_sum_
    entropy = -1 * np.sum([np.log2(p+1e-5) * p for p in pr_freq])
    return entropy

def fft_energy(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    return np.sum(freq_spectrum ** 2) / len(freq_spectrum)

def fft_skew(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    _fft_mean, _fft_std = fft_mean(sequence_data), fft_std(sequence_data)
    return np.mean([0 if _fft_std < epsn else np.power((x - _fft_mean) / _fft_std, 3)
                    for x in freq_spectrum])

def fft_kurt(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    _fft_mean, _fft_std = fft_mean(sequence_data), fft_std(sequence_data)
    return np.mean([0 if _fft_std < epsn else np.power((x - _fft_mean) / _fft_std, 4)
                    for x in freq_spectrum])

def fft_shape_mean(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    shape_sum = np.sum([x * freq_spectrum[x]
                        for x in range(len(freq_spectrum))])
    return 0 if _freq_sum_ < epsn else shape_sum * 1.0 / _freq_sum_

def fft_shape_std(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    shape_mean = fft_shape_mean(sequence_data)
    var = np.sum([0 if _freq_sum_ < epsn else np.power((x - shape_mean), 2) * freq_spectrum[x]
                  for x in range(len(freq_spectrum))]) / _freq_sum_
    return np.sqrt(var)

def fft_shape_skew(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    shape_mean = fft_shape_mean(sequence_data)
    return np.sum([np.power((x - shape_mean), 3) * freq_spectrum[x]
                   for x in range(len(freq_spectrum))]) / _freq_sum_

def fft_shape_kurt(sequence_data):
    def fft_fft(sequence_data):
        fft_trans = np.abs(np.fft.fft(sequence_data))
        # dc = fft_trans[0]
        freq_spectrum = fft_trans[1:int(np.floor(len(sequence_data) * 1.0 / 2)) + 1]
        _freq_sum_ = np.sum(freq_spectrum)
        return freq_spectrum, _freq_sum_
    freq_spectrum, _freq_sum_ = fft_fft(sequence_data)
    shape_mean = fft_shape_mean(sequence_data)
    return np.sum([np.power((x - shape_mean), 4) * freq_spectrum[x] - 3
                   for x in range(len(freq_spectrum))]) / _freq_sum_
# =================================== END =====================================

關(guān)于所有的特征的程序吱抚,大家從文章開頭的鏈接里找,Thanks?(?ω?)?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末考廉,一起剝皮案震驚了整個濱河市频伤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌芝此,老刑警劉巖憋肖,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異婚苹,居然都是意外死亡岸更,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門膊升,熙熙樓的掌柜王于貴愁眉苦臉地迎上來怎炊,“玉大人,你說我怎么就攤上這事∑浪粒” “怎么了债查?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長瓜挽。 經(jīng)常有香客問我盹廷,道長,這世上最難降的妖魔是什么久橙? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任俄占,我火速辦了婚禮,結(jié)果婚禮上淆衷,老公的妹妹穿的比我還像新娘缸榄。我一直安慰自己,他們只是感情好祝拯,可當我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布甚带。 她就那樣靜靜地躺著,像睡著了一般佳头。 火紅的嫁衣襯著肌膚如雪欲低。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天畜晰,我揣著相機與錄音,去河邊找鬼瑞筐。 笑死凄鼻,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的聚假。 我是一名探鬼主播块蚌,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼膘格!你這毒婦竟也來了峭范?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤瘪贱,失蹤者是張志新(化名)和其女友劉穎纱控,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體菜秦,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡甜害,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了球昨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尔店。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出嚣州,到底是詐尸還是另有隱情鲫售,我是刑警寧澤,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布该肴,位于F島的核電站情竹,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏沙庐。R本人自食惡果不足惜鲤妥,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望拱雏。 院中可真熱鬧棉安,春花似錦、人聲如沸铸抑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鹊汛。三九已至蒲赂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間刁憋,已是汗流浹背滥嘴。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留至耻,地道東北人若皱。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像尘颓,于是被迫代替她去往敵國和親走触。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,927評論 2 355