信息检索笔记-索引压缩

2024-05-04 23:08

本文主要是介绍信息检索笔记-索引压缩,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       第一章介绍了信息系统中的两个数据结构:词典及倒排记录表。本文将介绍对两个数据结构的各种压缩技术,这些技术对构建高效的IR系统很关键。

     索引压缩的优点:(1)第一能增加高速缓存利用率。在搜索系统中,如果某个关键字使用频繁,那么我们可以将他放在高速缓存中,这样搜索的时候只需要查一下高速缓存就行了(不要磁盘访问操作),找到之后解压缩就行了。如果索引小了就可以在高速缓存里面放更多的索引,当然就更快了。

   (2)压缩能够加快数据从磁盘到内存的速度。将未压缩的数据块传到内存时间大于压缩以后的传输时间+解压时间。即使会增加内存进行解压缩的开销,但是我们也可以通过加载一个小很多的压缩倒排表来减少I/O时间。

【注】解压算法一定要快。

     本文介绍的无损压缩,而大小写转换、词干还原和停用词剔除属于有损压缩。


词项统计特性

     Heaps定理,词项数目M、文档中词条的个数T有如下关系:

                

不同文档,k值略有不同。因为大小写转换和词干还原会降低词汇量的增长率,而允许加入数字和容忍拼写错误会增加该增长率。由上面的定理我们知道,随着文档数目的增加,词汇量会持续增加而不会达到一个稳定的值。

     Zipf定理:如果t1是文档计中出现最多的词项,而t2是文档集中出现第二多的词项,一次类推,那么排名第i多的词项的文档集频率与1/i成正比。如下:

                

随着词项出现次数的下降,那么出现的频率急剧下降。例如,出现第100多的词项出现频率就很小。


词典压缩

     影响信息检索最重要的一个因素是磁盘访问次数。而如果有部分词典存在磁盘上,那么在处理查询就需要更多的磁盘访问次数。因此词典压缩主要目的就是将词典放入内存,或者说是要把大部分词典放入内存,这样才能获得高的查询吞吐率。

     一般的存储方法(需要28B),400000个词项,需要400000*28=11.2MB,很显然这种方法很是浪费空间。

struct dictionary{char word[20];//20B存储单词int fileFrequency;//4B文档频率Type *reverseIndexPointer;//4B倒排记录指针
}

      下面针对这种浪费空间的方案提出一些改进方法。


(1)将词典存储在单一连续的单元中
     一个改进的办法是将所有的词项存在一个字符串中,而词典中存储一个定位指针。

char word[200000];//所有的单词都存在这个里面
struct dictionary{int index;//指向一个word里面的索引int fileFrequency;//4B文档频率Type *reverseIndexPointer;//4B倒排记录指针
}

(2)按块存储

     在单一连续的单元中,存储一些指针。然后只保留第一个词项的指针。


(3)公共前缀

     在上面的压缩方式里面,我们没有用到公共前缀。实际上按词典排序的单词一般都具有公共前缀,这样具有公共前缀的单词我们不需要存前缀,只需要用一个特殊字符来代替就行了。


倒排记录表的压缩

      倒排记录非常大,例如,800000篇文档,每篇文档200个词条,那么log(800000)=20,所以每个文档ID需要20b,则整个倒排记录表有800000*200*20/8=250MB。所以压缩很重要。

(1)可变字节码(VB)

      因为一些高频词汇出现的文档ID是连续的。例如,the:2888,2889,2890......。这样我们只需要存储第一个数,后面存偏移量就行了。

(2)r编码


后记

     下一篇是基于词项频率-文档频率的文档权重评分。请看:http://blog.csdn.net/lsjseu/article/details/12255761

这篇关于信息检索笔记-索引压缩的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/960296

相关文章

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

MySQL 索引简介及常见的索引类型有哪些

《MySQL索引简介及常见的索引类型有哪些》MySQL索引是加速数据检索的特殊结构,用于存储列值与位置信息,常见的索引类型包括:主键索引、唯一索引、普通索引、复合索引、全文索引和空间索引等,本文介绍... 目录什么是 mysql 的索引?常见的索引类型有哪些?总结性回答详细解释1. MySQL 索引的概念2

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二