Project Icon

gemma_pytorch

Gemma模型的官方PyTorch实现及多平台推理支持

gemma_pytorch项目是Gemma模型的官方PyTorch实现,支持CPU、GPU和TPU多平台推理。项目提供PyTorch和PyTorch/XLA两种实现,涵盖2B、7B、9B和27B等多个模型变体及量化版本。通过Docker可快速部署环境并进行推理。项目还包含最新的Gemma v2和CodeGemma模型支持,为用户提供全面的Gemma模型应用方案。

PyTorch 中的 Gemma

Gemma 是一系列轻量级、最先进的开放模型,它们基于用于创建 Google Gemini 模型的研究和技术。这些模型是文本到文本的、仅解码器的大型语言模型,提供英语版本,包括开放权重、预训练变体和指令微调变体。欲了解更多详情,请查看以下链接:

这是 Gemma 模型的官方 PyTorch 实现。我们提供了使用 PyTorch 和 PyTorch/XLA 的模型和推理实现,并支持在 CPU、GPU 和 TPU 上运行推理。

更新

  • [6月26日 🔥] 支持 Gemma v2。您可以在 Kaggle 和 Hugging Face 上找到检查点

  • [4月9日] 支持 CodeGemma。您可以在 KaggleHugging Face 上找到检查点

  • [4月5日] 支持 Gemma v1.1。您可以在 KaggleHugging Face 上找到 v1.1 检查点。

下载 Gemma 模型检查点

您可以在 Kaggle 这里 找到模型检查点。

或者,您可以在 Hugging Face Hub 这里 找到模型检查点。要下载模型,请进入感兴趣的模型仓库,点击"Files and versions"标签,然后下载模型和分词器文件。对于程序化下载,如果您已安装 huggingface_hub,也可以运行:

huggingface-cli download google/gemma-7b-it-pytorch

请注意,您可以选择 2B、2B V2、7B、7B int8 量化、9B 和 27B 变体。

VARIANT=<2b 或 7b 或 9b 或 27b>
CKPT_PATH=<在此插入检查点路径>

在 Colab 上免费尝试

请按照 https://ai.google.dev/gemma/docs/pytorch_gemma 的步骤操作。

使用 PyTorch 尝试

前提条件:确保您已正确设置非root用户的docker权限。

sudo usermod -aG docker $USER
newgrp docker

构建 docker 镜像

DOCKER_URI=gemma:${USER}

docker build -f docker/Dockerfile ./ -t ${DOCKER_URI}

在 CPU 上运行 Gemma 推理

PROMPT="生命的意义是"

docker run -t --rm \
    -v ${CKPT_PATH}:/tmp/ckpt \
    ${DOCKER_URI} \
    python scripts/run.py \
    --ckpt=/tmp/ckpt \
    --variant="${VARIANT}" \
    --prompt="${PROMPT}"
    # 对于 int8 量化模型,添加 `--quant`

在 GPU 上运行 Gemma 推理

PROMPT="生命的意义是"

docker run -t --rm \
    --gpus all \
    -v ${CKPT_PATH}:/tmp/ckpt \
    ${DOCKER_URI} \
    python scripts/run.py \
    --device=cuda \
    --ckpt=/tmp/ckpt \
    --variant="${VARIANT}" \
    --prompt="${PROMPT}"
    # 对于 int8 量化模型,添加 `--quant`

使用 PyTorch/XLA 尝试

构建 docker 镜像(CPU、TPU)

DOCKER_URI=gemma_xla:${USER}

docker build -f docker/xla.Dockerfile ./ -t ${DOCKER_URI}

构建 docker 镜像(GPU)

DOCKER_URI=gemma_xla_gpu:${USER}

docker build -f docker/xla_gpu.Dockerfile ./ -t ${DOCKER_URI}

在 CPU 上运行 Gemma 推理

docker run -t --rm \
    --shm-size 4gb \
    -e PJRT_DEVICE=CPU \
    -v ${CKPT_PATH}:/tmp/ckpt \
    ${DOCKER_URI} \
    python scripts/run_xla.py \
    --ckpt=/tmp/ckpt \
    --variant="${VARIANT}" \
    # 对于 int8 量化模型,添加 `--quant`

在 TPU 上运行 Gemma 推理

注意:请确保使用从 xla.Dockerfile 构建的 docker 容器。

docker run -t --rm \
    --shm-size 4gb \
    -e PJRT_DEVICE=TPU \
    -v ${CKPT_PATH}:/tmp/ckpt \
    ${DOCKER_URI} \
    python scripts/run_xla.py \
    --ckpt=/tmp/ckpt \
    --variant="${VARIANT}" \
    # 对于 int8 量化模型,添加 `--quant`

在 GPU 上运行 Gemma 推理

注意:请确保使用从 xla_gpu.Dockerfile 构建的 docker 容器。

docker run -t --rm --privileged \
    --shm-size=16g --net=host --gpus all \
    -e USE_CUDA=1 \
    -e PJRT_DEVICE=CUDA \
    -v ${CKPT_PATH}:/tmp/ckpt \
    ${DOCKER_URI} \
    python scripts/run_xla.py \
    --ckpt=/tmp/ckpt \
    --variant="${VARIANT}" \
    # 对于 int8 量化模型,添加 `--quant`

分词器注意事项

预训练的分词器模型中保留了99个未使用的标记,以协助更高效的训练/微调。未使用的标记格式为 <unused[0-98]>,标记 ID 范围为 [7-105]

"<unused0>": 7,
"<unused1>": 8,
"<unused2>": 9,
...
"<unused98>": 105,

免责声明

这不是 Google 官方支持的产品。

项目侧边栏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

AIWritePaper论文写作

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

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