Project Icon

prem-1B-SQL

本地Text-to-SQL模型保护数据不受第三方干扰

Prem-1B-SQL是由Prem AI研发的本地化Text-to-SQL模型。拥有10亿参数,适合低GPU和量化后的CPU设备,强调数据本地储存以防数据外泄。模型在BirdBench和Spider基准数据集上的准确率分别为51.54%和85%。通过PremSQL开源库,用户可定制数据集、强化执行和评估,支持错误处理和自动修正,实现数据分析流程一体化。Prem-1B-SQL具备出色的集成和微调能力,适用于多种数据分析场景,保障查询转换的安全、准确和高效。

Prem-1B-SQL项目介绍

Prem-1B-SQL是由Prem AI开发的一款先进的本地化文本到SQL模型。它在数据安全方面秉持“本地优先”的理念,避免了将数据库暴露给第三方封闭源模型的潜在风险。这款模型拥有10亿个参数,适合在低GPU甚至CPU设备上运行,并支持量化处理。未来,官方计划持续优化其表现,这一切使得Prem-1B-SQL在数据分析领域展现出强大的应用潜力。

项目背景

Prem AI坚信,AI辅助的数据分析应当以本地化为核心,因为将数据库暴露给第三方封闭源模型可能导致数据安全问题。基于此理念,他们推出了Prem-1B-SQL,一款适合在本地设备上高效运行的文本到SQL模型。

项目成果

Prem-1B-SQL在两个常用的数据集上进行了评估:BirdBench和Spider。具体结果如下:

数据集执行准确率
BirdBench(验证集)46%
BirdBench(测试集)51.54%
Spider85%

其中,BirdBench数据集根据难度分为三个等级,私密测试结果如下:

难度等级测试数执行准确率软F1分数
简单94960.70%61.48%
适中55547.39%49.06%
挑战28529.12%31.83%
总计178951.54%52.90%

此外,通过与其他流行的模型进行对比,可以看出Prem-1B-SQL在保持紧凑的参数量的同时,能达到相当不错的测试分数:

模型参数量(亿)BirdBench 测试分数
AskData + GPT-4o(当前冠军)NA72.39
DeepSeek coder 236B23656.68
GPT-4(2023)NA54.89
PremSQL 1B(我们的)151.4
Qwen 2.5 7B Instruct751.1
Claude 2 Base(2023)NA49.02

如何使用Prem-1B-SQL

Prem-1B-SQL构建在transformers库上,因此可以直接与transformers库结合使用。也正因为如此,它与数据库中输入提示的形成紧密关联。为了简化使用,Prem AI开发了PremSQL库,这是一款完全开源的软件库,它具有以下特性:

  • 本地优先:避免使用第三方封闭来源提供商,确保数据安全。
  • 可定制数据集:能够创建、微调和评估内置或自定义的数据集。
  • 坚固的执行器和评估器:轻松连接数据库并评估模型性能。
  • 高级生成器:将自然语言提示转换为可执行的SQL查询。
  • 错误处理和自我纠正:在推理过程中自动纠正SQL查询。
  • 微调支持:支持通过LoRA、QLoRA或全微调策略进行模型微调。
  • 端到端管道:无缝集成所有组件,实现自主数据分析。

Prem-1B-SQL可以通过PremSQL管道或生成器进行部署。以下是一些使用示例:

通过PremSQL管道运行Prem-1B-SQL

最简单的方式就是通过PremSQL管道,只需提供数据库路径或连接URI即可。以下是示例代码:

from premsql.pipelines import SimpleText2SQLAgent
from premsql.generators import Text2SQLGeneratorHF
from premsql.executors import SQLiteExecutor

dsn_or_db_path = "./data/db/california_schools.sqlite"

agent = SimpleText2SQLAgent(
    dsn_or_db_path=dsn_or_db_path,
    generator=Text2SQLGeneratorHF(
        model_or_name_or_path="premai-io/prem-1B-SQL",
        experiment_name="simple_pipeline",
        device="cuda:0",
        type="test"
    ),
)

question = "please list the phone numbers of the direct charter-funded schools that are opened after 2000/1/1"

response = agent.query(question)
response["table"]

通过PremSQL生成器运行Prem-1B-SQL

当需要在某个数据集上进行批量生成时,可以使用PremSQL生成器:

from premsql.generators import Text2SQLGeneratorHF
from premsql.datasets import Text2SQLDataset

dataset = bird_dataset = Text2SQLDataset(
    dataset_name='bird', split="validation", force_download=False,
    dataset_folder="/path/to/dataset"
).setup_dataset(num_rows=10, num_fewshot=3)

generator = Text2SQLGeneratorHF(
    model_or_name_or_path="premai-io/prem-1B-SQL",
    experiment_name="test_generators",
    device="cuda:0",
    type="test"
)

responses = generator.generate_and_save_results(
    dataset=bird_dataset,
    temperature=0.1,
    max_new_tokens=256
)

print(responses)

使用执行引导解码

该策略在生成的SQL失败时使用错误信息进行修正,直到获得有效结果或重试次数用完为止。

from premsql.executors import SQLiteExecutor

executor = SQLiteExecutor()
response = generator.generate_and_save_results(
    dataset=bird_dataset,
    temperature=0.1,
    max_new_tokens=256,
    force=True,
    executor=executor,
    max_retries=5 
)

模型训练使用的数据集

Prem-1B-SQL的训练使用了以下数据集:

  1. BirdBench训练数据集:可在此处找到。
  2. Spider数据集:可在此处找到。
  3. 域专属数据集:由PremAI收集并上传。
  4. Gretel AI合成数据集:可在此处找到。

此外,开发团队通过结合上述数据集创建了错误处理数据集,将模型的学习扩展到自我纠正能力上。

未来,Prem AI计划在公共基准上发布更多的评估结果,以展示Prem-1B-SQL的能力。有关更多的详细信息,请参阅文档

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号