图书推荐与管理系统(Qmazon)
=============
简介
-------------
这是本人于本科二年级时修读的"面向对象的程序设计(C++)"的课程作业。该系统实现了一个关于图书的评论与推荐系统,类似亚马逊、当当与豆瓣。该系统使用C++作为编程语言,并使用了Qt程序开发框架完成了程序的可视化,搭建了类似PC版QQ风格的界面,具有很高的美观度。本系统针对图书推荐这一核心功能采用了基于用户的协同过滤算法,并结合基于人口统计学的冷启动推荐算法完成了推荐模块的设计。
数据集 :http://www2.informatik.uni-freiburg.de/~cziegler/BX/
数据集三个csv文件请手动去掉文件最后一行的空行!!!!!!!!
并在编译项目后,将数据放至build目录相应编译模式文件夹下!!!!!!!!
系统展示图
-------------
</br>
![Alt](http://i.imgur.com/eQuoHYh.png)
![Alt](http://i.imgur.com/QJBUnHO.png)
需求分析
-------------
此系统对我们提出的需求可以分为前端功能和后端功能,前端功能即普通用户的一些操作功能,包括用户的注册、登录、获取推荐、打分、评论、更改信息、注销账户、查找图书、查找好友等功能,后端功能包括管理员的一些操作功能,包括管理员的登录、添加图书、删除图书、更改图书信息、添加新用户、删除用户、更改用户资料、查找图书、查找用户、注销账户等功能。因此在CLI(命令行界面)下我们需要首先设置登录与注册功能、登陆后根据登录身份的不同来设计可以进行的不同功能。而在GUI(图形用户界面)下我们需要设置登录界面、注册界面、管理员功能界面、用户功能界面、以及用户的各个子功能界面。命令行界面的实现将通过VS、Dev-Cpp来实现,而图形化界面将在CLI代码的基础上通过Qt Creator编译并实现。
类的设计
-------------
本程序主要的类有两个,其定义在base.h头文件中:图书(book)类与用户(user)类。具体定义及操作可见base.h头文件,这里便不再多说。其函数具体定义在Main.cpp文件中。
文件操作
-------------
#### 1、图书信息
使用 ifstream打开文件后,将每条读入的数据暂存到一个Book类型的newbook中,这本书的所有数据读完之后,将newbook使用
```c++
books.insert(map<string, Book>::value_type(IS, newbook));
```
加入到总的book这个map类型的对象中中。其中IS为newbook的ISBN码,直接用来索引图书。
书的各类信息分隔使用
```c++
getline(file, value, ';');
IS = string(value, 1, value.length() - 2);
```
表示读到“;”之前的数据,并且IS的内容是value去掉最前面的“与最后面的”所得。
最后使用```c++file.close();```关闭文件。
#### 2、用户信息
与图书信息的读入过程类似。
#### 3、评分信息
先用ifstream打开文件,之后用
```c++
getline(file, value, ';');
string(value, 1, value.length() - 2);
```
读入IS与ID,再直接利用map的索引将信息读入每个信息的对应项之中。并且增加读过这个book的用户信息,与这个user看过的图书信息。
```c++
users[ID].booksRead.insert(map<string, int>::value_type(IS, rank));
books[IS].usersRead.insert(map<string, int>::value_type(ID, rank));
```
最后使用file.close();关闭文件。并且读完用户全部评分信息后,使用迭代器将每个book与每个user的平均评分求出。例下面就是求出每个book的平均分的代码。
```c++
map<string, Book>::iterator iter = books.begin();
for (; iter != books.end(); iter++)
{
iter->second.aveRank = iter->second.sum / iter->second.cnt;
}
```
#### 4、文件回写
由于又增加修改删除的图书用户等,在使用过一遍系统后要将所有信息全部重新写入。
#####book文件写回
先用ofstream打开文件,之后先写回标题栏。
```c++
file << "\"ISBN\";\"Book-Title\";\"Book-Author\";\"Year-Of-Publication\";\"Publisher\""<< ";\"Image-URL-S\";\"Image-URL-M\";\"Image-URL-L\"" << endl;
```
之后将每一类信息写回,双引号使用\”表示。
最后
```c++
file.close();
```
关闭文件。
#####user文件写回。
先用ofstream打开文件,之后先写回标题栏。
```c++
file2 << "\"User-ID\";\"Location\";\"Age\"" << endl;
```
之后将每一类信息写回,双引号使用\”表示。
最后
```c++
file.close();
```
关闭文件。
#####rank文件写回。先用ofstream打开文件,之后先写回标题栏。
```c++
file3 << "\"User-ID\";\"ISBN\";\"Book-Rating\"" << endl;
```
之后将每一类信息写回,双引号使用\”表示。
最后
```c++
file.close();
```
关闭文件。
基于用户的协同过滤推荐算法
-------------
对于一个已经读过几本书的用户,我们采用的推荐方法便是采用正常的基于用户的协同过滤算法。基于用户的协同过滤推荐算法的基本思想便是:首先依据依据用户对物品的评价计算出所有用户之间的相似度,之后选出与当前用户最相似的N个用户,再用N个邻居用户对物品的评分,预测当前用户对没有浏览过的物品的可能评分,最后按照预测出的可能评分的高低向当前用户推荐物品。 接下来将对算法的实现进行详细介绍。算法在程序中的位置为recommendsystem1.cpp中的
```c++
User:: getrecommendation()
```
首先我们要先进行对与所有用户的相似度计算。计算的基本公式如下:
![alt](http://i.imgur.com/wBY7J35.png)
</br>当我们计算当前用户A与用户B的相似度时,首先我们要先去遍历A读过的书,从这些书里去找到B同样也读过的书,找到相应的书后,这本书便是公式中的p。以上公式可分为三个求和部分,因此函数中我采用了sumup,sumdown1,sumdown2分别累加。之后通过套用公式并对所有其共同读过的书进行累加计算出用户A与B的相似度,并通过第一层类似地计算出A与所有用户的相似度,将相似度存于一个
```c++
map<string, double>Sims
```
即当前用户与id为String的用户的相似度。</br>
到这里我们计算出了当前用户与所有用户的相似度,接下来我们便可以选取邻居用户进行预测分数。在这里的邻居用户数我选定为全体用户(27w+),原因是由于数据集本来就是就很稀疏本来能够拥有相似度的用户就很少,因此采用全体用户即可最为准确的进行推荐且不会造成速度上的缓慢。预测公式如下:
![alt](http://i.imgur.com/FyhfoNd.png)
首先我们从所有书中去遍历,并筛选出该用户没有读过的书,假定现在我们要预测图书P的预测评分,则接下来去从所有读过P的人中去寻找,找到与当前用户有相似度的用户,按照上边的公式进行计算并累加,便可以计算出P的预测评分。类似地,便可以计算出所有图书的预测评分。在这里我将所有预测评分存在了一个map<string, double> RankPre中,string指的是书的ISBN码,double指评分。</br>
之后便是排序过程,这里我首先写了一个将map中的元素按降序排列并存储在Vector的函数
```c++
void sortMapByValue(map<string, double>& tMap, vector<pair<string, double> >& tVector)
```
将之前的Rankpre排序后存于Rvector中,接下来便可以将Rvector前几个元素输出即为推荐图书了。</br>
在计算推荐图书的过程实际上也顺便进行了推荐好友的计算,即相似度Sims已被我们存储。之后再将Sims调用sortMapByValue函数进行降序排列并存于Svector中,再输出前几个元素便为推荐好友。</br>
同时,还有一点值得注意。如果一个用户读过书,但读的书过于少或过于“冷门”,以至于没有人与其读过相同的书,即没有人和他拥有相似度,则对他仍作冷�
辣椒种子
- 粉丝: 4328
- 资源: 5837
最新资源
- 抽水蓄能电站混合发电系统调峰经济调度模型研究:粒子群算法的应用与调度方案优化,抽水蓄能电站的最佳调度方案研究 参考文献:抽水蓄能电站的最佳调度方案研究 非完全复献 matlab?粒子群算法 主要内容:
- 局部遮阴环境下光伏MPPT仿真模型的粒子群优化算法研究,局部遮阴光伏MPPT仿真模型-粒子群算法 ,核心关键词:局部遮阴光伏; MPPT仿真模型; 粒子群算法; 优化算法 ,局部遮阴下光伏MPPT的粒
- 两级式单相光伏并网系统:BOOST电路MPPT控制与前级桥式逆变SPWM调制及双闭环控制并网效果展示,两级式单相光伏并网仿真 前级采用BOOST变电路,通过电导增量法MPPT控制实现最大功率点跟踪
- "常用PLC电气图纸与CAD电气原理图库:三菱、欧姆龙等品牌的实用图库与快速设计工具",常用PLC电气图纸,CAD电气原理图常用画法,60多套,有三菱,欧姆龙,西门子,基恩士,经验成功应用案例,元器件
- 基于IEEE 9节点三机九节点系统的Matlab Simulink仿真模型:电压观测与扩展研究,支持向量与离散模式,IEEE 9节点 三机九节点系统 Matlab simulink仿真 该模型自己搭
- COMSOL软件模拟环状流管道中球阀开度对速度场、压力场及阀门流阻特性的影响分析,comsol软件 环状流管道中球阀开度对速度场,压力场,阀门流阻特性的影响 就是提取数据对速度场,压力场,阀门流阻特性
- 基于S7-200 PLC与MCGS组态的运料小车控制:梯形图程序详解、接线图与IO分配及组态画面展示,No.1160 基于S7-200 PLC和MCGS组态的运料小车控制系统 带解释的梯形图程序,接线
- EPLAN电气元件库大全:含部件宏、EDZ格式及众多品牌低压电器,1:1实物对应,便捷布局,一站式采购 ,EPLAN史上最全部件库,部件宏,EDZ格式,大小合适导入容易 部件包含图片宏,尺寸宏,有西门
- "并联型有源滤波器APF的Matlab仿真模型:采用ip-iq谐波检测与滞环电流控制及PI直流电压调控",并联型有源滤波器,APF,matlab仿真模型 谐波检测采用ip-iq方法,电流控制是滞环控
- IPMSM模型中的MTPA控制策略:采用牛顿迭代法的精确控制研究,该模型为IPMSM的MTPA控制,MTPA采用牛顿迭代法对关 ,核心关键词:IPMSM; MTPA控制; 牛顿迭代法; 关联关系,"I
- "Buck变换器系列仿真:平均电流控制、负载跳变与双闭环PI控制的性能探究及学习指南",Buck变器系列仿真 包括平均电流控制,,负载跳变及闭环性能测试,双闭环PI控制 模型简单易懂,适合小白学习
- 永磁同步电机SIMULINK仿真下的MRAS无传感器控制策略探索,永磁同步电机+SIMULINK+MRAS无传感器控制 A1 暂无文档 ,核心关键词:永磁同步电机; SIMULINK; MRAS无传感
- 有源电力滤波器(并联型APF)针对非线性负载应用场景的电流优化控制 含非线性负载时电流THDr显著下降,滞环控制与三角波比较控制效果对比 ,有源电力滤波器(并联型APF) 应用场景:含非线性负载时 非
- "龙讯方案之HDMI转EDP高清接口技术,1920x1080@60Hz全规格支持,全套资料、原理图、PCB及源码资源一应俱全",lt9721龙讯方案,hdmi转edp,1920*1080-60,可以提
- 基于虚拟同步控制技术的双馈风机多端MMC阻抗建模验证与扫频分析程序(附讲解与仿真模型),扫频法 阻抗扫描 阻抗建模验证 正负序阻抗 逆变器 同步控制 VSG 复现 双馈风机MMC 电压源型VSG阻抗建
- 基于Matlab仿真的声源定位算法及STM32F4实现源码:高精度定位达0.013米,2022声源定位相关资料及代码 内附声源定位算法基本原理及matlab仿真原理及实现方法; stm32f4实现源码
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈