当前位置: 首页 > news >正文

Elasticsearch(9) gauss的使用

elasticsearch version: 7.10.1
在Elasticsearch中,gauss作为衰减函数(decay function)被用于function_score查询中,用于实现基于地理位置或其他数值字段的衰减权重评分。gauss衰减函数模拟了高斯分布,即距离中心点越近的文档,其得分越高;随着距离增大,得分按照高斯分布规律衰减。

gauss的语法

GET /your_index/_search
{"query": {"function_score": {"query": { // 基础查询,可以是任何有效的Elasticsearch查询"match_all": {}},"functions": [{"gauss": {// 距离衰减字段,这里假设是location"location": {// 中心点坐标"origin": "51.5074, -0.1278", // 伦敦市中心经纬度// 高斯衰减的标准化差(sigma),影响衰减速度"scale": "10km", // 单位可以是千米、米等// 斜率因子(offset),影响衰减起点"offset": "0km",// 缩放因子(decay),影响衰减陡峭程度"decay": 0.5}}}]}}
}
  • location字段(假定为地理位置类型)与指定中心点的距离来计算衰减得分
  • scale参数决定了衰减的速度,即距离中心点多少单位后得分下降一半
  • offset参数可以让衰减在距离中心点一定距离后才开始
  • decay参数是对衰减曲线的进一步调整,控制衰减的陡峭程度

标题

gauss的案例

场景

假设我们有一个商店索引,其中包含地理位置信息,并且我们希望根据顾客位置对其附近的商店进行优先排序

索引创建

PUT /shops
{"mappings": {"properties": {"name": {"type": "text"},"location": {"type": "geo_point"}}}
}

文档插入

POST /shops/_doc
{"name": "Shop A","location": "51.5074,-0.1278" // 伦敦大本钟坐标
}POST /shops/_doc
{"name": "Shop B","location": "48.8566,2.3522" // 巴黎埃菲尔铁塔坐标
}POST /shops/_doc
{"name": "Shop C","location": "40.7128,-74.0060" // 纽约时代广场坐标
}POST /shops/_doc
{"name": "Shop D","location": "37.7749,-122.4194" // 旧金山金门大桥坐标
}POST /shops/_doc
{"name": "Shop E","location": "-33.8521,151.2111" // 悉尼歌剧院坐标
}POST /shops/_doc
{"name": "Shop F","location": "55.7507,37.6173" // 莫斯科红场坐标
}POST /shops/_doc
{"name": "Shop G","location": "35.6895,139.6917" // 东京晴空塔坐标
}POST /shops/_doc
{"name": "Shop H","location": "-23.5505,-46.6333" // 圣保罗独立公园坐标
}

查询语句

GET /shops/_search
{"query": {"function_score": {"query": { "match_all": {} // 这里仅作示例,实际应用中应替换为更具针对性的查询条件},"functions": [{"gauss": {"location": {"origin": "51.5074,-0.1278", // 用户所在位置坐标"scale": "10km", // 衰减半径为10公里"offset": "0km", // 衰减起始位置为零"decay": 0.5 // 衰减指数}}}],"score_mode": "multiply", // 各项得分的组合方式"boost_mode": "replace" // 得分替换还是累加}}
}

相关文章:

  • [scikit-learn] 第一章 初识scikit-learn及内置数据集介绍
  • 【四 (4)数据可视化之 Ploty Express常用图表及代码实现 】
  • Linux 自动备份 mysql 脚本
  • Windows10安装RubyRails步骤
  • Apache zookeeper kafka 开启SASL安全认证
  • vite打包时发布时,放在服务器的二级目录中
  • 解析编程中不可或缺的基础:深入了解结构体类型
  • 【Linux-网络编程】
  • 【漏洞复现】大华智慧园区综合管理平台SQL注入漏洞
  • 【vue baidu-map】实现百度地图展示基地,鼠标悬浮标注点展示详细信息
  • 配置vscode环境极简版(C/C++)(图文)
  • 在idea中配置tomcat服务器,部署一个项目(下载教程加链接)
  • KONG - API转发流程梳理
  • 深入探索Java并发编程:ArrayBlockingQueue详解
  • Python最常用的库
  • 【编码】-360实习笔试编程题(二)-2016.03.29
  • C++11: atomic 头文件
  • C++入门教程(10):for 语句
  • js中forEach回调同异步问题
  • python学习笔记 - ThreadLocal
  • React 快速上手 - 06 容器组件、展示组件、操作组件
  • RxJS: 简单入门
  • win10下安装mysql5.7
  • 编写高质量JavaScript代码之并发
  • 从零开始的无人驾驶 1
  • 关于Java中分层中遇到的一些问题
  • 来,膜拜下android roadmap,强大的执行力
  • 老板让我十分钟上手nx-admin
  • 力扣(LeetCode)21
  • 视频flv转mp4最快的几种方法(就是不用格式工厂)
  • 手机app有了短信验证码还有没必要有图片验证码?
  • 数据库写操作弃用“SELECT ... FOR UPDATE”解决方案
  • 腾讯优测优分享 | 你是否体验过Android手机插入耳机后仍外放的尴尬?
  • 学习笔记:对象,原型和继承(1)
  • 在Mac OS X上安装 Ruby运行环境
  • ​3ds Max插件CG MAGIC图形板块为您提升线条效率!
  • #includecmath
  • #LLM入门|Prompt#1.7_文本拓展_Expanding
  • (3)选择元素——(14)接触DOM元素(Accessing DOM elements)
  • (Python第六天)文件处理
  • (二)斐波那契Fabonacci函数
  • (分布式缓存)Redis哨兵
  • (附源码)流浪动物保护平台的设计与实现 毕业设计 161154
  • (三)docker:Dockerfile构建容器运行jar包
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (十)c52学习之旅-定时器实验
  • (转)C语言家族扩展收藏 (转)C语言家族扩展
  • (转)ObjectiveC 深浅拷贝学习
  • .Net 8.0 新的变化
  • .Net6 Api Swagger配置
  • :中兴通讯为何成功
  • [ C++ ] template 模板进阶 (特化,分离编译)
  • [04] Android逐帧动画(一)
  • [Arduino学习] ESP8266读取DHT11数字温湿度传感器数据
  • [BZOJ2281][SDOI2011]黑白棋(K-Nim博弈)