我需要「壓縮」表示信號的python數組的大小。信號看起來像下面的例子。信號壓縮
signal = [
[0.0,0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9,1.0,1.1], #time values
[1,1,1,2,3,4,4,4,4,2,1,1] #function values
]
壓縮後,信號應該看起來像下面的代碼。
signal_compressed = [
[0.0,0.2,0.3,0.4,0.5,0.8,0.9,1.0,1.1], #time values
[1,1,2,3,4,4,2,1,1] #function values
]
您會發現,如果存在具有常數值的區域,則只會存儲此區域的第一個和最後一個值。
我寫了下面的算法來做到這一點。
signal_compressed = [[],[]]
old_value = None
for index, value in enumerate(signal[1]):
if value != old_value:
if index > 0:
if signal_compressed[0][-1] != signal[0][index - 1]:
signal_compressed[0].append(signal[0][index - 1])
signal_compressed[1].append(signal[1][index - 1])
signal_compressed[0].append(signal[0][index])
signal_compressed[1].append(value)
old_value = value
if signal_compressed[0][-1] < signal[0][-1]:
signal_compressed[0].append(signal[0][-1])
signal_compressed[1].append(signal[1][-1])
該算法工作正常。對於具有很多不變部分的信號,他的工作速度非常快。但是,如果我嘗試壓縮沒有恆定段的信號(例如正弦信號或噪聲信號),該算法的工作非常緩慢。
如何加快我的算法並節省功能?
謝謝您的回答。我已經嘗試過你的算法並與我的算法進行了比較。對於短信號,你的算法更快。但是對於大量輸入來說,它比我的要慢。你能否用'NumPy'解釋解決方案? – wewa 2013-03-27 13:24:24
@wewa:我已經添加了一個這樣的解決方案的大綱,它沒有Python循環。 – NPE 2013-03-27 13:50:27
我也用'NumPy'試過了這個新算法。這比我的速度快一點。但只有當你不將numpy數組轉換回列表。是否有其他可能性來壓縮我的數據? – wewa 2013-03-27 14:35:46