美文网首页算法
机器学习中的稀疏矩阵

机器学习中的稀疏矩阵

作者: CourageK | 来源:发表于2019-05-29 19:38 被阅读0次

什么是稀疏矩阵?

    大多数元素都是0的矩阵称为稀疏矩阵,否则称为稠密矩阵。规模巨大的稀疏矩阵在应用机器学习中很常见,尤其在自然语言处理领域中,例如独热编码。稀疏矩阵的表示、计算会增加空间和时间复杂度,因此描述稀疏矩阵的稀疏性需要进行特殊的表示,以提高存储和计算性能。

    本文由浅入深地结合Python实例来剖析稀疏矩阵的很多存储和计算方式,比如SciPy库在稀疏矩阵的计算上支持很好。文章内容主要包含以下几个部分。

稀疏矩阵的稀疏性

    矩阵的稀疏性可以用分数来量化,等于矩阵中零值的个数除以矩阵中的元素总数:

    sparsity = count zero elements / total elements

    下面是一个3 x 6稀疏矩阵的例子。

      1, 0, 0, 1, 0, 0

A = 0, 0, 2, 0, 0, 1 

      0, 0, 0, 2, 0, 0

    该矩阵有13个零值元素,元素总数为18,因此该矩阵的稀疏性为:13/18=0.722.

机器学习中的稀疏矩阵

      对于机器学习来说,稀疏矩阵很常见,比如用户是否看过电影库中的所有电影,用户是否购买了产品目录中的产品,歌曲目录中每首歌曲的收听次数等。

    稀疏矩阵的表示方法如下:

    1)Coordinate Format (COO):是一种坐标形式的稀疏矩阵。采用三个数组row、col和data保存非零元素的信息,这三个数组的长度相同,row保存元素的行,col保存元素的列,data保存元素的值。存储的主要优点是灵活、简单,仅存储非零元素以及每个非零元素的坐标。但是COO不支持元素的存取和增删,一旦创建之后,除了将之转换成其它格式的矩阵,几乎无法对其做任何操作和矩阵运算。

坐标表示实例 coo例子

2)Diagonal Storage Format (DIA,对角线存储格式):对角线矩阵,它由两个数组进行存储:values是一个二维数组,distance是一个一维数组,distance[i]表示对角线相对主对角线的偏移量。values[i][j]表示第i行,相对主对角线偏离distance[j]的那条对角线上的数值。

DIA表示实例 DIA例子

3)Compressed Sparse Row Format (CSR):压缩稀疏行矩阵,它由values、columns、rows三个数组组成。values是一个一维数组,columns是一个和values等长的一维数组,表示values中每个元素所在的列。rows是一个一维数组,rows[i]表示第i行元素在columns和values中的起始位置。rows数组的长度等于行数+1。

稀疏矩阵的表示

用Python进行稀疏矩阵计算

相关文章

  • 机器学习中的稀疏矩阵

    什么是稀疏矩阵? 大多数元素都是0的矩阵称为稀疏矩阵,否则称为稠密矩阵。规模巨大的稀疏矩阵在应用机器学习中很常见,...

  • 稀疏矩阵计算心得

    在机器学习中,经常遇到稀疏向量,稀疏矩阵。如何高效处理这些稀疏对象,决定了一些模型能否在线落地应用。目前正在专攻这...

  • MATLAB稀疏矩阵

    7稀疏矩阵 稀疏矩阵是一种特殊类型的矩阵,即矩阵中包括较多的零元素。对于稀疏矩阵的这种特性,在MATLAB中可以只...

  • keras使用稀疏输入进行训练

    稀疏矩阵 稀疏矩阵是指矩阵中数值为0的元素数目远远多于非0元素的数目,在实际中遇到的大矩阵基本都是稀疏的。如果使用...

  • 线性代数(7) 矩阵

    矩阵 矩阵在机器学习中重要性就不再多数,在机器学习特别是深度学习中,大部分工作就是对矩阵进行变换和运算。以下内容需...

  • 机器学习稀疏矩阵简介(附Python代码)

    摘要:本文主要介绍了稀疏矩阵的基本知识、它存在的一些问题以及如何在Python中应用它,对于初学者和工程应用者来说...

  • 稀疏矩阵用于python的keras和theano

    稀疏矩阵 稀疏矩阵(sparse matrix)是由于矩阵中存在大量0,从而可以采用特别的存储技巧来压缩内存。由于...

  • 机器学习中的矩阵

    预备知识 详细内容见: 机器学习的数学基础 先上数学中的几个定理与定义. 设 是数域 (实数域或复数域) 上的...

  • 机器学习的数学基础相关文章

    矩阵机器学习的数学基础:矩阵篇

  • 稀疏矩阵

    对于经过ReLU之后的网络,通常存在很多的0。这时如果用稀疏矩阵来表示,则会节省存储空间,或者带来计算上的便利。稀...

网友评论

    本文标题:机器学习中的稀疏矩阵

    本文链接:https://www.haomeiwen.com/subject/prdutctx.html