- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想为机器学习方法编码我输入的字符串字母。让我们假设我的火车数据是这样的:
score text
1 show photos
1 show my photos
2 who are you?
目前我在做这样的事情:
for index, row in train_set.iterrows():
list2 = []
list2 = list(row.text.lower())
for n, key in enumerate(list2):
if key in dictionary:
list2[n] = dictionary[key]
else:
dictionary[key] = i
list2[n] = i
i += 1
train_set.set_value(index,'text', list2)
作为这个示例数据的结果,我得到:
score text
1 [0, 1, 2, 3, 4, 5, 1, 2, 6, 2, 0]
1 [0, 1, 2, 3, 4, 7, 8, 4, 5, 1, 2, 6, 2, 0]
2 [3, 1, 2, 4, 10, 13, 9, 4, 8, 2, 19, 21]
如您所知,例如对于神经网络,使用这些值并不是一种正确的方法,因此在我看来,在这种情况下,单一热编码将是最佳解决方案。我想知道在 test_set
数据框的 text
列以及 train_set< 中的
数据框,它看起来像 text
列中转换这些值的最有效方法是什么test_set
但显然第一列没有预期值。我认为在这两种情况下,在使用一种热编码后我应该具有相同大小的列,并且相同的索引和行应该对应于 test_set
和 train_set
中的相同字符数据框。我希望你明白我的意思。如果没有,请告诉我。我将尝试以更清楚的方式解释它。我该怎么做?有什么想法吗?
最佳答案
一种解决方案是使用自定义 Prepper
类来编码您的训练集。当训练集被编码时,Prepper
类对象记录(单词,单热索引)对应关系。
然后您将使用相同的 Prepper
对象来编码您的测试集。
Prepper
类的粗略骨架是:
from collections import defaultdict
class Prepper(object):
def __init__(self):
self.vocab = defaultdict(lambda : len(self.vocab))
def encode_train_word(self, train_word):
return self.vocab[train_word]
def encode_test_word(self, test_word):
if test_word in self.vocab:
return self.vocab[test_words]
else:
return -1 # index for unknown token
如果我不得不重新获取您的代码片段,它看起来像:
prepper = Prepper()
for index, row in train_set.iterrows():
list2 = list(row.text.lower())
encoded_list_2 = [prepper.encode_train_word(word) for word in list2]
train_set.set_value(index, 'text', encoded_list_2)
## and for the test set
for index, row in test_set.iterrows():
list2 = list(row.text.lower())
encoded_list_2 = [prepper.encode_test_word(word) for word in list2]
test_set.set_value(index, 'text', encoded_list_2)
关于python - 如何为机器学习方法编码我的数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50431164/
简介 在上一篇文章《机器学习:神经网络构建(上)》中讨论了线性层、激活函数以及损失函数层的构建方式,本节中将进一步讨论网络构建方式,并完整的搭建一个简单的分类器网络。 目录 网络Netwo
简介 在本篇文章中,我们采用逻辑回归作为案例,探索神经网络的构建方式。文章详细阐述了神经网络中层结构的实现过程,并提供了线性层、激活函数以及损失函数的定义(实现方法)。 目录 背景介绍
简介 在前两篇文章中,我们详细探讨了如何利用采样数据来估计回归曲线。接下来,在本节中,我们将深入讨论如何处理分类问题。 章节安排 背景介绍 数学方法 程序实现 背景介绍 线
简介 在上一篇文章《机器学习:线性回归(上)》中讨论了二维数据下的线性回归及求解方法,本节中我们将进一步的将其推广至高维情形。 章节安排 背景介绍 最小二乘法 梯度下降法 程序
PyCaret是一个开源、低代码Python机器学习库,能够自动化机器学习工作流程。它是一个端到端的机器学习和模型管理工具,极大地加快了实验周期,提高了工作效率。PyCaret本质上是围绕几个机器学习
在我的研究进展中,我现在已经将寄生虫从图像中分离出来。寄生虫看起来像蠕虫。我希望 MATLAB 读取所有输入图像,查找类似深紫色图像的蠕虫,如果检测到,则给出检测到的答复。我尝试使用直方图比较,但我认
目前我正在尝试了解机器学习算法的工作方式,但我没有真正了解的一件事是预测标签的计算准确度与视觉混淆矩阵之间的明显差异。我会尽量解释清楚。 这是数据集的片段(这里你可以看到 9 个样本(在真实数据集中大
第一章 绪论 机器学习 : 致力于研究如何通过计算的手段,利用经验来改善系统自身的性能。在计算机系统中, “经验” 通常以“数据“形式存在,因此,机器学习所研究的主要内容,是关于在计算
1. 算法原理(K-Nearest Neighbor) 本质是通过距离判断两个样本是否相似,如果距离够近就认为他们足够相似属于同一类别 找到离其最近的 k 个样本,并将这些样本称
前言 K-means是一种经典的无监督学习算法,用于对数据进行聚类。K-means算法将数据集视为具有n个特征的n维空间,并尝试通过最小化簇内平方误差的总和来将数据点划分为簇。本文将介绍K-m
目录 前言 介绍LightGBM LightGBM的背景和起源 L
前言 可以说掌握了机器学习,你就具备了与机器对话,充分利用机器为人类服务的能力。在人工智能时代,这将成为一项必备技能,就好比十年前你是编程大牛,二十年前你英语超好一样。因此,无论你是什么专业的
几个贯穿始终的概念 当我们把人类学习简单事物的过程抽象为几个阶段,再将这些阶段通过不同的方法具体化为代码,依靠通过计算机的基础能力-- 计算 。我们就可以让机器能够“学会”一些简单的事物。
1、选题背景 人脸识别技术是模式识别和计算机视觉领域最富挑战性的研究课题之一,也是近年来的研究热点,人脸性别识别作为人脸识别技术
每当我们在公有云或者私有云发布训练好的大数据模型,为了方便大家辨识、理解和运用,参照huggingface所制定的标准制作一个Model Card展示页,是种非常好的模型展示和组织形式。 下面就是一
2. 支持向量机 对偶优化 拉格朗日乘数法可用于解决带条件优化问题,其基本形式为: \[\begin{gather} \min_w f(w),\\ \mathrm{s.t.} \quad
我正在尝试运行以下代码: https://github.com/opencv/opencv/blob/master/samples/dnn/classification.cpp 我在这里找到所有经过预
我是机器学习新手。当我使用 scikit-learn 模块中的波士顿数据集练习具有默认参数的决策树回归模型时。 在此链接解决方案( How to Build a Decision tree Regre
我有用于训练的数据。当我将其输入神经网络时,该数据出现 3% 的错误。 我知道这些数据有一定的过度代表性 - 例如,第 5 类的示例大约是其他类的十分之一。 我的作业指出,我可以通过偏置训练数据(即删
我在 Python 的多类分类中使用 SVM 时遇到问题。事实上,问题在于性别分类(来自图像),其中训练数据集仅包含“y=1”或“ y=-1”作为类标签(二进制)。但是,在预测中,如果是男性,我必须预
我是一名优秀的程序员,十分优秀!