elastic search java api 向量搜索实践 / java结合es实现 以图搜图

这篇具有很好参考价值的文章主要介绍了elastic search java api 向量搜索实践 / java结合es实现 以图搜图。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

准备数据

elastic search java api 向量搜索实践 / java结合es实现 以图搜图,elasticsearch,springboot,java,elasticsearch,机器学习

1. FunctionScoreQueryBuilder 方式

代码

//构建脚本查询
Script script = new Script(
        Script.DEFAULT_SCRIPT_TYPE,
        "painless",
        //pic_vector - 搜索字段
        "cosineSimilarity(params.queryVector, doc['pic_vector']) + 1.0",
        new HashMap<String, Object>() {{
            //searchData.getPicVector() - 需要搜索的向量数组,List<Double> 类型
            put("queryVector", searchData.getPicVector());
        }});
ScriptScoreFunctionBuilder scriptScoreFunctionBuilder = ScoreFunctionBuilders.scriptFunction(script);

//构建普通查询
BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
// 只查存在的数据
boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getState), ConstantEnum.ONE.code));
// 查询名称
if (StringUtils.isNotBlank(searchData.getName())) {
    boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getName), searchData.getName()));
}

// 构建查询请求
SearchRequest searchRequest = new SearchRequest("picture");
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
FunctionScoreQueryBuilder functionScoreQueryBuilder = QueryBuilders.functionScoreQuery(boolQueryBuilder, scriptScoreFunctionBuilder);
searchSourceBuilder.query(functionScoreQueryBuilder);
searchRequest.source(searchSourceBuilder);

// 执行搜索
SearchResponse searchResponse = null;
try {
    searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
} catch (IOException e) {
    e.printStackTrace();
}

DSL

GET picture/_search
{
  "query": {
    "function_score": {
      "query": {
        "bool": {
          "filter": [
            {
              "term": {
                "state": {
                  "value": 1,
                  "boost": 1
                }
              }
            }
          ],
          "adjust_pure_negative": true,
          "boost": 1
        }
      },
      "functions": [
        {
          "filter": {
            "match_all": {
              "boost": 1
            }
          },
          "script_score": {
            "script": {
              "source": "cosineSimilarity(params.queryVector, doc['pic_vector']) + 1.0",
              "lang": "painless",
              "params": {
                "queryVector": [
                  数据太长了,先不展示了~
                ]
              }
            }
          }
        }
      ],
      "score_mode": "multiply",
      "max_boost": 3.4028235e+38,
      "boost": 1
    }
  }
}

搜索图片

elastic search java api 向量搜索实践 / java结合es实现 以图搜图,elasticsearch,springboot,java,elasticsearch,机器学习

搜索结果

elastic search java api 向量搜索实践 / java结合es实现 以图搜图,elasticsearch,springboot,java,elasticsearch,机器学习文章来源地址https://www.toymoban.com/news/detail-745546.html

2. WrapperQueryBuilder 方式

代码

BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
searchRequest.source().query(boolQueryBuilder);

// 只查存在的数据
boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getState), ConstantEnum.ONE.code));

// 查询拖名称
if (StringUtils.isNotBlank(searchData.getName())) {
    boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getName), searchData.getName()));
}

/*
    若包含图片向量,使用 WrapperQueryBuilder 重新构建搜索 DSL 。
    这个方法要在所有条件设置完成之后调用
 */
List<Double> picVector = searchData.getPicVector();
if (CollectionUtil.isNotEmpty(picVector)) {
    buildPicVectorWrapperQueryBuilder(searchData, searchRequest);
}
//执行检索
SearchResponse searchResponse = null;
try {
    searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
} catch (IOException e) {
    e.printStackTrace();
    return ElasticSearchUtil.getEmptyList();
}

/**
 * 构建向量搜索DSL
 *
 * @param searchData
 * @param searchRequest
 */
private void buildPicVectorWrapperQueryBuilder(PictureSearchParam searchData, SearchRequest searchRequest) {
    SearchSourceBuilder source = searchRequest.source();
    source.minScore(searchData.getMinCosScore());
    JSONObject boolQueryDsl = JSONObject.parseObject(source.toString()).getJSONObject("query");
    String fieldName = MapUtils.camelToUnderline(FieldGetterUtil.getPropName(searchData::getPicVector));
    JSONObject queryObject = new JSONObject();
    queryObject.
            put("script_score", new JSONObject() {{
                put("query", boolQueryDsl);
                put("script", new JSONObject() {{
                    put("source", "cosineSimilarity(params." + fieldName + ", doc['" + fieldName + "'])+1.0");
                    put("params", new JSONObject() {{
                        put(fieldName, searchData.getPicVector());
                    }});
                }});
            }});
    WrapperQueryBuilder wrapperQueryBuilder = new WrapperQueryBuilder(JSON.toJSONString(queryObject));
    searchRequest.source().query(wrapperQueryBuilder);
}

DSL

GET picture/_search
{
  "from": 0,
  "size": 10,
  "query": {
    "wrapper": {
      "query": "{"script_score":{"query":{"bool":{"filter":[{"term":{"state":{"value":1,"boost":1.0}}}],"adjust_pure_negative":true,"boost":1.0}},"script":{"source":"cosineSimilarity(params.pic_vector, doc['pic_vector'])+1.0","params":{"pic_vector":[1.6442052125930786,1.8865864276885986,1.7520954608917236,1.468852162361145,0.5215243697166443,0.7162830829620361,0.24571764469146729,1.4161274433135986,0.6646647453308105,1.3490488529205322,0.48114028573036194,0.2379283457994461,1.2469896078109741,0.08662496507167816,0.5922273993492126,0.10052661597728729,0.10489580780267715,2.9626169204711914,0.9646034240722656,0.19339174032211304,0.6715909242630005,0.04913193732500076,0.0,0.42337557673454285,0.025834018364548683,0.0,0.11716371029615402,0.6066735982894897,0.014276627451181412,2.884373903274536,1.64122474193573,1.2666609287261963,0.25835415720939636,1.1439200639724731,1.4614897966384888,0.11240338534116745,0.41580113768577576,1.0173624753952026,0.5987152457237244,1.2826963663101196,0.5032907724380493,1.057185173034668,0.547160804271698,0.05201975628733635,0.9926323890686035,0.21758079528808594,1.5080771446228027,0.8714171648025513,1.0743465423583984,0.26693201065063477,0.09906674176454544,0.6293906569480896,1.286428451538086,0.0,0.3668249547481537,0.5311413407325745,0.061351045966148376,2.250185012817383,2.789849042892456,0.15071651339530945,0.1434730738401413,0.9516364932060242,0.1407829225063324,0.25287064909935,0.17089177668094635,1.6555739641189575,0.0,0.0019493978470563889,1.3358027935028076,0.07204823940992355,0.16275016963481903,0.11294800788164139,0.5596479177474976,2.8226816654205322,0.14157873392105103,0.03585885465145111,0.9136238098144531,0.41478878259658813,1.0509036779403687,0.3129948079586029,2.0000646114349365,0.8153970837593079,1.3230550289154053,1.1095032691955566,0.28675076365470886,0.18675370514392853,0.2574092745780945,0.45135366916656494,0.016980139538645744,0.20753440260887146,0.41814732551574707,0.45569372177124023,0.3243209421634674,2.3663172721862793,0.3488512933254242,0.3961148262023926,1.2847280502319336,0.4596094787120819,0.295514315366745,0.27450114488601685,0.3971012234687805,0.09721055626869202,1.0776207447052002,1.7841401100158691,1.1067540645599365,0.47844311594963074,0.20624254643917084,0.31310611963272095,0.6461139917373657,0.7538109421730042,0.395407110452652,0.45494332909584045,0.6232404112815857,0.8919894695281982,0.07885006815195084,0.4594714045524597,0.0811014398932457,0.4367794096469879,0.38426822423934937,0.32951658964157104,0.39118894934654236,0.22487390041351318,0.8610787391662598,0.5830796957015991,0.22959084808826447,0.0,0.9512133002281189,1.5710111856460571,1.2377055883407593,0.7546780109405518,0.48969006538391113,0.01670645736157894,0.003672399092465639,0.13706518709659576,1.7633861303329468,0.0814945325255394,1.1701894998550415,1.7390072345733643,0.3970920443534851,0.12410901486873627,0.25183501839637756,0.0,0.8199000358581543,0.7423927187919617,0.6346560716629028,0.022905947640538216,0.04582146182656288,0.9695563912391663,0.12152308970689774,0.17273357510566711,0.7655898928642273,0.08139333128929138,0.07582168281078339,0.9004191756248474,0.14518927037715912,0.6863758563995361,0.1891728788614273,1.0480291843414307,0.19950711727142334,0.8628987073898315,0.5608657598495483,0.8113354444503784,1.4624766111373901,1.43254554271698,0.4083332121372223,0.34310656785964966,0.9406865835189819,0.25686052441596985,1.1322646141052246,1.3540557622909546,0.02817135490477085,0.9846411943435669,0.9473340511322021,0.011850777082145214,0.061210229992866516,1.5749471187591553,0.07743599265813828,0.021998148411512375,0.3337361216545105,1.3646867275238037,0.197146937251091,0.02684418112039566,0.12807682156562805,1.0077452659606934,0.3472479283809662,1.2218244075775146,0.09163398295640945,0.933601975440979,0.9883574843406677,0.0011759570334106684,1.3720240592956543,0.6321293711662292,0.4054896831512451,0.35202157497406006,0.9274296164512634,0.31666436791419983,0.2984192967414856,1.3704978227615356,0.5182018876075745,1.0565110445022583,0.40002939105033875,0.4459632635116577,0.040395546704530716,0.10418936610221863,0.17342320084571838,0.2005527913570404,0.8796011209487915,0.11033149808645248,1.0753612518310547,1.6421480178833008,0.8594897389411926,0.23118343949317932,0.020162638276815414,0.11008383333683014,1.025146484375,0.6431025266647339,0.3835214376449585,0.2778571844100952,0.19006343185901642,0.1956976354122162,0.33776241540908813,1.3048166036605835,0.404217928647995,0.2543957233428955,0.6464782953262329,0.11861731112003326,0.3645017445087433,0.39175671339035034,0.001248408923856914,0.21438832581043243,1.7175337076187134,0.023903202265501022,0.08463321626186371,2.3428306579589844,1.0570204257965088,0.7067260146141052,0.02989930287003517,0.5042319893836975,1.3931736946105957,2.6658830642700195,0.15046465396881104,0.06599919497966766,0.950067937374115,1.8213883638381958,1.1690945625305176,0.24541716277599335,0.2557571828365326,1.3565306663513184,0.8072720766067505,0.08816192299127579,0.35571640729904175,0.18390542268753052,0.21673527359962463,0.03435497358441353,0.6771786212921143,0.3647828698158264,0.013729920610785484,3.0426361560821533,2.367980480194092,0.5787132382392883,1.466723084449768,0.44589436054229736,0.22420497238636017,0.462899774312973,0.8461235165596008,0.8448554277420044,0.22718840837478638,0.5224109888076782,0.363288015127182,1.0595544576644897,0.7337091565132141,0.828894853591919,0.38964617252349854,0.33601781725883484,1.631548523902893,0.1084078997373581,0.0020526465959846973,0.44630682468414307,0.737890899181366,0.5049909949302673,1.5234544277191162,0.12044011056423187,0.47697144746780396,0.21996237337589264,0.03638237714767456,0.00388450943864882,1.1379690170288086,0.09419768303632736,0.04319988936185837,0.3590329587459564,0.7639684677124023,0.20068643987178802,0.03304234892129898,0.9005059003829956,0.3665461242198944,0.07220682501792908,0.4413575232028961,2.284785270690918,0.4442480802536011,0.42596006393432617,0.5397369265556335,0.48256734013557434,0.05242738127708435,0.048188235610723495,0.020073335617780685,0.28828370571136475,0.5012069344520569,0.1711190640926361,0.44558703899383545,0.11565989255905151,2.3350460529327393,0.9526135325431824,0.9658022522926331,0.5853427648544312,0.478196382522583,0.9319117069244385,3.159679412841797,0.6313217878341675,0.48193103075027466,0.4907498359680176,1.1279035806655884,0.5200980305671692,0.33537474274635315,1.0791858434677124,0.0018491842783987522,0.30037400126457214,0.3399773836135864,0.010889220982789993,0.2526705265045166,0.9613133668899536,0.5535693168640137,2.868227243423462,0.6160788536071777,0.33963432908058167,0.7948097586631775,1.3093180656433105,0.7971509695053101,0.11126016080379486,1.805647611618042,0.6230979561805725,0.36196717619895935,0.0321471132338047,1.3630361557006836,2.590884208679199,0.6007828712463379,0.14051060378551483,0.3489038646221161,1.0702216625213623,1.4794830083847046,0.39767003059387207,0.20679956674575806,0.015743117779493332,0.2465030550956726,1.7555897235870361,0.06133950874209404,1.101117730140686,0.9891293048858643,0.47916021943092346,0.04654693230986595,1.335697054862976,1.2709628343582153,0.1092357262969017,0.3777872622013092,0.25866177678108215,2.8629610538482666,0.330032616853714,0.30021238327026367,0.14954997599124908,0.5424569845199585,0.07252263277769089,0.15865133702754974,0.40076035261154175,0.7282562851905823,0.3705361783504486,0.015413789078593254,0.015840834006667137,0.4034458100795746,0.02868160977959633,1.3420019149780273,0.036083247512578964,0.8236557245254517,0.7892447710037231,0.12343525141477585,0.07038391381502151,0.06860870867967606,0.6933117508888245,0.0,0.3600417673587799,0.3517952859401703,0.7348923087120056,2.3836183547973633,0.19568277895450592,0.019822144880890846,0.49209439754486084,1.1363734006881714,0.7762866616249084,0.35173341631889343,0.059090349823236465,0.24521274864673615,1.3700393438339233,0.5121893286705017,0.45342862606048584,2.3489906787872314,0.130288764834404,0.9179604053497314,0.23467522859573364,1.2870936393737793,0.18395568430423737,0.896112322807312,0.05169786885380745,0.5849955081939697,0.17520982027053833,0.4322708249092102,0.10064983367919922,0.6949729919433594,0.31241825222969055,0.017296070232987404,0.21149475872516632,0.10829086601734161,0.5270223021507263,0.3509761691093445,0.8720590472221375,0.7077852487564087,1.0009738206863403,0.2758578360080719,0.001055699191056192,0.12185824662446976,0.1356113702058792,0.6326422691345215,0.30826836824417114,0.43483516573905945,0.6391230821609497,0.015828637406229973,0.060418616980314255,0.08130747824907303,0.8263728618621826,0.6869108080863953,1.4351948499679565,1.5345723628997803,0.17672862112522125,0.7611819505691528,0.19866245985031128,0.03643443062901497,0.40735024213790894,0.8617676496505737,0.6442905068397522,0.13291509449481964,0.08961779624223709,0.013482140377163887,0.3748442530632019,0.628272294998169,0.48694804310798645,0.6231419444084167,0.354279100894928,0.8560224175453186,1.8554027080535889,0.018688630312681198,0.558110773563385,0.8572626709938049,1.342378854751587,0.15025082230567932,0.4749850928783417,0.14787939190864563,0.291209876537323,0.6362593173980713,0.2041471004486084,0.07663371413946152,1.1260404586791992,1.0800954103469849,0.12397252023220062,0.1458875834941864,2.1002097129821777,0.22718596458435059,0.9807181358337402,0.8075492978096008,0.09468934684991837,1.3038803339004517,0.36220166087150574,0.1676052212715149,0.39378318190574646,0.08315883576869965,0.19796334207057953,0.3453468382358551,0.08353745192289352,0.7185510396957397,0.5905119180679321,0.17001262307167053,0.02233128249645233,1.3430479764938354,0.42938247323036194,2.469149589538574,0.17807133495807648,0.6416274309158325,0.7143462896347046,0.24247682094573975,0.3711608946323395,1.1266783475875854,0.21057012677192688,0.08259957283735275,0.06458510458469391,0.7159583568572998,0.08617547154426575,0.8249351382255554,0.5276781916618347,0.21359385550022125,1.655901551246643,2.3674702644348145,0.25014927983283997,0.5986981987953186,0.947422206401825,0.15310008823871613,0.009164717979729176]}}}}"
    }
  },
  "min_score": 1,
  "explain": true,
  "_source": {
    "includes": [
      "id",
      "pic_path"
    ],
    "excludes": []
  },
  "sort": [
    {
      "create_time": {
        "order": "desc"
      }
    }
  ],
  "track_total_hits": 2147483647
}

搜索图片

elastic search java api 向量搜索实践 / java结合es实现 以图搜图,elasticsearch,springboot,java,elasticsearch,机器学习

搜索结果

elastic search java api 向量搜索实践 / java结合es实现 以图搜图,elasticsearch,springboot,java,elasticsearch,机器学习

看到最后了一起薅个羊毛呗~

到了这里,关于elastic search java api 向量搜索实践 / java结合es实现 以图搜图的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring Boot 整合 分布式搜索引擎 Elastic Search 实现 数据聚合

    本文参考黑马 分布式Elastic search Elasticsearch是一款非常强大的开源搜索引擎,具备非常多强大功能,可以帮助我们从海量数据中快速找到需要的内容 本篇文章将讲解 Elastic Search 如何实现数据聚合,以及 在项目实战中如何通过数据聚合实现业务需求并完成功能。 以下为官方

    2024年02月11日
    浏览(43)
  • Spring Boot 整合 分布式搜索引擎 Elastic Search 实现 我附近的、酒店竞排

    本文参考黑马 分布式Elastic search Elasticsearch是一款非常强大的开源搜索引擎,具备非常多强大功能,可以帮助我们从海量数据中快速找到需要的内容 在酒店列表页的右侧,有一个小地图,点击地图的定位按钮,地图会找到你所在的位置: 点击定位后,会发送给服务端以下请求

    2024年02月06日
    浏览(38)
  • ES搜索引擎入门+最佳实践(九):项目实战(二)--elasticsearch java api 进行数据增删改查

            本篇是这个系列的最后一篇了,在这之前可以先看看前面的内容: ES搜索引擎入门+最佳实践(一)_flame.liu的博客-CSDN博客 ES搜索引擎入门+最佳实践(二)_flame.liu的博客-CSDN博客 ES搜索引擎入门+最佳实践(三)_flame.liu的博客-CSDN博客 ES搜索引擎入门+最佳实践(四)_flame.liu的博客

    2024年02月12日
    浏览(55)
  • 【搜索引擎】elastic search核心概念

    前言 本文不涉及ES的具体安装下载、操作、集群的内容,这部分内容会放在后面一篇文章中。本文只包含ES的核心理论,看完本文再去学ES的细节会事半功倍。 目录 1.由日志存储引出的问题 2.什么是ES? 3.ES的数据结构 4.ES的核心原理 5.联系作者 本文或者说本系列的来源: 前面

    2024年02月03日
    浏览(46)
  • fastapi结合Manticore Search、elasticsearch、mysql实现全文搜索

    创建测试表 测试表插入数据 表字段描述 字段意义 mysql数据同步到es es查看数据(Elasticvue插件)   mysql数据同步到Manticore 注:Manticore 和 Mysql 使用pymysql即mysql客户端 Manticore 数据查询(工具Webyog SQLyog)   es安全认证连接(参考官网) 按fields查询方法封装,输入参数fields 筛选器,

    2024年02月12日
    浏览(41)
  • elastic search es 分组统计 aggs 次数用法

    参考链接:https://www.elastic.co/guide/en/elasticsearch/reference/current/search-aggregations.html es 各个版本的语法可能会不一样,如果大家在用的时候发现语法报错了,请查阅相关版本的语法。 刚需要按 ip 地址统计某个接口的访问次数,查了下 es 分组统计次数 aggs 的用法,特此记录一下,方

    2024年02月11日
    浏览(57)
  • 使用docker安装elastic search[ES]和kibana

    使用docker安装elastic search和kibana,版本均为7.17.1 docker pull# 去dockerhub看具体版本,这里用7.17.1 临时安装生成文件# 参数说明 -d 后台启动 –name 起别名即:NAMES -p 9200:9200 将端口映射出来 elasticsearch的9200端口是供外部访问使用;9300端口是供内部访问使用集群间通讯 -e “discovery.

    2024年02月14日
    浏览(45)
  • 微服务 分布式搜索引擎 Elastic Search RestAPI

    本文参考黑马 分布式Elastic search Elasticsearch是一款非常强大的开源搜索引擎,具备非常多强大功能,可以帮助我们从海量数据中快速找到需要的内容 ES官方提供了各种不同语言的客户端,用来操作ES。这些客户端的本质就是组装DSL语句,通过http请求发送给ES。官方文档地址:

    2024年01月24日
    浏览(47)
  • 微服务分布式搜索引擎 Elastic Search RestClient 操作文档

    本文参考黑马 分布式Elastic search Elasticsearch是一款非常强大的开源搜索引擎,具备非常多强大功能,可以帮助我们从海量数据中快速找到需要的内容 初始化RestHighLevelClient 为了与索引库操作分离,我们再次参加一个测试类,做两件事情: 初始化RestHighLevelClient 我们的酒店数据

    2024年01月24日
    浏览(38)
  • 【elastic search】JAVA操作elastic search

    目录 1.环境准备 2.ES JAVA API 3.Spring Boot操作ES 本文是作者ES系列的第三篇文章,关于ES的核心概念移步: https://bugman.blog.csdn.net/article/details/135342256?spm=1001.2014.3001.5502 关于ES的下载安装教程以及基本使用,移步: https://bugman.blog.csdn.net/article/details/135342256?spm=1001.2014.3001.5502 在前文

    2024年01月25日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包