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

手把手教你用Pinecone和Hugging Face数据集,5步搞定一个多模态混合搜索Demo

5步实战基于Pinecone与Hugging Face打造时尚商品多模态搜索系统当你在电商平台搜索复古风蓝色牛仔裤时是否遇到过返回结果与预期不符的情况传统关键词搜索的局限性正在被新一代多模态混合搜索技术打破。本文将带你用Pinecone向量数据库和Hugging Face数据集构建一个能同时理解图像与文本的智能搜索系统。1. 环境准备与工具链搭建工欲善其事必先利其器。我们需要配置以下关键组件Pinecone账户注册获取API密钥这是连接向量数据库的通行证Python 3.8环境推荐使用conda创建独立环境关键库安装pip install pinecone-client datasets sentence-transformers pinecone-text验证安装是否成功import pinecone from sentence_transformers import SentenceTransformer print(所有依赖库已就绪)注意建议使用CUDA支持的GPU环境加速向量计算特别是处理大规模数据集时2. 数据集加载与预处理我们选用Hugging Face上的ashraq/fashion-product-images-small数据集包含44,072条时尚商品记录每项都有图像和结构化元数据。加载数据集并查看样本结构from datasets import load_dataset fashion_data load_dataset(ashraq/fashion-product-images-small, splittrain) print(f数据集包含{fashion_data.num_rows}条记录) print(f特征字段{fashion_data.features})典型的数据预处理步骤包括提取图像像素数据合并文本元数据字段处理缺失值标准化分类标签示例预处理代码# 分离图像和元数据 images fashion_data[image] metadata fashion_data.remove_columns(image) # 合并文本字段 metadata metadata.map(lambda x: { combined_text: f{x[productDisplayName]} {x[baseColour]} {x[articleType]} })3. 双引擎向量生成混合搜索的核心是同时使用两种向量表示方法稀疏向量BM25适用于精确关键词匹配传统搜索引擎的基石from pinecone_text.sparse import BM25Encoder bm25 BM25Encoder() bm25.fit(metadata[combined_text]) # 生成稀疏向量示例 sparse_vec bm25.encode_documents(男士蓝色牛仔裤)稠密向量CLIP模型捕捉语义信息理解时尚休闲等抽象概念model SentenceTransformer(sentence-transformers/clip-ViT-B-32, devicecuda) # 同时处理文本和图像 text_embedding model.encode(女士红色连衣裙) image_embedding model.encode(images[0])两种向量对比向量类型优势局限性适用场景稀疏向量关键词匹配精准无法处理同义词明确的产品名称搜索稠密向量理解语义关系需要大量计算风格、抽象概念搜索4. Pinecone索引构建与数据上传配置Pinecone索引是关键步骤需要特别注意维度匹配import pinecone pinecone.init(api_keyYOUR_API_KEY, environmentus-west1-gcp) index_name fashion-hybrid-search if index_name in pinecone.list_indexes(): pinecone.delete_index(index_name) # 创建支持混合搜索的索引 pinecone.create_index( nameindex_name, dimension512, # 必须与CLIP模型输出维度一致 metriccosine, specpinecone.ServerlessSpec(cloudaws, regionus-west-2) )批量上传数据的优化策略from tqdm.auto import tqdm batch_size 100 index pinecone.Index(index_name) for i in tqdm(range(0, len(metadata), batch_size)): # 获取批次数据 batch_meta metadata[i:ibatch_size] batch_images images[i:ibatch_size] # 生成向量 sparse_embeds bm25.encode_documents(batch_meta[combined_text]) dense_embeds model.encode(batch_images).tolist() # 构建上传结构 records [] for idx, (sparse, dense, meta) in enumerate(zip(sparse_embeds, dense_embeds, batch_meta)): records.append({ id: str(iidx), values: dense, sparse_values: sparse, metadata: meta }) # 上传数据 index.upsert(records)提示实际应用中建议添加错误处理和重试机制特别是处理大规模数据集时5. 混合搜索实现与参数调优真正的混合搜索不仅仅是简单拼接结果而是动态平衡两种搜索方式基础查询实现def hybrid_search(query, imageNone, top_k10, alpha0.5): # 文本处理 sparse bm25.encode_queries(query) dense model.encode(query).tolist() # 图像处理 if image is not None: img_vec model.encode(image).tolist() dense [sum(x)/2 for x in zip(dense, img_vec)] # 调整权重 hdense [v * alpha for v in dense] hsparse { indices: sparse[indices], values: [v * (1-alpha) for v in sparse[values]] } # 执行查询 return index.query( top_ktop_k, vectorhdense, sparse_vectorhsparse, include_metadataTrue )参数调优实验alpha值搜索类型查询示例适用场景0.9密集优先适合海滩度假的服装抽象概念查询0.1稀疏优先Levis 501 蓝色牛仔裤精确产品搜索0.5均衡混合商务休闲男士衬衫综合需求查询可视化结果展示import matplotlib.pyplot as plt def display_results(results): fig, axes plt.subplots(1, len(results[matches]), figsize(20,5)) for ax, match in zip(axes, results[matches]): img images[int(match[id])] ax.imshow(img) ax.set_title(f{match[metadata][productDisplayName]}\nScore: {match[score]:.2f}) ax.axis(off) plt.show() results hybrid_search(夏季女士连衣裙, alpha0.7) display_results(results)在实际项目中我发现alpha参数的最佳值通常在0.3-0.7之间具体取决于查询的抽象程度。对于包含明确产品型号的搜索降低alpha值能获得更精准的结果而对于风格、场景等抽象查询提高alpha值效果更好。

相关文章:

手把手教你用Pinecone和Hugging Face数据集,5步搞定一个多模态混合搜索Demo

5步实战:基于Pinecone与Hugging Face打造时尚商品多模态搜索系统 当你在电商平台搜索"复古风蓝色牛仔裤"时,是否遇到过返回结果与预期不符的情况?传统关键词搜索的局限性正在被新一代多模态混合搜索技术打破。本文将带你用Pinecone…...

R 4.5情感分析项目交付倒计时:客户验收必查的6类偏见指标+3份可签字审计报告模板

更多请点击: https://intelliparadigm.com 第一章:R 4.5情感分析项目交付倒计时总览 距离 R 4.5 情感分析项目正式交付仅剩 14 天,当前整体进度达 82%,核心模型训练与评估已闭环,正进入最终集成测试与文档固化阶段。本…...

为什么 2026 年被称为 AI Agent Harness Engineering 元年

为什么全行业都在说2026年是AI Agent Harness Engineering元年?从概念、痛点到落地的完整解析 引言 如果你关注AI领域的最新动态,大概率在2025年底已经听到过无数次「2026年是AI Agent Harness Engineering元年」的判断。从OpenAI的年度开发者大会到国内大厂的AI战略发布会…...

OpenAI隐私过滤器

多年来,这个笑话一直在自我书写。OpenAI。 这家公司的名字里包含"Open",就像"超大虾"里包含"超大"一样。好吧,看来压力足够让OpenAI开始认真出货了。 2026年4月22日,OpenAI在Apache 2.0下发布了一…...

从128ms到9.3ms响应,从$427/月到$158/月——PHP 9.0异步AI网关真实成本拆解(含AWS Lambda冷启动规避方案)

更多请点击: https://intelliparadigm.com 第一章:PHP 9.0异步AI网关演进全景图 PHP 9.0 正式将协程原生化、事件驱动内核与 AI 接口抽象层深度集成,标志着 PHP 从传统 Web 脚本语言跃迁为高并发 AI 服务编排中枢。其核心突破在于引入 async…...

ARM SVE2向量存储指令ST1Q与ST1W详解

1. ARM SVE2向量存储指令概述在现代处理器架构中,SIMD(单指令多数据)技术是提升计算性能的关键手段。作为ARMv9架构的重要组成部分,SVE2(Scalable Vector Extension 2)引入了更强大的向量处理能力&#xff…...

观察不同时段通过Taotoken调用大模型的延迟波动情况

观察不同时段通过Taotoken调用大模型的延迟波动情况 1. 测试环境与数据收集方法 我们基于实际业务场景,对Taotoken平台进行了为期两周的持续监测。测试环境采用Python编写的自动化脚本,每小时向平台发送固定内容的请求,记录每次调用的响应时…...

手持式雷达测速仪 车辆测速仪

手持式雷达测速仪核心依托多普勒效应工作,测速精准、稳定性强。设备主动向车辆、厂区移动设备等目标物体发射无线电波,当电波接触到移动目标后,部分电波能量会回弹至设备天线。设备通过精准捕捉返回信号的频率差异,智能运算测算出…...

体验 Taotoken 多模型聚合路由带来的高可用与低延迟

体验 Taotoken 多模型聚合路由的稳定性与响应表现 1. 多模型聚合路由的核心价值 在实际业务开发中,大模型 API 的稳定性与响应速度直接影响开发效率和用户体验。Taotoken 通过聚合多家模型供应商的 API 资源,为开发者提供了统一的接入点。这种设计使得…...

适合 Reddit 多账号运营的指纹浏览器推荐哪款?

做Reddit多账号运营已经一年多,为了找到适配的指纹浏览器,我前前后后试了四五款,踩过不少环境不稳定、IP质量差的坑,最后筛选下来,只有RoxyBrowser一直用到现在,亲测适配Reddit多账号、矩阵运营&#xff0c…...

从零实现一个轻量级 RPC 框架:通信协议与动态代理的核心原理

🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可须臾或…...

【LeetCode刷题日记】347.前k个高频元素

🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可须臾或…...

【R 4.5物联网时序数据处理终极指南】:零基础到生产级TSDB集成,覆盖xts、zoo、timetk与arrow新引擎实战

更多请点击: https://intelliparadigm.com 第一章:R 4.5物联网时序数据处理全景概览 R 4.5 版本在时间序列生态中引入了原生时序向量(tsibble v1.1 兼容性增强)、并行化 dplyr 管道支持,以及对纳秒级时间戳&#xff0…...

【LLM实时交互性能瓶颈终结者】:用Swoole协程+自定义协议替代HTTP轮询,QPS提升23.6倍实测报告

更多请点击: https://intelliparadigm.com 第一章:LLM实时交互性能瓶颈终结者:Swoole协程自定义协议方案全景概览 在大语言模型(LLM)高频、低延迟的实时对话场景中,传统 HTTP/1.1 同步阻塞模型常因连接复用…...

R语言+PHM工业实践:3天快速复现NASA涡轮引擎剩余寿命预测(附可运行GitHub仓库)

更多请点击: https://intelliparadigm.com 第一章:R语言PHM工业实践:3天快速复现NASA涡轮引擎剩余寿命预测(附可运行GitHub仓库) 本章基于NASA公开的C-MAPSS数据集,使用R语言构建端到端的预测性健康管理&…...

三格电子 SG-ECAT-HUB_4|EtherCAT 工业组网神器,一进三出重构自动化拓扑

在智能制造、机器人、产线自动化等高实时性场景中,传统 EtherCAT 线型(菊花链)组网常面临布线受限、单点故障断全线、扩展困难、同步精度不足等痛点。三格电子推出SG-ECAT-HUB_4 4 口 EtherCAT 分支器,以一进三出、多拓扑支持、DC…...

3步解锁微信数据主权:WeChatMsg技术架构与实战指南

3步解锁微信数据主权:WeChatMsg技术架构与实战指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeChatMs…...

告别闪烁!用STM32的PWM+DMA驱动WS2812灯带,实现丝滑渐变效果(附完整代码)

STM32高级灯光控制:PWMDMA驱动WS2812实现影院级渐变效果 当你在深夜的工作室里调试灯光项目时,是否曾被WS2812灯带的闪烁问题困扰?那种本应流畅的彩虹渐变效果,却因为驱动方式不当而变得卡顿生硬,就像老式幻灯机切换画…...

告别电位器!用STM32和MCP4017打造一个可编程的智能分压电路(教程+源码)

基于STM32与MCP4017的智能分压电路设计与实战解析 在传统电子设计中,机械电位器因其结构简单、成本低廉而被广泛使用。然而,随着智能化需求的提升,机械电位器暴露出调节精度低、易磨损、无法远程控制等固有缺陷。本文将介绍如何利用数字可编程…...

FITC标记的Siglec-2/CD22 Fc嵌合蛋白在B细胞免疫治疗研究中的应用

一、CD22蛋白的结构特征与细胞分布CD22又被称为Siglec-2,是唾液酸结合的免疫球蛋白样凝集素家族的重要成员,属于I型跨膜蛋白,分子量为140kDa。人类CD22基因位于19号染色体长臂,编码的蛋白胞外域包含七个Ig结构域,最远端…...

大语言模型偏见检测失效的真相(R语言stats+tidyverse实战避坑手册)

更多请点击: https://intelliparadigm.com 第一章:大语言模型偏见检测失效的统计学根源 当我们在评估LLM输出中的性别、种族或地域偏见时,常依赖基于词频统计的指标(如WEAT、SEAT)或分类器驱动的偏差分数。然而&#…...

Android Studio中文语言包终极指南:3分钟实现开发效率翻倍的完整教程

Android Studio中文语言包终极指南:3分钟实现开发效率翻倍的完整教程 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack …...

电磁铁的磁性可以无限增强吗

电磁铁的磁性无法无限增强,这主要源于材料的磁饱和特性。当磁场强度达到临界值后,即便继续增大电流或增加线圈匝数,磁性也难以持续提升。铁芯材料内部存在大量微小磁畴,在外加磁场作用下,这些磁畴会逐渐转向与磁场一致…...

Keep开源AIOps平台:面向现代分布式系统的智能告警管理与自动化解决方案

Keep开源AIOps平台:面向现代分布式系统的智能告警管理与自动化解决方案 【免费下载链接】keep The open-source AIOps and alert management platform 项目地址: https://gitcode.com/GitHub_Trending/kee/keep 在当今云原生和微服务架构主导的技术环境中&am…...

如何快速掌握Tesseract OCR:5个简单步骤开启文字识别之旅

如何快速掌握Tesseract OCR:5个简单步骤开启文字识别之旅 【免费下载链接】tesseract Tesseract Open Source OCR Engine (main repository) 项目地址: https://gitcode.com/gh_mirrors/tes/tesseract Tesseract OCR是一个功能强大的开源光学字符识别引擎&am…...

【Dify金融问答合规审计白皮书】:基于27家持牌机构实测数据,揭示97.3%高风险问答触发点及实时拦截方案

更多请点击: https://intelliparadigm.com 第一章:Dify金融问答合规审计白皮书导言 在金融行业加速拥抱大模型应用的背景下,Dify 作为低代码 AI 应用开发平台,正被广泛用于构建智能投顾、监管问答、风险提示等高敏感度场景。然而…...

# 我用AI编程两年,差点被“驯化”:一个前端开发的反思

从依赖AI到被限流惊醒,再到重新找回自己的“决策权”和“创造力”。这篇文章记录了一个前端开发者在AI浪潮中的真实心路历程,希望能给你一些启发。 前言 作为一名前端开发,我从2024年初开始使用AI工具辅助编程。当时买的是Copilot&#xff0…...

戴尔与惠普笔记本电脑大比拼:谁在性能、价格、便携性上更胜一筹?

戴尔与惠普:如何选择适合你的笔记本电脑过去几年里,戴尔(Dell)和惠普(HP)推出了不少令人心仪的 Windows 笔记本电脑。每当有人咨询 PC 推荐时,这两个品牌总会首先被想起,因为它们都有…...

你的BLDC仿真电流波形为啥是锯齿?手把手调Simscape双闭环PI参数(附调试记录)

BLDC仿真电流波形锯齿问题全解析:从PI调参到波形优化实战指南 当你在Simscape中完成BLDC电机双闭环模型搭建,满心期待看到平滑的电流波形时,屏幕上却出现了令人不安的锯齿状波形——这种经历可能让任何工程师感到沮丧。但别担心,锯…...

2026 年手机市场供应受限价格上涨,旧款机型性价比更高成优选

2026 年新手机的困境智能手机市场因内存芯片供应受限而面临压力。2026 年推出的手机表现平平,且许多都提了价。2025 年的顶级手机如今正在打折,相比新设备,它们是更划算的选择。根据 IDC 12 月的报告,PC、智能手机和其他消费电子产…...