我将数据拆分以进行训练/测试。
当我使用PCA时很简单。
from sklearn.decomposition import PCA
pca = PCA()
X_train_pca = pca.fit_transform(X_train)
X_test_pca = pca.transform(X_test)
从这里,我可以在下一步中使用X_train_pca和X_test_pca,依此类推。
但是当我使用t-SNE
from sklearn.manifold import TSNE
X_train_tsne = TSNE(n_components=2, random_state=0).fit_transform(X_train)
我似乎无法转换测试集,以便我可以将t-SNE数据用于下一步,例如支持向量机
有什么帮助吗?
最佳答案
我相信您要尝试做的事是不可能的。
t-SNE进行投影以尝试保持您适合的样本之间的成对距离。因此,如果不进行调整,就无法使用t-SNE模型预测新数据的投影。
另一方面,我不会将t-SNE的输出作为分类器的输入。主要是因为t-SNE是高度非线性的并且有些随机,并且根据不同的运行和不同的困惑度值,您可以获得非常不同的输出。
参见this t-SNE的说明。
但是,如果您确实愿意为此目的使用t-SNE,则必须将t-SNE模型拟合到整个数据上,一旦拟合,就可以进行训练和测试拆分。
from sklearn.manifold import TSNE
size_train = X_train.shape[0]
X = np.vstack((X_train,X_test))
X_tsne = TSNE(n_components=2, random_state=0).fit_transform( X )
X_train_tsne = X_tsne[0:size_train,:]
X_test_tsne = X_tsne[size_train:,:]
关于python - 如何在模型中实现t-SNE?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/52849890/