首页 文章

心电信号上的Keras Conv1D

提问于
浏览
0

我试图对不同的心电信号进行分类 . 我正在使用Keras的Conv1D,但没有得到任何好结果 . 我已经尝试过更改图层数,窗口大小等,但每次运行时我都会得到所有相同类的预测(类是0,1,2,所以我得到类似[1的预测输出] 1,1,1,1,1,1,1,1,1,1,1,1,1],但每次运行脚本时类都会改变 . ECG信号是1000点numpy阵列 .

我在这里做错了吗?我认为使用几层来分类成3种不同的ECG信号会很有效 .

#arrange and randomize data
y1=[[0]]*len(lead1)
y2=[[1]]*len(lead2)
y3=[[2]]*len(lead3)
y=np.concatenate((y1,y2,y3))
data=np.concatenate((lead1,lead2,lead3))
data = keras.utils.normalize(data)
data=np.concatenate((data,y),axis=1)
data=np.random.permutation((data))
print(data)

#separate data and create categories
Xtrain=data[0:130,0:-1]
Xtrain=np.reshape(Xtrain,(len(Xtrain),1000,1))
Xpred=data[130:,0:-1]
Xpred=np.reshape(Xpred,(len(Xpred),1000,1))
Ytrain=data[0:130,-1]
Yt=to_categorical(Ytrain)
Ypred=data[130:,-1]
Yp=to_categorical(Ypred)

#create CNN model
model = Sequential()
model.add(Conv1D(20,20,activation='relu',input_shape=(1000,1)))
model.add(MaxPooling1D(3))
model.add(Conv1D(20,10,activation='relu'))
model.add(MaxPooling1D(3))
model.add(Conv1D(20,10,activation='relu'))
model.add(GlobalAveragePooling1D())
model.add(Dense(3,activation='relu',use_bias=False))
model.compile(optimizer='adam', loss='categorical_crossentropy',metrics=['accuracy'])
model.fit(Xtrain,Yt)

#test model
print(model.evaluate(Xpred,Yp))
print(model.predict_classes(Xpred,verbose=1))

1 回答

  • 1

    我在这里做错了有什么明显的事吗?

    确实存在:您报告的输出并不奇怪,因为您当前正在使用ReLU作为最后一层的激活,这没有任何意义 .

    在多级设置中,例如你的,最后一层的激活必须是softmax,当然不是ReLU;将您的上一层更改为:

    model.add(Dense(3, activation='softmax'))
    

    不太确定你为什么要求 use_bias=False ,但你可以尝试使用和不使用它并进行实验......

相关问题