【ASE+python学习】-批量识别石墨烯团簇结构中的吡啶氮,并删除与其相连的氢

news2025/1/11 5:02:58

批量识别石墨烯团簇结构中的吡啶氮,并删除与其相连的氢

  • 文章背景
  • 任务内容
  • 程序实现思路
  • 实现代码
    • 建立标准结构中边缘碳与氢的位置差值标准数据集
    • 读入待修改结构,识别氮与氢位置差值是否存在标准数据集
  • 代码细节剖析

文章背景

在科研工作中,我的工作需要接触大量的石墨烯团簇结构。对结构掺入一个氮时,氮的分布位置可以分为三类:在团簇内部,团簇边缘,团簇空位附近。对于后两种,一般会形成吡啶氮,但掺氮后我们得到的结构其吡啶氮往往还包括了氢,即有个氢与吡啶氮相连。这是不合理的,因此需要将与吡啶氮相连的氢删除掉
常规操作是逐次打开结构,然后手动删除相应的氢。但如果有几千个这样的结构,手动删除需要花费很长的时间。我一开始是手动删除,执行了一个早上跟晚上也只删除了六百多个,还有两千多个。这样的重复工作让我不禁思考,怎么样可以让程序自动识别出吡啶氮的位置,然后找到相连的氢,自动把它删除呢?
一切自动执行的任务,其实现的核心是程序员对任务过程每个步骤的规则都烂熟于心,然后采用数据与逻辑的方法将每个步骤程序化。结合循环便可以实现批量自动执行。
因此,我针对这个任务的特点,重新剖析了每个实现步骤,尝试使用简单的数学方法结合for循环、if条件结构将步骤程序化

任务内容

打开石墨烯团簇结构,删除与吡啶氮相连的氢原子
在这里插入图片描述

程序实现思路

自动打开石墨烯团簇结构,识别出与吡啶氮相连的氢原子,自动删除
在这里插入图片描述

实现代码

建立标准结构中边缘碳与氢的位置差值标准数据集

def get_str_NH_varyposition(str_path=r'D:\software output files\initial_str_addH',str_file='POSCAR0'):
    '''
    该函数实现自动识别吡啶氮,找出与吡啶氮相连的氢的index,并进行删除
    完整设计思路为:
    1.首先读入一个完整的结构,提取出所有吡啶氮与氢的位置信息
    2.计算吡啶氮与对应氢之间的位置差,存入列表,作为标准数据
    3.读入待删除含有吡啶氮相连氢的结构,提取所有氮、氢的位置
    4.使用迭代,计算氮与氢的相对位置,与标准数据进行比对,如果完全一致,则识别出与吡啶氮相连氢的序号
    5.删除对应的氢,将新结构存入新文件路径
    本函数实现步骤1,2
    str_path:为标准结构所在文件夹的路径
    str_file:为标准结构文件的名字
    '''
    #读入结构
    str_atom=read(os.path.join(str_path,str_file),format='vasp')#读入结构信息,转为atoms object
    #获取结构位置信息
    str_position=str_atom.get_positions()
    #提取结构中所有的N
    N2=str_atom[[atom.index for atom in str_atom if atom.symbol=='N']]
    #提取结构中所有的H
    H27=str_atom[[atom.index for atom in str_atom if atom.symbol=='H']]
    #获取N,H的位置
    H27_position=H27.get_positions()
    N2_position=N2.get_positions()
    #边缘氮、空位氮与相连氢的坐标差
    Npev_index=[73,118,57,45,29,81,92,83,89,93,117,64,65,59,72,31,32,25,70,61,27,53,54,99,102,103,50]
    Hev_index=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,119,120,121]
    N_H_varyx_L=[]
    N_H_varyy_L=[]
    for i in range(0,len(Npev_index),1):
        Npev_position=str_position[Npev_index[i]]
        Hev_position=str_position[Hev_index[i]]
        N_H_varyx=Npev_position[0]-Hev_position[0]
        N_H_varyy=Npev_position[1]-Hev_position[1]
        N_H_varyx_L.append(N_H_varyx)
        N_H_varyy_L.append(N_H_varyy)
    #print("N_H_varyx_L",N_H_varyx_L)
    #print("N_H_varyy_L",N_H_varyy_L)
    return N_H_varyx_L,N_H_varyy_L

读入待修改结构,识别氮与氢位置差值是否存在标准数据集

def find_NpH_index(str_folder,save_path):
    '''
    该函数实现自动识别吡啶氮,找出与吡啶氮相连的氢的index,并进行删除
    完整设计思路为:
    1.首先读入一个完整的结构,提取出所有吡啶氮与氢的位置信息
    2.计算吡啶氮与对应氢之间的位置差,存入列表,作为标准数据
    3.读入待删除含有吡啶氮相连氢的结构,提取所有氮、氢的位置
    4.使用迭代,计算氮与氢的相对位置,与标准数据进行比对,如果完全一致,则识别出与吡啶氮相连氢的序号
    5.删除对应的氢,将新结构存入新文件路径
    本函数实现步骤3,4,5
    str_folder:为待修改结构文件所在文件夹路径
    save_path:为存储修改后的结构文件的存储文件夹路径
    '''
    str_files=os.listdir(str_folder)
    for file in str_files:
        str_PATH=os.path.join(str_folder,file)
        str_atom=read(str_PATH,format='vasp')#读入结构信息,转为atoms object
        #获取结构位置信息
        str_position=str_atom.get_positions()
        #提取结构中所有的N
        N2=str_atom[[atom.index for atom in str_atom if atom.symbol=='N']]
        #提取结构中所有的H
        H27=str_atom[[atom.index for atom in str_atom if atom.symbol=='H']]
        #获取N,H的位置
        H27_position=H27.get_positions()
        N2_position=N2.get_positions()
        #获取吡啶氮与氢位置相差的标准数据
        N_H_varyx_L,N_H_varyy_L=get_str_NH_varyposition()
        #识别读入的氢与氮的相对位置差
        H_delete_index_L=[]#建立新列表存储识别出的氢列表
        for i in range(0,len(N2_position),1):
            for j in range(0,len(H27_position),1):
                N2_H27_varyx=N2_position[i][0]-H27_position[j][0]#计算x坐标差值
                #print("N2_H27_varyx",N2_H27_varyx)
                N2_H27_varyy=N2_position[i][1]-H27_position[j][1]#计算y坐标差值
                #print("N2_H27_varyy",N2_H27_varyy)
                z_L=[z for z in N_H_varyx_L if N2_H27_varyx==z]#识别坐标差值是否符合标准数据
                k_L=[k for k in N_H_varyy_L if N2_H27_varyy==k]
                if not z_L == []:
                    if not k_L == []:
                        str_position_L=str_position.tolist()#np.array转为list
                        H27_position_j=H27_position[j].tolist()
                        H_delete_index=str_position_L.index(H27_position_j)
                        H_delete_index_L.append(H_delete_index)
        #print("H_delete_index_L",H_delete_index_L)
        del str_atom[[i for i in H_delete_index_L]]#删除识别出来的与吡啶氮相连的氢原子
        write(os.path.join(save_path,file),str_atom,format='vasp')#将修改后的结构保存     

函数调用:

str_folder=r'D:\software output files\initial_str_addH'
save_path=r'D:\software output files\initial_str_auto_deleteH'
find_NpH_index(str_folder,save_path)

代码细节剖析

该函数代码主要包括以下知识点:
【ASE方面】

  1. read(),write()函数,作用分别是:将结构信息读取为atom object,将atom object写入文件;
  2. atom_object.get_positions()函数,可以获取atom object中所有的原子坐标信息,数据形式为列表;
  3. atom.index,atom.symbol,可以获取atom object中某种元素所对应所有原子索引
  4. del atom_object[atom_index] ,删除atom object中某个原子

【python方面】

  1. for循环遍历列表,如:for i in list:
  2. 增加列表元素,append()
  3. os模块,os.listdir(), 将文件名读取为列表形式;os.path.join(),实现文件路径拼接
  4. tolist()函数,实现将np.array转为list
  5. if 条件语句,如判断列表是否为空列表,if not List == []:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/60686.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STM32系列(HAL库)——串口IAP

前言 IAP(In Application Programming)即在应用编程,IAP 是用户自己的程序在运行过程中对 User Flash 的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产 品中的固件程序进行更新升级。 设备具备IAP功能…

javaScript学习———变量概述 变量的使用 变量语法扩展 变量命名规范交换 变量案例

博主每篇博文的浪漫主义: 【东京girl秀场上那些甜度爆表的女孩子们。💖】 https://www.bilibili.com/video/BV1pG411F7KT/?share_sourcecopy_web&vd_source385ba0043075be7c24c4aeb4aaa73352 东京girl秀场上那些甜度爆表的女孩子们。💖…

计算机组成原理--------12.4---------开始

计算机硬件的基本组成 冯诺依曼计算机的特点 冯诺依曼首次提出“存储程序”概念 计算机由五大部件组成:I/O设备(输入输出),存储器(存放数据和程序),运算器(算术运算、逻辑运算&…

[附源码]JAVA毕业设计科研项目审批管理系统(系统+LW)

[附源码]JAVA毕业设计科研项目审批管理系统(系统LW) 目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目…

关于解释型语言和编译性语言的区别

关于博主每篇博文的浪漫主义 【初恋是整遍《手写的从前》】 https://www.bilibili.com/video/BV1JP411g7qF/?share_sourcecopy_web&vd_source385ba0043075be7c24c4aeb4aaa73352 初恋是整遍《手写的从前》能够知道解释性语言和编译型语言的特点能够知道标识符不能是关键字…

docker_重装mysql

1.docker ps 查看docker正在运行的容器 2.docker stop xxx 停止正在运行的mysql 3.docker pull mysql:5.7 docker拉取mysql指定版本的镜像 docker pull mysql docker拉取最新版本的镜像 4.docker run -itd --name mysql-test -p 3306:3306 -e MYSQL_ROOT_PASSWORD123456 mysql:…

PHP代码审计系列(一)

PHP代码审计系列&#xff08;一&#xff09; 本系列将收集多个PHP代码安全审计项目从易到难&#xff0c;并加入个人详细的源码解读。此系列将进行持续更新。 extract变量覆盖 源码如下 <?php$flagextractFlag.txt; extract($_GET);if(isset($shiyan)){ $contenttrim(f…

YOLO算法创新改进系列(项目汇总)

&#x1f680;&#x1f680;&#x1f680;——YOLO算法创新改进系列项目汇总——&#x1f384;&#x1f384;&#x1f384; &#x1f680; YOLO算法创新改进系列 &#xff08;项目汇总&#xff09;&#x1f384;&#x1f388; &#x1f340; 改进YOLOv5/YOLOv7——魔改YOLOv5/Y…

文件操作及IO

目录 一、文件的分类 二、文件路径 三、File 常见方法 1、get 相关方法使用 2、文件的创建和删除 3、遍历目录下所有文件 四、文件读写 一、文件的分类 站在程序员的角度&#xff0c;文件通常可以分为两类&#xff1a; 文本文件&#xff1a;以字符形式存储二进制文件&…

Java基于SSM的海淘商城系统

随着计算机网络的普及,电子商务的兴起,网络支付以及网络安全体系逐渐完善,人们的生活进入了网络时代,越来越多的人习惯于乐于网上购物,只需上网轻轻点击鼠标便能够买到心仪商品。 本系统主要是针对广大网络消费者而开发的,专为网络消费者打造,建设一个”全球购”海淘商城系统。…

Redis学习笔记(五)

主从复制 单机redis的风险和问题 机器故障&#xff1a;硬盘故障、系统崩溃容量瓶颈&#xff1a;内存不足&#xff0c;无限升级内存结论&#xff1a;为了避免单点redis服务器故障&#xff0c;准备多台服务器互相连通&#xff0c;将数据复制多个副本保存在不同的服务器上&#xf…

Vue 官方文档2.x教程学习笔记 1 基础 1.5 计算属性和侦听器 1.5.2 侦听器

Vue 官方文档2.x教程学习笔记 文章目录Vue 官方文档2.x教程学习笔记1 基础1.5 计算属性和侦听器1.5.2 侦听器1 基础 1.5 计算属性和侦听器 1.5.2 侦听器 虽然计算属性在大多数情况下更合适&#xff0c;但有时也需要一个自定义的侦听器。 这就是为什么 Vue 通过 watch 选项提…

图像处理:模糊图像判断

目录 上期回顾 采用Laplace算子的原因 实现的效果 图片素材 代码的展示与讲解 效果展示 项目资源 上期回顾 上一次的图像清晰度评价没有成功&#xff0c;主要的原因是那几张图像清晰度评价函数都实际都采用了梯度求解&#xff0c;不同的场景灰度的明暗不同&#xff0c;…

数据结构栈的实现

目录栈的概念栈的结构声明初始化数据入栈出栈判断栈是否为空取栈顶的值销毁栈栈的概念 栈是一种线性表&#xff0c;插入数据的一端叫栈顶&#xff0c;另一端叫栈底。 入栈&#xff1a;数据从栈顶进入栈中 出栈&#xff1a;数据从栈顶删除 所以&#xff0c;栈的特点就是先进后出…

Spark - OnYARN 模式搭建,并使用 Scala、Java、Python 三种语言测试

一、SparkOnYarn搭建 安装前需要提前安装好 hadoop 环境&#xff0c;关于 HDFS 和 Yarn 集群的搭建可以参考下面我的博客&#xff1a; https://blog.csdn.net/qq_43692950/article/details/127158935 下面是我 Hadoop 的安装结构 主机规划设置主机名角色192.168.40.172node1N…

1. STL六大组件

0. 介绍 STL提供六大组件&#xff0c;它们之间可以彼此套用&#xff0c;如下图所示&#xff1a; 容器&#xff08;containers&#xff09;&#xff1a;用于存放数据&#xff1b; 算法&#xff08;algorithms&#xff09;&#xff1a;包含各种常用算法&#xff1b; 迭代器&…

Dubbo-RPC核心接口介绍

前言 Dubbo源码阅读分享系列文章&#xff0c;欢迎大家关注点赞 SPI实现部分 Dubbo-SPI机制 Dubbo-Adaptive实现原理 Dubbo-Activate实现原理 Dubbo SPI-Wrapper 注册中心 Dubbo-聊聊注册中心的设计 Dubbo-时间轮设计 通信 Dubbo-聊聊通信模块设计 RPC 聊聊Dubbo协议 …

go语言日志实现详解(打印日志、日志写入文件和日志切割)

log包定义了Logger类型&#xff0c;该类型提供了一些格式化输出的方法。本包也提供了一个预定义的“标准”logger&#xff0c;可以通过调用函数Print系列(Print|Printf|Println&#xff09;、Fatal系列&#xff08;Fatal|Fatalf|Fatalln&#xff09;、和Panic系列&#xff08;P…

[附源码]计算机毕业设计JAVA医院挂号管理系统

[附源码]计算机毕业设计JAVA医院挂号管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybati…

简单的咖啡文化静态HTML网页设计作品 DIV布局咖啡馆文化网页模板代码 DW咖啡网站制作成品

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…