晶体空间结构变换方法及系统与流程

文档序号:24191243发布日期:2021-03-09 15:11阅读:498来源:国知局
晶体空间结构变换方法及系统与流程

1.本发明涉及晶体展示,特别涉及一种晶体空间结构变换方法及系统。


背景技术:

2.当前描述一个晶体的3维微观空间结构的方式主要是描述晶胞参数,晶体中非对称单元内的分子的每一个原子在晶胞中的相对坐标,和空间群来实现的。具体方式说明如下:
3.晶胞参数
4.构成晶体的最基本的几何单元称为晶胞(unit cell),其形状、大小与空间格子的平行六面体单位相同,保留了整个晶格的所有特征。
5.晶胞能完整反映晶体内部原子或离子在三维空间分布之化学

结构特征的平行六面体单元。其中既能够保持晶体结构的对称性而体积又最小者特称“单位晶胞”,但亦常简称晶胞。如图1所示,其具体形状大小由它的三组棱长a、b、c及棱间交角α、β、γ(合称为”晶胞参数”)来表征,与空间格子中的单位平行六面体相对应。
6.分子内的原子坐标。
7.晶胞构成了一个参考坐标系。原点为三组棱的交点,x、y、z方向分别为从原点出发沿a、b、c三个方向。
8.在晶胞这个最小单元内,非对称的每个分子的每个原子都有在上述参考坐标系下的坐标。
9.比如,对于分子(c13 h16 n4 o),可以用下面的方式来描述每个原子的坐标
10.[0011][0012][0013]
每一行中第一列为原子的名称,第二列为原子的元素类型,第三至五列为原子在
坐标系中的分数坐标,其实际坐标为该分数坐标乘以x、y、z方向分别对应的棱长a、b、c。最后一列为权重值,通常为1。
[0014]
晶体的空间群信息
[0015]
晶体内部结构中全部对称要素的集合称为“空间群”。
[0016]
一切晶体结构中总共只能有230种不同的对称要素组合方式,即230个空间群。它是由俄国结晶学家费多洛夫和德国结晶学家薛弗利斯(artur moritz schoenflies,1853

1928)于1890至1891年间各自独立地先后推导得出来的,故亦称为“230个费多洛夫群”。
[0017]
只要给定晶体的空间群的序号,就可以唯一确定该晶体是以怎样的对称要素从非对称的单个分子在空间中有序排列成整个晶体的。
[0018]
比如如果确定晶体是2号空间群。则全部对称要素为下面两个对称操作
[0019]
1x,y,z
[0020]2‑
x,

y,

z
[0021]
所以,晶胞内的所有分子可以从这两个对称操作得到。比如对于上述分子中的每个原子应用这两个对称操作,应用对称操作1,分子中原子坐标不变;应用对称操作2,分子中原子坐标都变为原来的负数。这样就得到完整的晶体3维微观结构描述。
[0022]
当前大部分的晶体学软件,比如ccdc等都支持这样的描述。
[0023]
当前的描述方法虽然比较直观,计算也相对简单,但在描述有机晶体优化过程中却非常不方便。因为有机晶体中通常包括好多个柔性健,这些柔性键可以在空间内自由旋转。在晶体优化的过程中,通常都需要保持其他原子间相对位置不变,单独旋转指定的1个或几个柔性键。那么,上述的描述方式就很难直接计算出旋转后的晶体结构。如果在晶体搜索的全局优化算法中,更是无法对晶体结构进行指定的柔性键扫描。这会让整个晶体搜索和优化的过程变成一个不连续的过程,只能通过试错的方式进行。


技术实现要素:

[0024]
基于此,有必要提供一种可提高晶体优化效率的晶体空间结构变换方法。
[0025]
同时,提供一种可提高晶体优化效率的晶体空间结构变换系统。
[0026]
一种晶体空间结构变换方法,包括:
[0027]
读取:读取晶体文件,将晶体文件中的晶胞参数、分子内的原子坐标和空间群信息转换为面向对象的数据结构存储,面向对象的数据结构包括:晶体结构、分子结构,晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性;分子结构包括:对应的分子实例的唯一标识、分子内全部原子的位置信息;
[0028]
转换:将面向对象的数据结构转换为新对象数据结构,新对象数据结构包括:新晶体结构、新分子结构,新晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性,新分子结构包括:分子内每个原子对应的原子链,将面向对象的数据结构中晶体结构中的晶胞属性和空间群属性复制到新晶体结构中对应属性,读取分子结构中分子内全部原子的位置信息,根据原子的位置信息确定每个原子的原子链;
[0029]
晶体演化:计算晶体的晶格能,根据设定步长调整晶体的晶胞属性参数和柔性键
取值,按照晶胞预设的棱长和棱角调整步长调整晶胞属性参数,将调整后的参数值赋给晶胞属性参数值,对每条原子链匹配指定的柔性键,根据设定步长进行旋转调整柔性键,每次调整一个参数,计算调整后的晶体晶格能,直至最低的晶体晶格能在设定的停止次数下不再增加,分配id给演化形成新的晶体;
[0030]
二次转换:将新对象数据结构转换为面向对象的数据结构;
[0031]
保存:将晶胞属性、空间群属性写入新的文件,遍历非对称单元内所有分子的属性,获取对应的分子结构参数,对每个分子结构中的原子数组依次逐行写入文件。
[0032]
在优选实施例中,所述晶体结构的对应晶胞属性记录对应晶胞的6个参数,三组棱长a、b、c、及棱间夹角α、β、γ,所述分子结构的分子内全部原子的位置信息为二维数组,该二维数组中每一项为一个5维数组,该5维数字第一项为原子的名称,第二项为原子的元素类型,第三至五项为原子在晶胞内的分数坐标。
[0033]
在优选实施例中,所述新晶体结构包的对应晶胞属性记录对应晶胞的6个参数,三组棱长a、b、c、及棱间夹角α、β、γ;所述新分子结构用三维数组记录分子内每个原子对应的原子链{[(cell_o,cell_o,0,θ
01
,0,θ
02
),(an1,at1,d
11

11
,d
12

12
,),(an2,at2,d
21

21
,d
22

22
),

,(an
n
,at
n
,d
n1

n1
,d
n2

n2
)],

,[(cell_o,cell_o,0,θ
01
,0,0),(an1,at1,d
11

11
,d
12

12
),(an2,at2,d
21

21
,d
22

22
),

,(an
m
,at
m
,d
m1

m1
,d
m2

m2
)]},其中第一层数组中的每个数组记录了一条原子链,每一条原子链中的数组记录了这条原子链中的每一个原子的信息,每条原子链中第一个数组记录的是晶胞原点的坐标信息,其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角,原子信息数组第一项an
i
为原子名称,唯一对应分子内的一个原子;第二项为原子的元素类型,第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离;第四项θ
i1
为该原子与前一个原子、和与后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0;第五项d
i2
为该原子与前一个原子局部坐标轴中x轴之间的轴距,第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角。
[0034]
在优选实施例中,所述原子局部坐标轴为以该原子与前一个原子之间的连线为z轴的负方向,x轴方向为该原子与前一个和后一个原子所在平面垂直的方向,y轴为与z轴、x轴成右手螺旋规则的方向,第一个原子的前一个原子为晶胞原点,最后一个原子的后一个原子为分子内任意一个非骨架原子;所述原子链:计算分子内每个原子与晶胞原点之间的距离,选择距离最近的一个原子为起始原子,对分子内的每个原子,在分子的拓扑结构中找到一条连接该原子和起始原子的通路,分子内的原子作为通路的节点,分子内两原子之间的键作为通路的边。
[0035]
在优选实施例中,所述转换还包括:读取与晶体结构对应的分子结构中每个原子的分数坐标,确定每个原子的原子链,并将原子链存储为三维数组中{[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
n
,at
n
)],

,[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
m
,at
m
)]},其中an1为起始原子,an
i
为分子内的任一原子,每个数组记录每个原子到起始原子的连接链路;计算晶胞原点到第一个原子的向量和晶胞棱a、c的夹角,得到θ
01

02
;遍历该数组,对每个原子链计算其d
i1

i1
,d
i2

i2
;获取该原子在原子链上前一个和后一个原子的分数坐标,第一个原子的前一个原子为晶胞的原点,最后一个原子的后一个原子为分
子内任一一个与该原子和前一个原子不共线的原子,计算该原子距离前一个原子的距离,得到d
i1
;计算该原子与前后原子形成的夹角的度数,得到θ
i1
;确定原子链上每个原子的原子局部坐标轴,计算前一个原子的原子局部坐标轴的x轴与该原子的原子局部坐标轴的x轴的轴距,得到d
i2
;计算计算前一个原子的原子局部坐标轴的x轴与该原子的原子局部坐标轴的x轴的轴间夹角,得到θ
i2
;将该数组存储为新分子结构中的分子内每个原子对应的原子链的属性中,并关联到对应的新晶体结构中。
[0036]
在优选实施例中,所述演化步骤包括:接受晶胞属性参数演化范围的输入或设置,接受柔性键演化范围的输入或设置,接受新对象数据结构,计算晶体的晶格能,复制新晶体结构对象,按照晶胞预设的棱长和棱角调整步长调整晶胞属性参数,将调整后的参数值赋给晶胞属性参数值,然后遍历新晶体结构中的分子内每个原子对应的原子链的对应数组,对每条原子链匹配指定的柔性键,若匹配到原子链中相邻的两个原子名称和顺序与指定的柔性键的原子键名称和顺序相同,则对后一个原子按指定步长调整,每次调整一个参数,默认做正向调整,然后计算调整后的晶体的晶格能,若调整后的晶体的晶格能增加,则下一步调整循环中做负向调整,如果调整后的晶体的晶格能减少则在下一个调整循环中继续做正向调整,若调整值超出预设调整边界,则将边界作为调整后的值,重复调整,直至最低的晶体晶格能在设定的停止次数下不再增加;所述演化步骤的演化顺序为先调整晶胞参数,再调整柔性键参数,晶胞参数按a、b、c、α、β、γ顺序进行调整,柔性键按新分子结构中的原子链数组中的顺序进行调整。
[0037]
在优选实施例中,所述二次转换包括:将新晶体结构中的晶胞属性和空间群属性复制为晶体结构中的对应属性,读取第一条原子链中的晶胞原点数组(cell_o,cell_o,0,θ
01
,0,θ
02
)和初始原子数组(an1,at1,d
11

11
,d
12

12
,),记初始原子在晶胞内的分数坐标为x,y,z,则x2+y2+z2=d
112
,cosθ
012
=x2/(x2+y2+z2),cosθ
022
=z2/(x2+y2+z2),解方程组可获取初始原子在晶胞内的分数坐标;读取下一个原子数组(an2,at2,d
21

21
,d
22

22
,),记该原子在晶胞内的分数坐标为x,y,z,则x2+y2+z2=d
212
,cosθ
11
=(d
112
+d
212

x2‑
y2‑
z2)/2d
11
d
21
,cosθ
12
=(d
122
+d
222

x2‑
y2‑
z2)/2d
12
d
22
,解方程组获取该原子在晶胞内的分数坐标;依次读取下一个原子数组(an
i
,at
i
,d
i1

i1
,d
i2

i2
),重复解方程组x2+y2+z2=d
i12
,cosθ
(i

1)1
=(d
(i

1)12
+d
i12

x2‑
y2‑
z2)/2d
(i

1)1
d
i1

[0038]
cosθ
(i

1)2
=(d
(i

1)22
+d
i22

x2‑
y2‑
z2)/2d
(i

1)2
d
i2
,获取原子在晶胞中的分数坐标,其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角,原子信息数组第一项an
i
为原子名称,唯一对应分子内的一个原子;第二项为原子的元素类型,第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离;第四项θ
i1
为该原子与前一个原子、和与后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0;第五项d
i2
为该原子与前一个原子局部坐标轴中x轴之间的轴距,第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角;如此迭代可以得到整条原子链中每个原子的分数坐标;遍历新分子结构中的分子内每个原子对应的原子链数组,对每条原子链重复上述求解操作,得到整个分子内全部原子的分数坐标,将分子内的全部原子的原子名称、原子类型、分数坐标填入分子结构的分子内全部原子的位置信息属性中,就得到了完整的晶体结构。
[0039]
一种晶体空间结构变换系统,包括:
[0040]
读取模块:读取晶体文件,将晶体文件中的晶胞参数、分子内的原子坐标和空间群信息转换为面向对象的数据结构存储,面向对象的数据结构包括:晶体结构、分子结构,晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性;分子结构包括:对应的分子实例的唯一标识、分子内全部原子的位置信息;
[0041]
转换模块:将面向对象的数据结构转换为新对象数据结构,新对象数据结构包括:新晶体结构、新分子结构,新晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性,新分子结构包括:分子内每个原子对应的原子链,将面向对象的数据结构中晶体结构中的晶胞属性和空间群属性复制到新晶体结构中对应属性,读取分子结构中分子内全部原子的位置信息,根据原子的位置信息确定每个原子的原子链;
[0042]
晶体演化模块:计算晶体的晶格能,根据设定步长调整晶体的晶胞属性参数和柔性键取值,按照晶胞预设的棱长和棱角调整步长调整晶胞属性参数,将调整后的参数值赋给晶胞属性参数值,对每条原子链匹配指定的柔性键,根据设定步长进行旋转调整柔性键,每次调整一个参数,计算调整后的晶体晶格能,直至最低的晶体晶格能在设定的停止次数下不再增加,分配id给演化形成新的晶体;
[0043]
二次转换模块:将新对象数据结构转换为面向对象的数据结构;
[0044]
保存模块:将晶胞属性、空间群属性写入新的文件,遍历非对称单元内所有分子的属性,获取对应的分子结构参数,对每个分子结构中的原子数组依次逐行写入文件。
[0045]
在优选实施例中,所述晶体结构的对应晶胞属性记录对应晶胞的6个参数,三组棱长a、b、c、及棱间夹角α、β、γ,所述分子结构的分子内全部原子的位置信息为二维数组,该二维数组中每一项为一个5维数组,该5维数字第一项为原子的名称,第二项为原子的元素类型,第三至五项为原子在晶胞内的分数坐标;
[0046]
所述二次转换模块包括:将新晶体结构中的晶胞属性和空间群属性复制为晶体结构中的对应属性,读取第一条原子链中的晶胞原点数组(cell_o,cell_o,0,θ
01
,0,θ
02
)和初始原子数组(an1,at1,d
11

11
,d
12

12
,),记初始原子在晶胞内的分数坐标为x,y,z,则x2+y2+z2=d
112
,cosθ
012
=x2/(x2+y2+z2),cosθ
022
=z2/(x2+y2+z2),解方程组可获取初始原子在晶胞内的分数坐标;读取下一个原子数组(an2,at2,d
21

21
,d
22

22
,),记该原子在晶胞内的分数坐标为x,y,z,则x2+y2+z2=d
212
,cosθ
11
=(d
112
+d
212

x2‑
y2‑
z2)/2d
11
d
21
,cosθ
12
=(d
122
+d
222

x2‑
y2‑
z2)/2d
12
d
22
,解方程组获取该原子在晶胞内的分数坐标;依次读取下一个原子数组(an
i
,at
i
,d
i1

i1
,d
i2

i2
),重复解方程组x2+y2+z2=d
i12
,cosθ
(i

1)1
=(d
(i

1)12
+d
i12

x2‑
y2‑
z2)/2d
(i

1)1
d
i1

[0047]
cosθ
(i

1)2
=(d
(i

1)22
+d
i22

x2‑
y2‑
z2)/2d
(i

1)2
d
i2
,获取原子在晶胞中的分数坐标,其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角,原子信息数组第一项an
i
为原子名称,唯一对应分子内的一个原子;第二项为原子的元素类型,第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离;第四项θ
i1
为该原子与前一个原子、和与后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0;第五项d
i2
为该原子与前一个原子局部坐标轴中x轴之间的轴距,第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角;如此迭代可以得到整条原子链中每个原子的分数坐标;遍历新分子结构中的分子内每个原子对应的原子链数组,对每条原子链重复上述求解操作,得到整个分子内全部原子的分数坐标,将分子内的全部原子的原子名称、原子类型、分数坐标填入分子结构的分子内全部原子的位置信息属性中,就得到了完整的晶体结构
[0048]
在优选实施例中,所述新晶体结构包的对应晶胞属性记录对应晶胞的6个参数,三组棱长a、b、c、及棱间夹角α、β、γ;所述新分子结构用三维数组记录分子内每个原子对应的原子链{[(cell_o,cell_o,0,θ
01
,0,θ
02
),(an1,at1,d
11

11
,d
12

12
,),(an2,at2,d
21

21
,d
22

22
),

,(an
n
,at
n
,d
n1

n1
,d
n2

n2
)],

,[(cell_o,cell_o,0,θ
01
,0,0),(an1,at1,d
11

11
,d
12

12
),(an2,at2,d
21

21
,d
22

22
),

,(an
m
,at
m
,d
m1

m1
,d
m2

m2
)]},其中第一层数组中的每个数组记录了一条原子链,每一条原子链中的数组记录了这条原子链中的每一个原子的信息,每条原子链中第一个数组记录的是晶胞原点的坐标信息,其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角,原子信息数组第一项an
i
为原子名称,唯一对应分子内的一个原子;第二项为原子的元素类型,第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离;第四项θ
i1
为该原子与前一个原子、和与后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0;第五项d
i2
为该原子与前一个原子局部坐标轴中x轴之间的轴距,第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角;
[0049]
所述转换模块还包括:读取与晶体结构对应的分子结构中每个原子的分数坐标,确定每个原子的原子链,并将原子链存储为三维数组中{[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
n
,at
n
)],

,[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
m
,at
m
)]},其中an1为起始原子,an
i
为分子内的任一原子,每个数组记录每个原子到起始原子的连接链路;计算晶胞原点到第一个原子的向量和晶胞棱a、c的夹角,得到θ
01

02
;遍历该数组,对每个原子链计算其d
i1

i1
,d
i2

i2
;获取该原子在原子链上前一个和后一个原子的分数坐标,第一个原子的前一个原子为晶胞的原点,最后一个原子的后一个原子为分子内任一一个与该原子和前一个原子不共线的原子,计算该原子距离前一个原子的距离,得到d
i1
;计算该原子与前后原子形成的夹角的度数,得到θ
i1
;确定原子链上每个原子的原子局部坐标轴,计算前一个原子的原子局部坐标轴的x轴与该原子的原子局部坐标轴的x轴的轴距,得到d
i2
;计算计算前一个原子的原子局部坐标轴的x轴与该原子的原子局部坐标轴的x轴的轴间夹角,得到θ
i2
;将该数组存储为新分子结构中的分子内每个原子对应的原子链的属性中,并关联到对应的新晶体结构中。
[0050]
上述晶体空间结构变换方法及系统通过转换将面向对象的数据结构转换为新对象数据结构,从而将晶体的参数空间从描述每个原子在晶胞内的分数坐标,转换为描述晶体内相邻两个原子之间的相对位置,包括相对距离,之间的夹角,和相邻两个分子键之间的轴距和轴间夹角,这样在晶体演化过程中整个参数空间是连续变化的,克服了之前由于参数空间不连续,导致演化过程不能平滑找到局部最优解的问题,这使得使用新的参数空间在找到局部和全局能量最低的晶体结构的过程中,效率有大幅提升,在研究和算法开发方
面也更直观。
附图说明
[0051]
图1为晶胞的示意图;
[0052]
图2为本发明一实施例的晶体空间结构变换方法的部分流程图。
具体实施方式
[0053]
如图1所示,本发明一实施例的晶体空间结构变换方法,包括:
[0054]
步骤s101,读取:读取晶体文件,将晶体文件中的晶胞参数、分子内的原子坐标和空间群信息转换为面向对象的数据结构存储,面向对象的数据结构包括:晶体结构、分子结构,晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性;分子结构包括:对应的分子实例的唯一标识、分子内全部原子的位置信息;
[0055]
步骤s103,转换:将面向对象的数据结构转换为新对象数据结构,新对象数据结构包括:新晶体结构、新分子结构,新晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性,新分子结构包括:分子内每个原子对应的原子链,将面向对象的数据结构中晶体结构中的晶胞属性和空间群属性复制到新晶体结构中对应属性,读取分子结构中分子内全部原子的位置信息,根据原子的位置信息确定每个原子的原子链;
[0056]
步骤s105,晶体演化:计算晶体的晶格能,根据设定步长调整晶体的晶胞属性参数和柔性键取值,按照晶胞预设的棱长和棱角调整步长调整晶胞属性参数,将调整后的参数值赋给晶胞属性参数值,对每条原子链匹配指定的柔性键,根据设定步长进行旋转调整柔性键,每次调整一个参数,计算调整后的晶体晶格能,直至最低的晶体晶格能在设定的停止次数下不再增加,分配id给演化形成新的晶体;
[0057]
步骤s107,二次转换:将新对象数据结构转换为面向对象的数据结构;
[0058]
步骤s109,保存:将晶胞属性、空间群属性写入新的文件,遍历非对称单元内所有分子的属性,获取对应的分子结构参数,对每个分子结构中的原子数组依次逐行写入文件。
[0059]
本实施例,支持读取传统的cif晶体文件,读取方式为标准的逐行扫描。模块将cif文件中的晶胞参数、分子内的原子坐标和空间群信息按下述面向对象的数据结构存储。
[0060]
数据结构包括2个实体类:晶体结构(crystal)、分子结构(molecule)。crystal类实例化后对应一个具体的晶体结构。molecule类实例化后对应一个具体的分子结构。crystal和molecule之间是1对多的关系,即每个crystal实例有1个或多个外键指向对应的molecule实例。
[0061]
crystal类包括属性id、unit_cell、molecule_ids、sym。其中id是对应晶体实例的唯一标识。unit_cell为晶胞属性,是一个6位数组,记录对应晶胞的6个参数:三组棱长a、b、c及棱间交角α、β、γ。molecule_ids为一个不定长多维数组,记录非对称单元内所有分子的id。sym是晶体实例对应的空间群。
[0062]
molecule类包括属性id、atoms。其中id是对应分子实例的唯一标识。atoms为分子内全部原子的位置信息,优选的为分子内全部原子的二维数组,即数组中的每一项是一个5
维数组,这个5维数组第一项为原子的名称,第二项为原子的元素类型,第三~五项为原子在晶胞内的分数坐标。参见背景技术。
[0063]
新数据结构包括2个实体类:新晶体结构(new_crystal)、新分子结构(new_molecule)。new_crystal类实例化后对应一个具体的晶体结构。new_molecule类实例化后对应一个具体的分子结构。new_crystal和new_molecule之间是1对多的关系,即每个new_crystal实例有1个或多个外键指向对应的new_molecule实例。
[0064]
new_crystal类包括属性id、unit_cell、molecule_ids、sym。其中id是对应晶体实例的唯一标识。unit_cell为晶胞属性,一个6位数组,记录对应晶胞的6个参数:三组棱长a、b、c及棱间交角α、β、γ。molecule_ids为一个不定长多维数组,记录非对称单元内所有分子的id。sym是晶体实例对应的空间群。
[0065]
new_molecule类包括属性id、atoms_chains。其中id是对应分子实例的唯一标识。
[0066]
atoms_chains记录了分子内每个原子对应的原子链,用一个三维数组记录,结构是这样的:{[(cell_o,cell_o,0,θ
01
,0,θ
02
),(an1,at1,d
11

11
,d
12

12
,),(an2,at2,d
21

21
,d
22

22
),

,(an
n
,at
n
,d
n1

n1
,d
n2

n2
)],

,[(cell_o,cell_o,0,θ
01
,0,0),(an1,at1,d
11

11
,d
12

12
),(an2,at2,d
21

21
,d
22

22
),

,(an
m
,at
m
,d
m1

m1
,d
m2

m2
)]},其中,第一层数组中的每个数组记录了一条原子链,每一条原子链中的数组记录了这条原子链中的每一个原子的信息。每条原子链中第一个数组记录的是晶胞原点的坐标信息。其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角。原子信息数组第一项an为原子名称,唯一对应分子内的一个原子。第二项为原子的元素类型。第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离。第四项θ
i1
为该原子与前一个和后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0。第五项d
i2
为该原子与前一个原子的原子局部坐标轴中x轴之间的轴距。第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角。
[0067]
原子局部坐标轴确定方法:该原子与前一个原子之间的连线为z轴的负方向。x轴方向为该原子与前一个和后一个原子所在平面垂直的方向。y轴为与z轴、x轴成右手螺旋规则的方向。第一个原子的前一个原子为晶胞原点,最后一个原子的后一个原子为分子内任意一个非骨架原子。
[0068]
原子链确定方法为:
[0069]
1.计算分子内每个原子与晶胞原点之间的距离。选择距离最近的一个原子为起始原子。
[0070]
2.对分子内的每个原子,在分子的拓扑结构中找到一条连接该原子和起始原子的通路,通路的节点是分子内的原子,通路的边是分子内两原子之间的键。
[0071]
优选地,根据下列规则将cif晶体文件读取的数据结构,转化为新数据结构。
[0072]
1.将crystal对象中的晶胞属性和空间群属性直接复制为new_crystal对象中对应的属性。
[0073]
2.对crystal对象中的每一个对应的molecule对象进行如下操作。
[0074]
1)读取molecule对象中的每个atom的分数坐标。按上述原子链确定方法,找出每个原子的原子链,并将原子链存储在三维数组中,存储结构如下。{[(cell_o,cell_o),
(an1,at1),(an2,at2),

,(an
n
,at
n
)],

,[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
m
,at
m
)]}。其中an1为起始原子,an
i
为分子内的任一原子。每个数组都记录了每个原子到起始原子的连接链路。
[0075]
2)计算晶胞原点到第一个原子的向量和晶胞棱a、c的夹角,得到θ
01

02

[0076]
3)遍历这个数组,对每个原子链计算其d
i1

i1
,d
i2

i2
。首先,获取该原子在原子链上前一个和后一个原子的分数坐标,第一个原子的前一个原子为晶胞的原点,最后一个原子的后一个原子为分子内任一一个与该原子和前一个原子不共线的原子。计算该原子距离前一个原子的距离,得到d
i1
。计算该原子与前后原子形成的夹角的度数,得到θ
i1
。按原子局部坐标轴确定方法,确定原子链上每个原子的局部坐标。计算前一个原子的局部x轴与该原子的局部x轴的轴距,得到d
i2
。计算计算前一个原子的局部x轴与该原子的局部x轴的轴间夹角,得到θ
i2

[0077]
4)将这个数组存储为new_molecule对象中的atoms_chains属性。并将new_molecule对象关联到步骤1中的new_crystal对象中。
[0078]
得到了新数据结构下的晶体对象。
[0079]
晶体演化是通过调整晶体内的晶胞,晶胞内分子位置、朝向,分子内柔性键来改变晶体结构,得到目标性质更好的晶体结构。本实施例支持以晶体晶格能为目标函数的演化。具体演化流程如下。
[0080]
1.指定晶胞参数的演化范围。
[0081]
系统提供接口,支持人工输入晶胞参数三组棱长a、b、c及棱间交角α、β、γ的演化范围。输入为一个二维数组[(a
d
,a
u
,a
s
),(b
d
,b
u
,b
s
),(c
d
,c
u
,c
s
),(α
d

u

s
),(β
d

u

s
),(γ
d

u

s
)]。其中a
d
,b
d
,c
d
,为棱长演化范围下限,取值范围是[1%,100%],a
u
,b
u
,c
u
,为棱长演化范围上限,取值范围是[100%,1000%]。其中α
d

d

d
为棱角演化范围下限,取值范围是[

180
°
,0
°
],α
u

u

u
为棱角演化范围上限,取值范围是[0
°
,180
°
]。实际演化过程中,晶胞参数会在(a*a
d
,a*a
u
),(b*b
d
,b*b
u
),(c*c
d
,c*c
u
),(α+α
d
,α+α
u
),(β+β
d
,β+β
u
),(γ+γ
d
,γ+γ
u
)范围内取值。a
s
,b
s
,c
s
为棱长的调整步长,α
s

d

s
为棱角的调整步长。
[0082]
系统可根据需要设置默认参数,系统默认的晶胞参数是[(10%,200%,0.01%),(10%,200%,0.01%),(10%,200%,0.01%),(

10
°
,10
°
,0.01
°
),(

10
°
,10
°
,0.01
°
),(

10
°
,10
°
,0.01
°
)]
[0083]
2.指定柔性键的演化范围。
[0084]
柔性键是分子内可旋转的单键。通常当两个原子之间形成σ键的时候,键两端的基团可以沿着键轴旋转,形成不同的分子构象。
[0085]
本实施例中,系统提供接口,支持人工指定分子柔性键的演化范围。具体流程如下。
[0086]
1)将分子内可旋转的单键两端的原子名称以数组的形式输入系统。如:[(an1,an3),(an7,an
10
)],表示该分子内有两个柔性键,两端原子分别是名称为an1,an3和an7,an
10
的原子。
[0087]
2)对每个柔性键设置旋转范围,输入为一个二维数组[(θ
d1
‑3,θ
u1
‑3,θ
s1
‑3),(θ
d7

10

u7

10

s7

10
)]。其中θ
d1
‑3,θ
d7

10
,为柔性键旋转范围下限,取值范围是
[0088]
[

180
°
,0
°
]。其中θ
u1
‑3,θ
u7

10
,为柔性键旋转范围上限,取值范围是[0
°
,180
°
]。系
统默认柔性键的取值范围是[

180
°
,180
°
]。θ
s1
‑3,θ
s7

10
为柔性键调整步长,默认取值为0.01
°

[0089]
3.输入初始晶体
[0090]
演化输入的初始晶体为经过经过晶体文件转换模块转换后的new_crystal晶体对象。
[0091]
4.计算初始晶体的晶格能。系统支持用力场方法、半经验方法、高精度量化方法计算晶体的能量。也可采用计算化学学科中的标准方法计算晶体能量的方法,常用的力场计算工具有amber、charmm等,半经验等计算工具有dftb、dmacrys,高精度量化方法的计算工具有vasp,crystal09等。
[0092]
5.按预设步长调整晶体的晶胞参数和柔性键的取值。复制一个new_crystal对象,按照晶胞预设的棱长和棱角调整步长值调整晶胞参数,将调整后的参数值直接赋给晶胞参数属性值。然后遍历new_crystal对象的atoms_chains数组,对每条原子链匹配指定的柔性键,如上例中的[(an1,an3),(an7,an
10
)]。如果匹配到原子链中相邻的两个原子名称和顺序与指定的柔性键的原子键名称和顺序相同,则对后一个原子,如上例中的an3,an
10
,所在原子数组的θ
32
,θ
102
,按指定步长调整。
[0093]
6.上个步骤中,每次调整只调整一个参数,默认做正向调整,即在原值基础上增加步长。然后计算调整后的晶体的晶格能。如果调整后的晶体的能量增加,则在下一个调整循环中做负向调整,即在原值基础上减少步长。如果调整后的晶体的能量减少,则在下一个调整循环中继续做争相调整。
[0094]
7.如果调整值超出预设调整边界,则将边界做为调整后的值。
[0095]
8.重复5~7步,直到最低的晶体能量在给定的停止次数下不再增加。默认的停止次数为2000,即在连续2000次迭代内没有能量更低的晶体出现,则停止演化。用户可以手动修改停止次数。
[0096]
本实施例的二次转换从new_crystal对象转换为crystal对象,具体转换方式如下。
[0097]
1.将new_crystal对象中的晶胞属性和空间群属性直接复制为crystal对象中对应的属性。
[0098]
2.对new_crystal对象中的每一个对应的new_molecule对象进行如下操作。
[0099]
1)读取第一条原子链中的晶胞原点数组(cell_o,cell_o,0,θ
01
,0,θ
02
)和初始原子数组(an1,at1,d
11

11
,d
12

12
,)。记初始原子在晶胞内的分数坐标为x,y,z。则x2+y2+z2=d
112
,cosθ
012
=x2/(x2+y2+z2),cosθ
022
=z2/(x2+y2+z2)。解方程可以得到初始原子在晶胞内的分数坐标。
[0100]
2)读取下一个原子数组(an2,at2,d
21

21
,d
22

22
,),记该原子在晶胞内的分数坐标为x,y,z。则x2+y2+z2=d
212
,cosθ
11
=(d
112
+d
212

x2‑
y2‑
z2)/2d
11
d
21
,cosθ
12
=(d
122
+d
222

x2‑
y2‑
z2)/2d
12
d
22
。解方程可以得到该原子在晶胞内的分数坐标。
[0101]
3)读取下一个原子数组,重复上一步,如此迭代可以得到整条原子链中每个原子的分数坐标。
[0102]
4)遍历new_molecule对象中的属性atoms_chains数组。对每条原子链重复上三步的操作,可以得到整个分子内全部原子的分数坐标。
[0103]
3.将分子内的全部原子的原子名称、原子类型、分数坐标填入molecule对象的atoms属性中,就得到了完整的crystal对象。
[0104]
保存,将演化得到的全部晶体存储成文件,供研究和其他用途。具体流程如下。
[0105]
1.用户可以通过接口指定需要保存的晶体结构的id。用户可以指定初始的晶体,但通常会指定演化过程中的任何结构。也可以指定全部演化得到的晶体结构。
[0106]
2.该模块会根据id检索到系统中对应的new_crystal对象。然后调用晶体结构转换模块中new_crystal转换成crystal对象的功能,得到crystal对象。
[0107]
3.该模块接着会将crystal对象的晶胞参数属性unit_cell、空间群属性sym顺序分行写入新的cif文件。然后遍历molecule_ids属性,获取对应的molecule对象,并将每个molecule中的原子数组依次逐行按写入cif文件。
[0108]
4.系统支持直接将cif文件保存在硬盘或其他存储介质中。
[0109]
本发明一实施例的晶体空间结构变换系统,包括:
[0110]
读取模块:读取晶体文件,将晶体文件中的晶胞参数、分子内的原子坐标和空间群信息转换为面向对象的数据结构存储,面向对象的数据结构包括:晶体结构、分子结构,晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性;分子结构包括:对应的分子实例的唯一标识、分子内全部原子的位置信息;
[0111]
转换模块:将面向对象的数据结构转换为新对象数据结构,新对象数据结构包括:新晶体结构、新分子结构,新晶体结构包括:晶体实例的唯一标识、对应的晶胞属性、非对称单元内所有分子的id、晶体实例对应的空间群属性,新分子结构包括:分子内每个原子对应的原子链,将面向对象的数据结构中晶体结构中的晶胞属性和空间群属性复制到新晶体结构中对应属性,读取分子结构中分子内全部原子的位置信息,根据原子的位置信息确定每个原子的原子链;
[0112]
晶体演化模块:计算晶体的晶格能,根据设定步长调整晶体的晶胞属性参数和柔性键取值,按照晶胞预设的棱长和棱角调整步长调整晶胞属性参数,将调整后的参数值赋给晶胞属性参数值,对每条原子链匹配指定的柔性键,根据设定步长进行旋转调整柔性键,每次调整一个参数,计算调整后的晶体晶格能,直至最低的晶体晶格能在设定的停止次数下不再增加,分配id给演化形成新的晶体;
[0113]
二次转换模块:将新对象数据结构转换为面向对象的数据结构;
[0114]
保存模块:将晶胞属性、空间群属性写入新的文件,遍历非对称单元内所有分子的属性,获取对应的分子结构参数,对每个分子结构中的原子数组依次逐行写入文件。
[0115]
本实施例的晶体结构的对应晶胞属性记录对应晶胞的6个参数,三组棱长a、b、c、及棱间夹角α、β、γ,所述分子结构的分子内全部原子的位置信息为二维数组,该二维数组中每一项为一个5维数组,该5维数字第一项为原子的名称,第二项为原子的元素类型,第三至五项为原子在晶胞内的分数坐标。
[0116]
本实施例的新晶体结构包的对应晶胞属性记录对应晶胞的6个参数,三组棱长a、b、c、及棱间夹角α、β、γ。新分子结构用三维数组记录分子内每个原子对应的原子链{[(cell_o,cell_o,0,θ
01
,0,θ
02
),(an1,at1,d
11

11
,d
12

12
,),(an2,at2,d
21

21
,d
22

22
),

,(an
n
,at
n
,d
n1

n1
,d
n2

n2
)],

,[(cell_o,cell_o,0,θ
01
,0,0),(an1,at1,d
11

11
,
d
12

12
),(an2,at2,d
21

21
,d
22

22
),

,(an
m
,at
m
,d
m1

m1
,d
m2

m2
)]},其中第一层数组中的每个数组记录了一条原子链,每一条原子链中的数组记录了这条原子链中的每一个原子的信息,每条原子链中第一个数组记录的是晶胞原点的坐标信息,其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角,原子信息数组第一项an
i
为原子名称,唯一对应分子内的一个原子;第二项为原子的元素类型,第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离;第四项θ
i1
为该原子与前一个原子、和与后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0;第五项d
i2
为该原子与前一个原子局部坐标轴中x轴之间的轴距,第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角。
[0117]
原子局部坐标轴为以该原子与前一个原子之间的连线为z轴的负方向,x轴方向为该原子与前一个和后一个原子所在平面垂直的方向,y轴为与z轴、x轴成右手螺旋规则的方向,第一个原子的前一个原子为晶胞原点,最后一个原子的后一个原子为分子内任意一个非骨架原子。
[0118]
本实施例的原子链:计算分子内每个原子与晶胞原点之间的距离,选择距离最近的一个原子为起始原子,对分子内的每个原子,在分子的拓扑结构中找到一条连接该原子和起始原子的通路,分子内的原子作为通路的节点,分子内两原子之间的键作为通路的边。
[0119]
进一步,本实施例的转换模块还包括:读取与晶体结构对应的分子结构中每个原子的分数坐标,确定每个原子的原子链,并将原子链存储为三维数组中{[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
n
,at
n
)],

,[(cell_o,cell_o),(an1,at1),(an2,at2),

,(an
m
,at
m
)]},其中an1为起始原子,an
i
为分子内的任一原子,每个数组记录每个原子到起始原子的连接链路;计算晶胞原点到第一个原子的向量和晶胞棱a、c的夹角,得到θ
01

02
;遍历该数组,对每个原子链计算其d
i1

i1
,d
i2

i2
;获取该原子在原子链上前一个和后一个原子的分数坐标,第一个原子的前一个原子为晶胞的原点,最后一个原子的后一个原子为分子内任一一个与该原子和前一个原子不共线的原子,计算该原子距离前一个原子的距离,得到d
i1
;计算该原子与前后原子形成的夹角的度数,得到θ
i1
;确定原子链上每个原子的原子局部坐标轴,计算前一个原子的原子局部坐标轴的x轴与该原子的原子局部坐标轴的x轴的轴距,得到d
i2
;计算计算前一个原子的原子局部坐标轴的x轴与该原子的原子局部坐标轴的x轴的轴间夹角,得到θ
i2
;将该数组存储为新分子结构中的分子内每个原子对应的原子链的属性中,并关联到对应的新晶体结构中。
[0120]
进一步,本实施例的演化模块包括:接受晶胞属性参数演化范围的输入或设置,接受柔性键演化范围的输入或设置,接受新对象数据结构,计算晶体的晶格能,复制新晶体结构对象,按照晶胞预设的棱长和棱角调整步长调整晶胞属性参数,将调整后的参数值赋给晶胞属性参数值,然后遍历新晶体结构中的分子内每个原子对应的原子链的对应数组,对每条原子链匹配指定的柔性键,若匹配到原子链中相邻的两个原子名称和顺序与指定的柔性键的原子键名称和顺序相同,则对后一个原子按指定步长调整,每次调整一个参数,默认做正向调整,然后计算调整后的晶体的晶格能,若调整后的晶体的晶格能增加,则下一步调整循环中做负向调整,如果调整后的晶体的晶格能减少则在下一个调整循环中继续做正向调整,若调整值超出预设调整边界,则将边界作为调整后的值,重复调整,直至最低的晶体
晶格能在设定的停止次数下不再增加。优选的,演化模块的演化顺序为先调整晶胞参数,再调整柔性键参数,晶胞参数按a、b、c、α、β、γ顺序进行调整,柔性键按新分子结构中的原子链数组中的顺序进行调整。
[0121]
二次转换模块包括:将新晶体结构中的晶胞属性和空间群属性复制为晶体结构中的对应属性,读取第一条原子链中的晶胞原点数组(cell_o,cell_o,0,θ
01
,0,θ
02
)和初始原子数组(an1,at1,d
11

11
,d
12

12
,),记初始原子在晶胞内的分数坐标为x,y,z,则x2+y2+z2=d
112
,cosθ
012
=x2/(x2+y2+z2),cosθ
022
=z2/(x2+y2+z2),解方程组可获取初始原子在晶胞内的分数坐标;读取下一个原子数组(an2,at2,d
21

21
,d
22

22
,),记该原子在晶胞内的分数坐标为x,y,z,则x2+y2+z2=d
212
,cosθ
11
=(d
112
+d
212

x2‑
y2‑
z2)/2d
11
d
21
,cosθ
12
=(d
122
+d
222

x2‑
y2‑
z2)/2d
12
d
22
,解方程组获取该原子在晶胞内的分数坐标;依次读取下一个原子数组(an
i
,at
i
,d
i1

i1
,d
i2

i2
),重复解方程组x2+y2+z2=d
i12
,cosθ
(i

1)1
=(d
(i

1)12
+d
i12

x2‑
y2‑
z2)/2d
(i

1)1
d
i1
,cosθ
(i

1)2
=(d
(i

1)22
+d
i22

x2‑
y2‑
z2)/2d
(i

1)2
d
i2
,获取原子在晶胞中的分数坐标,其中cell_o表示晶胞原点,θ
01
为晶胞原点到第一个原子的向量和晶胞a棱轴的夹角,θ
02
为晶胞原点到第一个原子的向量和晶胞c棱轴的夹角,原子信息数组第一项an
i
为原子名称,唯一对应分子内的一个原子;第二项为原子的元素类型,第三项d
i1
为距离前一个原子的距离,第一个原子的第三项表示距离晶胞原点的距离;第四项θ
i1
为该原子与前一个原子、和与后一个原子形成的夹角的度数,第一个原子的前一个原子为晶胞的原点,最后一个原子的θ
i1
为0;第五项d
i2
为该原子与前一个原子局部坐标轴中x轴之间的轴距,第六项θ
i2
为该原子与前一个原子局部坐标轴中x轴之间的夹角;如此迭代可以得到整条原子链中每个原子的分数坐标;遍历新分子结构中的分子内每个原子对应的原子链数组,对每条原子链重复上述求解操作,得到整个分子内全部原子的分数坐标,将分子内的全部原子的原子名称、原子类型、分数坐标填入分子结构的分子内全部原子的位置信息属性中,就得到了完整的晶体结构。
[0122]
本实施例的保存模块,将演化得到的全部晶体存储成文件,供研究和其他用途。具体流程如下:
[0123]
用户可以通过接口指定需要保存的晶体结构的id。用户可以指定初始的晶体,但通常会指定演化过程中的任何结构。也可以指定全部演化得到的晶体结构。
[0124]
该模块会根据id检索到系统中对应的new_crystal对象。然后调用晶体结构转换模块中new_crystal转换成crystal对象的功能,得到crystal对象。
[0125]
该模块接着会将crystal对象的晶胞参数属性unit_cell、空间群属性sym顺序分行写入新的cif文件。然后遍历molecule_ids属性,获取对应的molecule对象,并将每个molecule中的原子数组依次逐行按写入cif文件。
[0126]
系统支持直接将cif文件保存在硬盘或其他存储介质中。
[0127]
本发明系统架构采用模型层和控制层分离的架构设计。
[0128]
模型层的数据存储采用直接内存管理的架构,控制层用python开发成便于调用和封装的代码脚本库。
[0129]
本发明可以部署在公有云上、本地集群上,也可以部署在用户的个人电脑上。系统运行软件环境可采用:linux 4以上内核版本,python2.7运行环境。
[0130]
本发明将晶体的参数空间从描述每个原子在晶胞内的分数坐标,转换为描述晶体
内相邻两个原子之间的相对位置,包括相对距离,之间的夹角,和相邻两个分子键之间的轴距和轴间夹角。这样在晶体演化过程中整个参数空间是连续变化的。克服了之前由于参数空间不连续,导致演化过程不能平滑找到局部最优解的问题。这使得使用心得参数空间在找到局部和全局能量最低的晶体结构的过程中,效率有大幅提升,在研究和算法开发方面也更直观。
[0131]
以上述依据本申请的理想实施例为启示,通过上述的说明内容,相关工作人员完全可以在不偏离本项申请技术思想的范围内,进行多样的变更以及修改。本项申请的技术性范围并不局限于说明书上的内容,必须要根据权利要求范围来确定其技术性范围。
[0132]
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd

rom、光学存储器等)上实施的计算机程序产品的形式。
[0133]
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
[0134]
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
[0135]
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1