深度学习系列85:sqlite-ai系列

1. 介绍

目前用到三个插件:

sqlite-ai:使用sql来操作llm

sqlite-vec:类似faiss的向量检索插件

sqlite-rag:基于sqlite的混合rag插件

2. sqlite-ai

使用pip进行安装,下面是使用示例:

复制代码
import importlib.resources
import sqlite3
conn = sqlite3.connect("example.db")
ext_path = importlib.resources.files("sqliteai.binaries.cpu") / "ai"
conn.enable_load_extension(True)
conn.load_extension(str(ext_path))
conn.enable_load_extension(False)
conn.execute("SELECT llm_model_load('../MiniCPM4-0.5B-bf16.gguf', 'n_predict=4096,n_gpu_layers=99');")
conn.execute("SELECT llm_context_create('n_ctx=512,n_threads=6,n_batch=128');")
conn.execute("SELECT llm_chat_respond('你是谁?replay within 10 words');").fetchone()[0]

3. sqlite-vec

使用pip进行安装,下面是使用示例:

复制代码
import sqlite3
import sqlite_vec
import sqlite_lembed
from typing import List
db = sqlite3.connect(":memory:")
db.enable_load_extension(True)
sqlite_vec.load(db)
sqlite_lembed.load(db)
db.enable_load_extension(False)
db.executef"""INSERT INTO temp.lembed_models(name, model) select 'default', lembed_model_from_file('m3e-base.f16.gguf')""")
db.execute("""create table articles (headline text);""")
db.execute("""create virtual table vec_articles using vec0(headline_embeddings float[768]);""")
db.execute(f"""insert into articles VALUES ('{text[:500]}');""")
db.execute("""insert into vec_articles(rowid, headline_embeddings) select rowid, lembed(headline) from articles;""")
db.execute(f"""with matches as (SELECT rowid,distance FROM vec_articles WHERE headline_embeddings MATCH lembed('天气') and k = 2 ORDER BY distance)
select headline,100/(1+distance) from matches left join articles on articles.rowid = matches.rowid;""").fetchall()
相关推荐
henujolly17 分钟前
RAG Vs fine-tuning
人工智能
kaka.liulin -study20 分钟前
EmberTrace AI | Multimodel Map GIS: 基于多智能体协作的地图自主化分析技术
人工智能·microsoft
soldierluo21 分钟前
向量与向量数据
人工智能·算法·机器学习
人工智能技术咨询.23 分钟前
AI智能体搭建(3)
人工智能
居然JuRan28 分钟前
面字节豆包大模型岗,三轮技术面都问了啥?
人工智能
CHrisFC38 分钟前
江苏硕晟LIMS:坚守合规底线,构建生态监测信息管理合规体系
大数据·人工智能
Hcoco_me1 小时前
大模型面试题71: DPO有什么缺点?后续对DPO算法有哪些改进?
人工智能·深度学习·算法·自然语言处理·transformer·vllm
Mrs.Gril1 小时前
目标检测: rtdetr在RK3588上部署
人工智能·目标检测·计算机视觉
向上的车轮1 小时前
AI 进化论:智算时代操作系统——从算力适配到智能涌现
人工智能
路人与大师1 小时前
Genesis V5 技术深度解析:迈向自创生智能体内核
人工智能