我有4个numpy数组(特征)。numpy数组的维数为:
a1=(360,100)
a2=(360,100)
a3=(360,100)
a4=(360,13)我有360 (4类,每个是90)音频文件。我从这些wav文件中获得了4个不同的特征(a1,..a4)。我分别尝试了这些特征(a1,..a4)来训练svm并对音频进行分类。但有些结果并不好。现在我想将这4个特征结合起来,以获得更好的结果。但我不想把这些矩阵连接起来。我只想确定这些特征的一些系数,并只获得一个用于分类的特征向量。例如,
当我只使用a1特性时,性能是:
class1=%50, class2=%85, class3=%95, class4=%95当我只使用a2特性时,性能是:
class1=%30, class2= %96, class3=%94, class4=%80当我只使用a3特性时,性能是:
class1=%64, class2=%94, class3=%74, class4=%97当我只使用a4特性时,性能是:
class1=%74, class2=%96, class3=%85, class4=%88如何同时使用这4个功能来提高性能?我也连接了这些功能,但性能也不好。谢谢
发布于 2017-09-23 01:32:23
你描述它的方式,它看起来很像boosting:你的4个分类器中的每个都是弱的(参见this answer),boosting的想法是将一群弱的学习者转化为强的学习者。
可以从你现有的分类器中手动完成,例如using sci-kit。但我认为最简单的方法是使用XGBoost,它将在内部使用您的所有功能,为每个功能构建一个分类器,然后将它们提升为一个分类器:
from xgboost import XGBClassifier
model = XGBClassifier()
model.fit(train_x, train_y)
model.predict(test_x)https://stackoverflow.com/questions/46358245
复制相似问题