spark scala在计算特征向量欧氏距离中的一些问题

前言

本文设计scala的数据类型如下:

Seq

Array

mutable.WrappedArray

Vector

struct

涉及方法:

import scala.collection.mutable

import org.apache.spark.ml.linalg.{Vector, Vectors}

import org.apache.spark.ml.feature.VectorAssembler

import org.apache.spark.ml.feature.MinMaxScaler

简述:

spark.sql 获取hive中存储好的特征表格,toDF为该dataFrame增加对应列名,使用VectorAssembler()将相关特征取出集成为输出dataFrame:output(其中新增一列类型为vector的特征向量),定义标准化的对象scaler(如MinMaxScaler()),该对象的ft方法获取output中的标准化参数对象scalerModel,利用scalerModel的transform方法处理output获得scaledData,即标准化特征向量

特征向量可以先保存为hive库表,在这个过程中原本类型为vector的特征向量会被自动转化为struct<type:tinyint,size:int,indices:array<int>,values:array<double>>。需要注意Array和mutable.WrappedArray的区别。

所以在计算特征向量欧氏距离时,可以使用mutable.WrappedArray为传入参数的udf定义方式,取该字段的.values进行具体计算。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值