使用Deepchem构建化学分子的神经网络和图神经网络模型示例

2023-10-22 14:59

本文主要是介绍使用Deepchem构建化学分子的神经网络和图神经网络模型示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先,关于分子指纹,分子指纹是一个二进制向量,其中每个位代表是否存在该分子的某个子结构 ,例如苯环。 它通常很长,可能无法合并一些结构信息,例如手性 。
分子指纹

'''使用Deepchem构建化学分子的神经网络和图神经网络模型示例by wufeilDeepchem包含了很多的化学分子的数据集,同时也有将分子结构转换为机器学习能够识别的矩阵(序列)数据的方法,下面就来简单举几个例子,以便快速入门'''import numpy as np
import deepchem as dc
import tensorflow as tf#设定随机数,可重复再现
np.random.seed(88)
tf.random.set_seed(88)'''
Delaney(ESOL) 溶解度能数据集该数据集是Deepchem内置MoleculeNet数据集的一部分。首先,全连接神经网络多任务回归器
'''
#加载数据
tasks, datasets, transformers = dc.molnet.load_delaney() #默认是下载分子指纹
print(transformers)
print(tasks) #任务  #print: ['measured log solubility in mols per litre']
print(datasets[0])''''
划分数据集
'''
train_dataset, valid_dataset, test_dataset = datasets
print(train_dataset) #迭代对象
print(test_dataset)
print(valid_dataset)#模型的评价指标
avg_pearson_r2 = dc.metrics.Metric(dc.metrics.pearson_r2_score, np.mean)
#回归任务模型
'''
dc.models.MultitaskRegressor: deepchem的多任务回归的全连接网络模型
请参照:https://deepchem.readthedocs.io/en/latest/api_reference/models.html?highlight=MultitaskRegressor#deepchem.models.MultitaskRegressor.__init__'''
model = dc.models.MultitaskRegressor(len(tasks), #任务数量,这里为1n_features=datasets[0].X.shape[1], #每个分子的特征数量layer_sizes=[500])  #500层model.fit(train_dataset)train_score = model.evaluate(train_dataset, [avg_pearson_r2], transformers)
valid_score = model.evaluate(valid_dataset, [avg_pearson_r2], transformers)
assert train_score['mean-pearson_r2_score']>0.7, train_score
assert valid_score['mean-pearson_r2_score']>0.3, valid_score'''图卷积网络模型在全连接层神经网络模型中,输入的是ECFP的fingerprint在图神经网络中,这种ECFP的数据结构不适合,所以在导入数据的时候需要设置transformers=’GraphConv'dc.models.GraphConvModel有不同的参数需要设置,请见:https://deepchem.readthedocs.io/en/latest/api_reference/models.html#model
'''tasks, datasets, transformers = dc.molnet.load_delaney(featurizer='GraphConv')
train_dataset, valid_dataset, test_dataset = datasets
model = dc.models.GraphConvModel(len(tasks), mode='regression', dropout=0.5)
model.fit(train_dataset, nb_epoch=30)
train_score = model.evaluate(train_dataset, [avg_pearson_r2], transformers)
print(train_score)''''
这里要特别说明的是,数据结构的问题由于图神经网络的输入为特殊的链接矩阵和节点信息,因此,在这里的加载数据的时候使用了GraphConv的特征化方法生成的train_datset中, X保存的则是ConvMol的对象,专门用于图神经网络计算的计算。
详见:https://deepchem.readthedocs.io/en/latest/api_reference/dataclasses.html?highlight=ConvMol#deepchem.feat.mol_graphs.ConvMol如下例,返回链接表
'''
print(train_dataset.X[0].get_adjacency_list())
print(train_dataset.X[0].get_atom_features())

如何将一个分子转化为机器学习可以识别的数据类型(例如这里提到的分子指纹)呢?有力再写

这篇关于使用Deepchem构建化学分子的神经网络和图神经网络模型示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/262196

相关文章

Tomcat的下载安装与使用教程

《Tomcat的下载安装与使用教程》本文介绍了Tomcat的下载、安装和使用方法,包括在本机和云服务器上部署Tomcat的过程,以及解决启动失败问题的方法... 目录Tomcat的下载安装与使用Tomcat的下载与安装Tomcat在本机运行使用Tomcat在php云服务器上的使用总结Tomcat的下载安装与

Python使用PIL库将PNG图片转换为ICO图标的示例代码

《Python使用PIL库将PNG图片转换为ICO图标的示例代码》在软件开发和网站设计中,ICO图标是一种常用的图像格式,特别适用于应用程序图标、网页收藏夹图标等场景,本文将介绍如何使用Python的... 目录引言准备工作代码解析实践操作结果展示结语引言在软件开发和网站设计中,ICO图标是一种常用的图像

C++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

MyBatis与其使用方法示例详解

《MyBatis与其使用方法示例详解》MyBatis是一个支持自定义SQL的持久层框架,通过XML文件实现SQL配置和数据映射,简化了JDBC代码的编写,本文给大家介绍MyBatis与其使用方法讲解,... 目录ORM缺优分析MyBATisMyBatis的工作流程MyBatis的基本使用环境准备MyBati

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

spring @EventListener 事件与监听的示例详解

《spring@EventListener事件与监听的示例详解》本文介绍了自定义Spring事件和监听器的方法,包括如何发布事件、监听事件以及如何处理异步事件,通过示例代码和日志,展示了事件的顺序... 目录1、自定义Application Event2、自定义监听3、测试4、源代码5、其他5.1 顺序执行

Java之并行流(Parallel Stream)使用详解

《Java之并行流(ParallelStream)使用详解》Java并行流(ParallelStream)通过多线程并行处理集合数据,利用Fork/Join框架加速计算,适用于大规模数据集和计算密集... 目录Java并行流(Parallel Stream)1. 核心概念与原理2. 创建并行流的方式3. 适