package com.nii.sim;
import net.semanticmetadata.lire.builders.DocumentBuilder;
import net.semanticmetadata.lire.builders.GlobalDocumentBuilder;
import net.semanticmetadata.lire.imageanalysis.features.global.CEDD;
import net.semanticmetadata.lire.searchers.GenericFastImageSearcher;
import net.semanticmetadata.lire.searchers.ImageSearchHits;
import net.semanticmetadata.lire.searchers.ImageSearcher;
import net.semanticmetadata.lire.utils.FileUtils;
import org.apache.lucene.analysis.core.WhitespaceAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.index.DirectoryReader;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.IndexWriterConfig;
import org.apache.lucene.store.FSDirectory;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.FileInputStream;
import java.io.IOException;
import java.nio.file.Paths;
import java.util.Iterator;
import java.util.List;
/**
* @author wzj
* @create 2018-07-22 11:16
**/
public class ImageSimilarityTest
{
/**
* 图片保存的路径
*/
private static final String IMAGE_PATH = "H:\\JAVA\\ImageSim\\conf\\image";
/**
* 索引保存目录
*/
private static final String INDEX_PATH = "H:\\JAVA\\ImageSim\\conf\\index";
public static void main(String[] args) throws IOException
{
//indexImages();
searchSimilarityImage();
}
private static void indexImages() throws IOException
{
List<String> images = FileUtils.getAllImages(Paths.get(IMAGE_PATH).toFile(), true);
GlobalDocumentBuilder globalDocumentBuilder = new GlobalDocumentBuilder(false, false);
globalDocumentBuilder.addExtractor(CEDD.class);
IndexWriterConfig conf = new IndexWriterConfig(new WhitespaceAnalyzer());
IndexWriter indexWriter = new IndexWriter(FSDirectory.open(Paths.get(INDEX_PATH)), conf);
for (Iterator<String> it = images.iterator(); it.hasNext(); )
{
String imageFilePath = it.next();
System.out.println("Indexing " + imageFilePath);
BufferedImage img = ImageIO.read(new FileInputStream(imageFilePath));
Document document = globalDocumentBuilder.createDocument(img, imageFilePath);
indexWriter.addDocument(document);
}
indexWriter.close();
System.out.println("Create index image successful.");
}
private static void searchSimilarityImage() throws IOException
{
IndexReader ir = DirectoryReader.open(FSDirectory.open(Paths.get(INDEX_PATH)));
ImageSearcher searcher = new GenericFastImageSearcher(5, CEDD.class);
String inputImagePath = "H:\\JAVA\\ImageSim\\conf\\image\\5.png";
BufferedImage img = ImageIO.read(Paths.get(inputImagePath).toFile());
ImageSearchHits hits = searcher.search(img, ir);
for (int i = 0; i < hits.length(); i++)
{
String fileName = ir.document(hits.documentID(i)).getValues(DocumentBuilder.FIELD_NAME_IDENTIFIER)[0];
System.out.println(hits.score(i) + ": \t" + fileName);
}
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
ImageSim.zip (27个子文件)
ImageSim
settings.gradle 28B
build.gradle 975B
src
main
resources
java
com
nii
sim
ImageSimilarityTest.java 3KB
spider
MyPipeline.java 2KB
AppStoreProcessor.java 2KB
gradlew 5KB
libs
lire.jar 3.21MB
gradlew.bat 2KB
index
write.lock 0B
segments_1 71B
gradle
wrapper
gradle-wrapper.properties 237B
gradle-wrapper.jar 52KB
conf
image
2.png 5KB
9.png 14KB
3.png 33KB
5.png 17KB
8.png 24KB
6.png 11KB
1.png 22KB
4.png 6KB
10.png 5KB
7.png 10KB
index
write.lock 0B
segments_1 136B
_0.si 363B
_0.cfe 225B
_0.cfs 2KB
共 27 条
- 1
资源评论
- snowjake2022-08-11#文字清晰 文件清晰 目录结构清晰 而且是gradle工程 很方便 我还没试 等下试玩来评价 试玩成功 效果还可以
dmfrm
- 粉丝: 480
- 资源: 23
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功