- 作者简介:我是团团儿,是一名专注于云计算领域的专业创作者,感谢大家的关注
- 座右铭: 云端筑梦,数据为翼,探索无限可能,引领云计算新纪元
- 个人主页:团儿.-CSDN博客
目录
前言:
正文:
数据预处理步骤
第1步 - 导入有用的软件包 -
这里使用了以下两个软件包 -
第2步 - 定义样本数据 -
第3步 - 应用预处理技术
下面介绍数据预处理技术 -
二值化
二值化数据
平均去除
运行上述代码行后,将得到以下输出 -
现在,下面的代码将删除输入数据的平均值和标准偏差 -
运行上述代码行后,将得到以下输出 -
缩放
最小最大缩放
正常化
L1 标准化
L2 标准化
标记数据
标记编码步骤
第1步 - 导入有用的软件包
第2步 - 定义样本标签
第3步 - 创建和训练标签编码器对象
以下是运行上面的 Python 代码后的输出 -
第4步 - 通过编码随机排序列表来检查性能
第5步 - 通过解码一组随机数来检查性能 -
标记与未标记数据
前言:
在当今这个数字化时代,人工智能(AI)已经深入到我们生活的方方面面,从智能家居到自动驾驶汽车,从精准医疗到智能金融,AI正引领着一场前所未有的技术革命。然而,在这场革命的背后,有一个至关重要的环节往往被忽视,那就是人工智能数据准备。
数据是AI的“血液”,是其学习和决策的基础。没有高质量、准确且经过精心准备的数据,AI算法就像无源之水、无本之木,难以发挥出应有的效能。因此,人工智能数据准备不仅是一项技术挑战,更是一项关乎AI未来发展的战略任务。
本章旨在深入探讨人工智能数据准备的各个方面,从数据采集、清洗、标注、整合到验证,全方位、多层次地揭示数据准备的奥秘。我们将通过生动的案例、详实的数据和深入浅出的分析,帮助读者理解数据准备在AI项目中的重要性,并掌握实用的数据准备技巧和方法。
无论你是AI领域的专业人士,还是对AI技术充满好奇心的初学者,本章都将是你不可多得的良师益友。让我们一起踏上这段探索之旅,共同揭开人工智能数据准备的神秘面纱,为AI的未来发展贡献自己的力量。
正文:
在我们的日常生活中,需要处理大量数据,但这些数据是原始数据。 为了提供数据作为机器学习算法的输入,需要将其转换为有意义的数据。 这就是数据预处理进入图像的地方。 换言之,可以说在将数据提供给机器学习算法之前,我们需要对数据进行预处理。
数据预处理步骤
第1步 - 导入有用的软件包 -
如果使用 Python,那么这将成为将数据转换为特定格式(即预处理)的第一步。如下代码 -
import numpy as np
from sklearn import preprocessing
这里使用了以下两个软件包 -
- NumPy - 基本上 NumPy 是一种通用的数组处理软件包,设计用于高效处理任意记录的大型多维数组而不牺牲小型多维数组的速度。
- sklearn.preprocessing - 此包提供了许多常用的实用函数和变换器类,用于将原始特征向量更改为更适合机器学习算法的表示形式。
第2步 - 定义样本数据 -
导入包后,需要定义一些样本数据,以便可以对这些数据应用预处理技术。现在将定义以下样本数据 -
input_data = np.array([[2.1, -1.9, 5.5],[-1.5, 2.4, 3.5],[0.5, -7.9, 5.6],[5.9, 2.3, -5.8]])
第3步 - 应用预处理技术
在这一步中,我们需要应用预处理技术。
下面介绍数据预处理技术 -
二值化
这是当需要将数值转换为布尔值时使用的预处理技术。我们可以用一种内置的方法来二值化输入数据,比如说用0.5作为阈值,方法如下 -
data_binarized = preprocessing.Binarizer(threshold = 0.5).transform(input_data)
print("\nBinarized data:\n", data_binarized)
现在,运行上面的代码后,将得到以下输出,所有高于0.5(阈值)的值将被转换为1,并且所有低于0.5的值将被转换为0。
二值化数据
平均去除
这是机器学习中使用的另一种非常常见的预处理技术。 基本上它用于消除特征向量的均值,以便每个特征都以零为中心。 还可以消除特征向量中的特征偏差。 为了对样本数据应用平均去除预处理技术,可以编写如下Python代码。 代码将显示输入数据的平均值和标准偏差 -
print("Mean = ", input_data.mean(axis = 0))
print("Std deviation = ", input_data.std(axis = 0))
运行上述代码行后,将得到以下输出 -
现在,下面的代码将删除输入数据的平均值和标准偏差 -
data_scaled = preprocessing.scale(input_data)
print("Mean =", data_scaled.mean(axis=0))
print("Std deviation =", data_scaled.std(axis = 0))
运行上述代码行后,将得到以下输出 -
缩放
这是另一种数据预处理技术,用于缩放特征向量。 特征向量的缩放是需要的,因为每个特征的值可以在许多随机值之间变化。 换句话说,我们可以说缩放非常重要,因为我们不希望任何特征合成为大或小。 借助以下Python代码,我们可以对输入数据进行缩放,即特征矢量 -
最小最大缩放
正常化
这是另一种数据预处理技术,用于修改特征向量。 这种修改对于在一个普通的尺度上测量特征向量是必要的。 以下是可用于机器学习的两种标准化 -
L1 标准化
它也被称为最小绝对偏差。 这种标准化会修改这些值,以便绝对值的总和在每行中总是最多为 1。 它可以在以下 Python 代码,使用上面的输入数据来实现 -
## Normalize data
data_normalized_l1 = preprocessing.normalize(input_data, norm = 'l1')
print("\nL1 normalized data:\n", data_normalized_l1)
Python
上面的代码行生成以下输出:
L2 标准化
它也被称为最小二乘。这种归正常化修改了这些值,以便每一行中的平方和总是最多为 1。它可以在以下 Python 代码,使用上面的输入数据来实现-
## Normalize data
data_normalized_l2 = preprocessing.normalize(input_data, norm = 'l2')
print("\nL2 normalized data:\n", data_normalized_l2)
Python
执行以上代码行将生成以下输出 -
标记数据
我们已经知道,某种格式的数据对于机器学习算法是必需的。 另一个重要的要求是,在将数据作为机器学习算法的输入发送之前,必须正确标记数据。 例如,如果所说的分类,那么数据上会有很多标记。 这些标记以文字,数字等形式存在。与 sklearn 中的机器学习相关的功能期望数据必须具有数字标记。 因此,如果数据是其他形式,那么它必须转换为数字。 这个将单词标签转换为数字形式的过程称为标记编码。
标记编码步骤
按照以下步骤在 Python 中对数据标记进行编码 -
第1步 - 导入有用的软件包
如果使用 Python,那么这将是将数据转换为特定格式(即预处理)的第一步。 它可以做到如下 -
import numpy as np
from sklearn import preprocessing
第2步 - 定义样本标签
导入包后,我们需要定义一些样本标签,以便可以创建和训练标签编码器。 现在将定义以下样本标签 -
## Sample input labels
input_labels = ['red','black','red','green','black','yellow','white']
第3步 - 创建和训练标签编码器对象
在这一步中,我们需要创建标签编码器并对其进行训练。 以下是 Python 代码的实现 -
## Creating the label encoder
encoder = preprocessing.LabelEncoder()
encoder.fit(input_labels)
以下是运行上面的 Python 代码后的输出 -
第4步 - 通过编码随机排序列表来检查性能
此步骤可用于通过编码随机排序列表来检查性能。 下面的 Python 代码可以做同样的事情 -
## encoding a set of labels
test_labels = ['green','red','black']
encoded_values = encoder.transform(test_labels)
print("\nLabels =", test_labels)
标签将如下打印 -
Labels = ['green', 'red', 'black']
现在,可以得到编码值列表,即将文字标签转换为数字,如下所示 -
输出结果打印如下 -
第5步 - 通过解码一组随机数来检查性能 -
通过对随机数字集进行解码,可以使用此步骤来检查性能。 下面的 Python 代码也可以做同样的事情 -
## decoding a set of values
encoded_values = [3,0,4,1]
decoded_list = encoder.inverse_transform(encoded_values)
print("\nEncoded values =", encoded_values)
现在,将被打印如下 -
Encoded values = [3, 0, 4, 1]
print("\nDecoded labels =", list(decoded_list))
现在,解码值将被打印如下 -
Decoded labels = ['white', 'black', 'yellow', 'green']
标记与未标记数据
未标记的数据主要由自然或人造物体的样本组成,这些样本可以很容易从现实世界中获得。 它们包括音频,视频,照片,新闻文章等。
另一方面,带标签的数据采用一组未标记的数据,并用一些有意义的标签或标签或类来扩充每片未标记的数据。 例如,如果有照片,那么标签可以基于照片的内容放置,即它是男孩或女孩或动物或其他任何照片。 标记数据需要人类专业知识或判断一个给定的未标记数据。
有很多情况下,无标签数据丰富且容易获得,但标注数据通常需要人工/专家进行注释。 半监督学习尝试将标记数据和未标记数据组合起来,以建立更好的模型。
期待您的关注~