《零基础入门Spark》学习笔记 Day 14

特征工程-上

特征工程是机器学习流程中至关重要的环节,旨在通过数据转换、组合或创建新特征,提升模型性能。其核心目标包括提高数据质量、增强特征与目标变量的相关性,以及降低计算复杂度。

对于原始数据中的字段,我们会把它们分为数值型和非数值型。

Spark MLlib特征处理函数可以分为如下几类:

预处理(StringIndexer)

作用是以数据列为单位,把字段中的字符串转换为数值索引。

StringIndexed的用法比较简单,可以分为三个步骤:

第一步,实例化StringIndexer对象;

第二步,通过setInputCol和setOutputCol来指定输入列和输出列;

第三步,调用fit和transform函数,完成数据转换

特征选择(ChiSqSelector)

就是依据一定的标准,对特征字段进行遴选。实际上,面对数量众多的候选特征,业务经验往往是特征选择的重要出发点之一。与此同时,我们还会使用一些统计方法,去计算候选特征与预测标的之间的关联性,从而以量化的方式,衡量不同特征对于预测标的重要性。要使用ChiSqSelector来选择数值型字段,需要完成两步:

第一步,使用VectorAssembler创建特征向量

第二步,基于特征向量,使用ChiSqSelector完成特征选择。

归一化(MinMaxScaler)

用于是把一组数值,统一映射到同一个值域,而这个值域通常是[0,1]。当原始数据之间的量纲差异较大时,抖动较大,模型不容易收敛,从而导致训练效率较差。相反,当所有特征数据都被约束到同一个值域时,模型训练的效率会得到大幅提升。

MinMaxScaler的用法,也分为两步:

第一步,使用VectorAssembler创建特征向量;

第二步,基于特征向量,使用使用MinMaxScaler完成归一化

归一化的目标,在于去掉不同特征之间量纲的影响,避免量纲不一致而导致的梯度下降震荡,模型收敛效率低下等问题。

离散化

Embedding

向量计算

相关推荐
Clarence Liu2 小时前
langchain源码研究 - deepagents设计思想学习
人工智能·驱动开发·学习·langchain
Shadow(⊙o⊙)2 小时前
static与extern使用
c语言·学习
老纪的技术唠嗑局2 小时前
告别OpenClaw配置丢失——Mindkeeper内测版邀测
大数据·elasticsearch·搜索引擎
2501_933329552 小时前
技术深度剖析:Infoseek 字节探索舆情处置系统的全链路架构与核心实现
大数据·数据仓库·人工智能·自然语言处理·架构
Heartache boy2 小时前
DWT基础应用与获取程序运行时间Debug练习(上)
笔记·stm32·单片机
intcube2 小时前
让数据说话,让决策有据——构建闭环的数据驱动运营体系
大数据·人工智能·全面预算管理·财务规划
charlie1145141912 小时前
通用GUI编程技术——图形渲染实战(二十八)——图像格式与编解码:PNG/JPEG全掌握
开发语言·c++·windows·学习·图形渲染·win32
fly_over2 小时前
Claude Code 从零复刻教程 第 1 篇:项目初始化与 CLI 骨架
学习·源码·ai编程·工具·命令行·claude code
西梅汁2 小时前
C++ 设计模式三大类型理解
笔记