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

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

Project Cover

Kimi

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

Project Cover

阿里绘蛙

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

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

稿定AI

稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。

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