# PP-ShiTu 库管理工具
本工具是PP-ShiTu的离线库管理工具,主要功能包括:新建图像库、更改图像库、建立索引库、更新索引库等功能。此工具是为了用户能够可视化的管理图像及对应的index库,用户可根据实际情况,灵活的增删改查相应的gallery图像库及索引文件,在提升用户体验的同时,辅助PP-ShiTu在实际应用的过程中达到更好的效果。
目前此工具支持平台包括:
- Mac
- Windows
- Linux(注意,由于linux输入法问题,可能无法支持中文)
## 目录
- [1. 功能介绍](#1)
- [1.1 新建图像库](#1.1)
- [1.2 打开图像库](#1.2)
- [1.3 导入图像](#1.3)
- [1.4 图像操作](#1.3)
- [1.5 其他功能](#1.5)
- [2. 使用说明](#2)
- [2.1 环境安装](#2.1)
- [2.2 模型准备](#2.2)
- [2.3运行使用](#2.3)
- [3.生成文件介绍](#3)
- [致谢](#4)
- [FAQ](#FAQ)
## 1. 功能介绍
此工具主要功能包括:
- 构建`PP-ShiTu`中索引库对应的`gallery`图像库
- 根据构建的`gallery`图像库,生成索引库
- 对`gallery`图像库进行操作,如增删改查等操作,并更新对应的索引库
其中主界面的按钮如下图所示
界面按钮展示
上图中第一行包括:`主要功能按钮`、`保存按钮`、`新增类别按钮`、`删减类别按钮`。
第二行包括:`搜索框`、`搜索确定键`、`新加图像按钮`、`删除图像按钮`。
下面将进行具体功能介绍,其操作入口,可以点击`主要功能按钮`下拉菜单查看,如下图所示:
主要功能展示
### 1.1 新建图像库
点击新建库功能后,会选择一个**空的存储目录**或者**新建目录**,此时所有的图片及对应的索引库都会存放在此目录下。完成操作后,如下图所示
新建库
此时,用户可以新建类别具体可以点击`新增类别按钮`、`删减类别按钮`。选中类别后,可以进行添加图像及相关操作,具体可以点击及`新加图像按钮`、`删除图像按钮`。完成操作后,**注意保存**。
### 1.2 打开图像库
此功能是,用此工具存储好的库,进行打开编辑。注意,**打开库时,请选择打开的是新建库时文件夹路径**。打开库后,示例如下
打开库
### 1.3 导入图像
在打开图像库或者新建图像库完成后,可以使用导入图像功能,即导入用户自己生成好的图像库。具体有支持两种导入格式
- image_list格式:打开具体的`.txt`文件。`.txt`文件中每一行格式: `image_path label`。跟据文件路径及label导入
- 多文件夹格式:打开`具体文件夹`,此文件夹下存储多个子文件夹,每个子文件夹名字为`label_name`,每个子文件夹中存储对应的图像数据。
### 1.4 图像操作
选择图像后,鼠标右击可以进行如下操作,可以根据需求,选择具体的操作,**注意修改完成图像后,请点击保存按钮,进行保存**
图像操作
### 1.5 生成、更新index库
在用户完成图像库的新建、打开或者修改,并完成保存操作后。可以点击`主要功能按钮`中`新建/重建索引库`、`更新索引库`等功能,进行索引库的新建或者更新,生成`PP-ShiTu`使用的Index库
## 2. 使用说明
### 2.1 环境安装
安装好`PaddleClas`后
```shell
pip install fastapi
pip install uvicorn
pip install pyqt5
```
### 2.2 模型准备
请按照[PP-ShiTu快速体验](../quick_start/quick_start_recognition.md#2.2.1)中下载及准备inference model,并修改好`${PaddleClas}/deploy/configs/inference_drink.yaml`的相关参数。
### 2.3 运行使用
运行方式如下
```shell
cd ${PaddleClas}/deploy/shitu_index_manager
python index_manager.py -c ../configs/inference_drink.yaml
```
## 3. 生成文件介绍
使用此工具后,会生成如下格式的文件
```shell
index_root/ # 库存储目录
|-- image_list.txt # 图像列表,每行:image_path label。由前端生成及修改,后端只读
|-- images # 图像存储目录,由前端生成及增删查等操作。后端只读
| |-- md5.jpg
| |-- md5.jpg
| |-- ……
|-- features.pkl # 建库之后,保存的embedding向量,后端生成,前端无需操作
|-- index # 真正的生成的index库存储目录,后端生成及操作,前端无需操作。
| |-- vector.index # faiss生成的索引库
| |-- id_map.pkl # 索引文件
```
其中`index_root`是使用此工具时,用户选择的存储目录,库的索引文件存储在`index`文件夹中。
使用`PP-ShiTu`时,索引文件目录需换成`index`文件夹的地址。
## 致谢
此工具的前端主要由[国内qt论坛](http://www.qtcn.org/)总版主[小熊宝宝](https://github.com/cnhemiya)完成,感谢**小熊宝宝**的大力支持~~
此工具前端原项目地址:https://github.com/cnhemiya/shitu-manager
## FAQ
- 问题1: 点击新建索引库后,程序假死
答:生成索引库比较耗时,耐心等待一段时间就好
- 问题2: 导入图像是什么格式?
答: 目前支持两种格式 1)image_list 格式,list中每行格式:path label。2)文件夹格式:类似`ImageNet`存储方式
- 问题3: 生成 index库报错
答:在修改图像后,必须点击保存按钮,保存完成后,再继续生成index库。
- 问题4: 报错 图像与index库不一致
答:可能用户自己修改了image_list.txt,修改完成后,请及时更新index库,保证其一致。