我在MLPClassifier
上使用OneVsRestClassifier
。我正在将其用于分类文本数据,其中X
是pd.DataFrame
中的一组问题,Y
是多标签和多级字符串。请参阅下面的代码片段
text_clf = Pipeline([('scale',StandardScaler(with_mean=False)),('clf',OneVsRestClassifier(MLPClassifier(learning_rate = 'adaptive', solver = 'lbfgs',random_state=9000)))])
parameters = {'clf__alpha':[10.0 ** ~ np.arange(1, 7).any()],'clf__hidden_layer_sizes': [(100,),(50,)],'clf__max_iter': [1000,500],'clf__activation':('relu','tanh')}
grid = GridSearchCV(text_clf, parameters, cv=3, n_jobs=-1, scoring= 'accuracy')
with parallel_backend('threading'):
grid.fit(X,Y)
我收到以下错误
ValueError: Invalid parameter activation for estimator OneVsRestClassifier(estimator=MLPClassifier(activation='relu', alpha=0.0001, batch_size='auto', beta_1=0.9,
beta_2=0.999, early_stopping=False, epsilon=1e-08,
hidden_layer_sizes=(100,), learning_rate='adaptive',
learning_rate_init=0.001, max_iter=200, momentum=0.9,
n_iter_no_change=10, nesterovs_momentum=True, power_t=0.5,
random_state=9000, shuffle=True, solver='lbfgs', tol=0.0001,
validation_fraction=0.1, verbose=False, warm_start=False),
n_jobs=None). Check the list of available parameters with `estimator.get_params().keys()`.
根据我的理解,MLPClassifier
支持多标签分类。是否表明parameters
需要重新检查?如果是这样,那么任何身体都可以提供任何在何处更改parameters
的线索吗?
任何帮助都将不胜感激。
您的MLPClassifier
嵌套在OneVsRestClassifier
中作为其估计器。
换句话说,parameters
应该指定所有alpha
,hidden_layer_sizes
,...用于嵌套估计器而不是OneVsRestClassifier
。
更改 parameters
如以后的工作应该完成工作:
parameters = {'clf__estimator__alpha':[10.0 ** ~ np.arange(1,7).any()],
'clf__estimator__hidden_layer_sizes': [(100,),(50,)],
'clf__estimator__max_iter': [1000,500],
'clf__estimator__activation':('relu','tanh')}