Project Icon

zett

突破语言模型与分词器的兼容性限制

ZeTT是一个创新的开源项目,旨在解决语言模型与分词器之间的兼容性问题。该项目通过零样本分词器迁移技术,使任何语言模型能够与任意分词器协同工作,几乎不需要额外训练。ZeTT提供多个预训练超网络,支持26种语言和代码处理。用户可以轻松将现有模型适配新的分词器,提升模型的通用性。此外,ZeTT还支持训练自定义超网络和迁移微调模型等高级功能,为自然语言处理研究提供新的可能性。

零样本分词器迁移

本仓库包含论文《零样本分词器迁移》的代码。ZeTT使语言模型摆脱了对特定分词器的依赖,让您可以将任何模型与任何分词器搭配使用,只需很少或无需额外训练⚡

可用的预训练超网络

使用预训练超网络

环境设置

所需依赖在 requirements.txt 中,例如,可以通过以下方式创建一个可用的环境:

conda create -n zett Python=3.11
conda activate zett

pip install -r requirements.txt
pip install -U "jax[cuda12_pip]==0.4.23" -f https://storage.googleapis.com/jax-releases/jax_cuda_releases.html # 根据您的CUDA版本调整
pip install -e .

迁移到新的分词器

让我们将XLM-RoBERTa迁移到GPT2分词器。
git clone https://huggingface.co/benjamin/zett-hypernetwork-xlm-roberta-base

python3 scripts/transfer.py \
    --target_model=FacebookAI/xlm-roberta-base \
    --tokenizer_name=gpt2 \
    --output=my-new-fancy-xlm-r \
    --model_class=AutoModelForMaskedLM \
    --lang_code=en \
    --checkpoint_path=zett-hypernetwork-xlm-roberta-base \
    --save_pt # 否则只保存Flax权重

大功告成!

from transformers import AutoModelForMaskedLM, AutoTokenizer

tokenizer = AutoTokenizer.from_pretrained("my-new-fancy-xlm-r")
model = AutoModelForMaskedLM.from_pretrained("my-new-fancy-xlm-r")

out = model(**tokenizer("Hello world!", return_tensors="pt"))
..或者将Mistral-7B迁移到GPT-NeoX分词器: ```bash git clone https://huggingface.co/benjamin/zett-hypernetwork-Mistral-7B-v0.1

由于Flax权重未合并到主分支,我们需要指定包含Flax权重的PR版本

python3 scripts/transfer.py
--target_model=mistralai/Mistral-7B-v0.1
--revision=refs/pr/95
--tokenizer_name=EleutherAI/gpt-neox-20b
--output=my-new-fancy-mistral
--model_class=AutoModelForCausalLM
--checkpoint_path=zett-hypernetwork-Mistral-7B-v0.1
--save_pt # 否则只保存Flax权重


```python
from transformers import AutoModelForCausalLM, AutoTokenizer

tokenizer = AutoTokenizer.from_pretrained("my-new-fancy-mistral")
model = AutoModelForCausalLM.from_pretrained("my-new-fancy-mistral")

out = model(**tokenizer("Hello world!", return_tensors="pt"))

虽然代码库是用Jax/Flax编写的,但在./hf_hypernet中有模型的Pytorch绑定。您可以按以下方式使用它们:

from transformers import AutoModel, AutoModelForCausalLM, AutoTokenizer
from zett.utils import get_surface_form_matrix

base_model = AutoModelForCausalLM.from_pretrained("mistralai/Mistral-7B-v0.1")
hypernet = AutoModel.from_pretrained("benjamin/zett-hypernetwork-Mistral-7B-v0.1", trust_remote_code=True)

source_embeddings = torch.concatenate([
    base_model.get_input_embeddings().weight.data,
    base_model.get_output_embeddings().weight.data,
], axis=1)

hn_tokenizer = AutoTokenizer.from_pretrained("benjamin/zett-hypernetwork-Mistral-7B-v0.1")

target_surface_forms = get_surface_form_matrix(
    ["Ġhello", "Ġworld"], # 要预测的标记的字节表示
    maxlen=hypernet.config.hn_surface_maxlen,
    tokenizer_to_use=hn_tokenizer,
)[0]

# 最后一个输出是预测的偏置(如果模型使用偏置,例如XLM-R)
predicted_input_embeddings, predicted_output_embeddings, _ = hypernet(
    torch.from_numpy(target_surface_forms),
    source_embeddings=source_embeddings
)

但是transfer.py目前尚未移植到PyTorch(欢迎提交PR!)。

高级用法

训练超网络

用于训练超网络的脚本是train.py

但首先,您需要通过data/prepare.pydata/prepare_code.py下载并准备数据。

您还需要通过例如cd rust_utils && maturin develop --release安装rust_utils中的Rust模块(用于快速采样分词器)。

完成后,您可以使用configs/中的配置运行训练。例如:

python3 train.py configs/zeroshot/v7:tinyllama_en+code:lw=0.5_long.json

这将在英语和代码上训练TinyLlama的超网络。

使用基础模型超网络将微调模型转移到新的分词器

使用scripts/apply_to_ft.py来转移微调模型的分词器,给定一个已转移分词器的基础模型。例如:

python3 scripts/apply_to_ft.py \
    --output=transferred-chat-mistral \
    --base_model_path=mistralai/Mistral-7B-v0.1 \
    --ft_model_path=mistralai/Mistral-7B-Instruct-v0.1 \
    --tokenizer_swapped_base_model_path=path-to-base-model-with-new-tokenizer \
    --lambdas 0.5 \

复现论文中的实验

experiments/中有bash脚本,可以复现论文中的主要结果。

由于我们正在使用bigcode-evaluation-harness的一个分支来修复遇到的一些问题,代码评估仍然缺失。这些将很快被添加。

单字化、使用n-shot转移模型、复现论文中的分词器等

指南即将推出...(但同时您可以自行探索scripts/目录)

免责声明

我优先考虑快速发布代码,而不是将其完美清理。可能仍存在用于训练模型的个人环境痕迹和其他不太理想的地方。我正在清理这些内容。如果你遇到任何问题或有任何疑问,请提出反馈。

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

豆包MarsCode

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

Project Cover

AI写歌

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

Project Cover

白日梦AI

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

Project Cover

有言AI

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

Project Cover

Kimi

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

Project Cover

讯飞绘镜

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

Project Cover

讯飞文书

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

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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