首页
/ MolT5 开源项目使用教程

MolT5 开源项目使用教程

2024-09-18 14:18:08作者:吴年前Myrtle

1. 项目介绍

MolT5 是一个用于分子与自然语言之间翻译的自监督学习框架。该项目通过预训练模型在大量未标记的自然语言文本和分子字符串上,实现了新的、有用的和具有挑战性的视觉-语言任务的模拟,例如分子描述和基于文本的新分子生成。MolT5 通过在单模态数据上预训练模型,克服了化学领域数据稀缺的缺点。

2. 项目快速启动

2.1 环境准备

首先,确保你已经安装了 Python 3.7 或更高版本,并安装了所需的依赖包。你可以通过以下命令安装依赖:

pip install -r requirements.txt

2.2 下载预训练模型

MolT5 提供了多个预训练模型,你可以从 HuggingFace 模型库中下载。以下是下载 molt5-large-smiles2caption 模型的示例代码:

from transformers import T5Tokenizer, T5ForConditionalGeneration

tokenizer = T5Tokenizer.from_pretrained("laituan245/molt5-large-smiles2caption", model_max_length=512)
model = T5ForConditionalGeneration.from_pretrained('laituan245/molt5-large-smiles2caption')

2.3 使用模型进行分子描述

以下是一个使用 molt5-large-smiles2caption 模型进行分子描述的示例代码:

input_text = 'C1=CC2=C(C(=C1)[O-])NC(=CC2=O)C(=O)O'
input_ids = tokenizer(input_text, return_tensors="pt").input_ids

outputs = model.generate(input_ids, num_beams=5, max_length=512)
print(tokenizer.decode(outputs[0], skip_special_tokens=True))

2.4 使用模型进行分子生成

以下是一个使用 molt5-large-caption2smiles 模型进行分子生成的示例代码:

tokenizer = T5Tokenizer.from_pretrained("laituan245/molt5-large-caption2smiles", model_max_length=512)
model = T5ForConditionalGeneration.from_pretrained('laituan245/molt5-large-caption2smiles')

input_text = 'The molecule is a monomethoxybenzene that is 2-methoxyphenol substituted by a hydroxymethyl group at position 4. It has a role as a plant metabolite. It is a member of guaiacols and a member of benzyl alcohols.'
input_ids = tokenizer(input_text, return_tensors="pt").input_ids

outputs = model.generate(input_ids, num_beams=5, max_length=512)
print(tokenizer.decode(outputs[0], skip_special_tokens=True))

3. 应用案例和最佳实践

3.1 分子描述

MolT5 可以用于生成分子的自然语言描述,这对于药物发现和化学研究非常有用。例如,给定一个分子的 SMILES 表示,MolT5 可以生成该分子的详细描述,包括其结构和功能。

3.2 分子生成

MolT5 还可以用于基于文本描述生成新的分子。这对于设计新的药物分子或材料非常有用。例如,给定一个描述特定性质的文本,MolT5 可以生成具有这些性质的分子。

3.3 数据增强

MolT5 可以用于数据增强,通过生成新的分子描述和分子来扩展现有的数据集。这对于训练更强大的机器学习模型非常有用。

4. 典型生态项目

4.1 T5X

T5X 是一个用于预训练和微调 T5 系列模型的框架。MolT5 使用了 T5X 框架进行模型的预训练和微调。

4.2 HuggingFace Transformers

HuggingFace Transformers 是一个广泛使用的自然语言处理库,提供了大量的预训练模型和工具。MolT5 的模型可以通过 HuggingFace Transformers 库进行加载和使用。

4.3 TensorFlow

TensorFlow 是一个广泛使用的机器学习框架,MolT5 使用了 TensorFlow 进行模型的训练和评估。

通过这些生态项目,MolT5 可以与其他工具和框架无缝集成,提供更强大的功能和更好的用户体验。

登录后查看全文
热门项目推荐

最新内容推荐

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
53
468
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
878
517
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.1 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
180
264
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉Web框架。Rest, 宏路由,Json, 中间件,参数绑定与校验,文件上传下载,MCP......
Cangjie
87
14
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
349
381
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
612
60