计算化学公社

标题: 用 PyMOL 渲染 HSV 混色模式的 RDG 填色等值面图 [打印本页]

作者
Author:
liyuanhe211    时间: 2019-12-11 20:28
标题: 用 PyMOL 渲染 HSV 混色模式的 RDG 填色等值面图
本帖最后由 liyuanhe211 于 2020-11-12 23:52 编辑

本文未经同意不得转载内容,尤其是专门偷别人东西来发的公众号之类的。可以链接引用。



受益于 Multiwfn 及 Sobereva 的博文,文章中的 RDG 分析越来越常见。大家常使用VMD绘制RDG图。VMD上手容易,可调性极强,但在用 VMD 绘制 RDG 等填色图等值面图的过程中也有一些局限性。主要包括下面几点:(如果有的是我的错误认识,恳请指正)

第一个问题是,VMD 中的 colorbar 混色模式是 RGB linear,即分别对两种颜色的 R,G,B 值做数值线性加权平均。这种混合看起来有道理,但其实是不合理的:

如下图所示,左上角是 VMD 的混色模式,因为人眼对亮度的响应函数大概介于 log() 和 sqrt() 之间,所以计算机对各通道亮度的存储是开根号的,而因为 ( (√a + √b) / 2 )^2 < (a + b)/2,所以线性混合的结果是 RGB 中的某个通道越接近 50-50 混合的地方越暗、越“污”。这一点可以从其去色后的灰度图看出来,图中中上和右上分别时 HSV 和 LAB 下的亮度通道,都可见离红绿蓝基准点越远的地方越黑。
(, 下载次数 Times of downloads: 63)


这有两个解决方案,一是先将颜色取平方、加权平均、再开方,得到的结果如“Square”所示,其 LAB-L 通道基本平衡,HSV-V 通道也平均化了许多。
另一种方案是用 HSV-mixing,这样混合出来的HSV-V通道是严格平均化的(不过 LAB-L 通道显示中间较亮,这是考虑人眼对绿色的感知比红、蓝更加敏感,所以有时人眼“感觉”靠中间的位置混色较多的地方稍亮一些)。


第二个问题是,VMD默认三种颜色中的中间一种对应的数值是 min,max 的中点。而RDG图的填色通常是自-0.04至0.02,VMD会将绿色放置在正中央即-0.01的位置上,相对于0点(黑线处)有偏移,这使得一些接近“中性”的范德华作用被显示成略微排斥作用的棕黄色,影响分析。

(, 下载次数 Times of downloads: 64)


为了解决这些缺点,研究了一下用 PyMOL 绘制类似的图,效果不错。写了一个比较方便的脚本。可见结合脚本用PyMOL绘制可以:
(, 下载次数 Times of downloads: 69)


下图体现绿色定位不同造成的差异(下图中大片的RDG等值面按经验判断应该都是“一般的”范德华相互作用,将绿色向正值方向偏移后,RDG更符合化学直观。这两图做的时候没注意两边端点的值稍有区别,不过这不重要,造成显著差别的还是绿色是否在中心。):


(, 下载次数 Times of downloads: 68)


所用脚本如下:

(, 下载次数 Times of downloads: 156)


本脚本只在Windows 10, PyMOL-2.3.4.121 x64 portable (及其自带的python 3.7)下测试过。

使用其他操作系统没有显见的问题,但我个人没有测试过;如果使用的是较旧的 PyMOL 便携版,至少要求是配 Python 3 的。使用时请注意调用的Python是否正确。用便携版是因为它和它对应的Python在一起。PyMOL可以申请免费的学生Lisence (https://pymol.org/2/, Windows-zip file)。

脚本解压后有5个文件(一套 .bat, .py, .ini,和两个带MultipleCube的文件),请将这5个文件放在 PyMOLWin.exe 所在的文件夹下,配置 ini 文件后运行 Draw_RDG_with_PyMOL.bat 文件。注意安装路径不能有非ASCII字符


ini 文件中有相应的配置。文件中有比较详细的说明,解释如下四个选项:



使用时直接运行 .bat 文件

脚本首先询问是否使用 .ini 文件中定义的默认着色方式,如果使用则之间按回车,如果不使用则输入任意字符后回车进入定义色标的功能,可以模仿格式单独输入定义。

  1. Default color scheme:
  2. -------------------------------------------------------------
  3.     -0.035       -0.0      0.015
  4.     0000FF     00FF00     FF0000
  5. -------------------------------------------------------------

  6. Accept default gradient color scheme? (Enter for accept, enter any other character for user-defined gradient.)

  7. Default scheme accepted.


  8. --------------------------
复制代码
随后程序需要获取三个文件,RDG 的 .cub 文件,sign(λ2)*ρ 的 .cub 文件,还有包含分子结构(尤其是键级信息)的 .mol2 文件。注意路径均不能有非ASCII字符。


文件路径可以复制或拖拽。(注意首先提供的 cube 是 RDG 的cube,如果写反成先给了 sign(λ2)*ρ 的 cube 文件将显示不出任何等值面。)


如果文件名是 XXX1.cub,XXX2.cub 的两个 cub, 输入其中一个文件脚本会自动找到另一个,直接回车即可。

  1. Getting func1.cub, func2.cub, and molecule.mol2.
  2. Paste the path of RDG cube file (or drag the file in):D:\func2.cube

  3. RDG cube file: D:\func2.cube


  4. Is this your sign(λ2)*ρ cube file (Enter to confirm, enter any other character to refuse):

  5.    D:\func1.cube

  6. Sign(λ2)*ρ cube file: D:\func1.cube


复制代码
程序随后会生成一个以“.structure.cube”结尾的文件,这个文件只包含 cub 文件中的坐标,不包含格点数据。用户应用 GaussView 打开“xxxx.structure.cube”后修改键级,另存为mol2文件后回车。


  1. A small cube file is generated for you to load it into GaussView. You can modify the bond order, then convert it to mol2:
  2. D:/func2.structure.cube
  3. Paste the path of molecule cube file (or drag the file in). Press enter for default [D:/func2.structure.mol2]:
复制代码
如果配置无误,脚本会自动启动 PyMOL,并显示完整的 RDG 填色等值面图和对应格式的分子。对较大的Cube文件,图形化窗口可能会无响应一会儿。


确认 PyMOL 显示无误,可以用 Pov-Ray (File - Export Image as - POV-Ray) 或 PyMOL 自带的渲染器(如下图)渲染为高清、透明背景图片。


(, 下载次数 Times of downloads: 59)

另外文件夹下有一个Draw_RDG_with_PyMOL_MultipleCube.bat文件,可以通过它载入多个等值面文件,但都使用同一套着色cube。其目的是为了支持这一帖子:http://bbs.keinsci.com/thread-16243-1-1.html。使用方法与上类似,一看就知道差别。


PyMOL 相比 VMD 有其优势,但也有其局限性,比如界面远不如 VMD 直观,学习曲线比较陡峭,其灵活性很高但有很多操作依赖 Python 命令等。可结合各自软件的优势使用。欢迎批评、讨论、捉虫。


(需要补充一点,文中“批判”了VMD的混色有问题,但其实PyMOL的默认混色与VMD存在同样的问题,所以如果大家用PyMOL的默认设置填色,其会和VMD一样“污”。只不过PyMOL里可以定义任意多的色度节点及节点对应的数值(而VMD只能定义起点、终点和三个颜色),所以我写脚本使用脚本自定义的混色方式定义了(默认值)1000个点的色度曲线,这样每个色度节点足够接近时,程序内部用什么混色方式就不再重要了。)




作者
Author:
sobereva    时间: 2019-12-13 23:28
好文,链接已加入下文,之后在Multiwfn培训班里也介绍一下
用Multiwfn+VMD做RDG分析时的一些要点和常见问题
http://sobereva.com/291http://bbs.keinsci.com/thread-1206-1-1.html
作者
Author:
Peter_zhong    时间: 2020-1-2 09:49
老师好,您文中说:“本脚本只在Windows 10, PyMOL-2.3.4.121 x64 portable (及其自带的python 3.7)下测试通过”。这里明确了别的系统都不可以是吗?我笔记本、台式都是win7
作者
Author:
liyuanhe211    时间: 2020-1-2 18:59
Peter_zhong 发表于 2020-1-2 09:49
老师好,您文中说:“本脚本只在Windows 10, PyMOL-2.3.4.121 x64 portable (及其自带的python 3.7)下测 ...

不是,其他系统理论上都可以,只是仅在Win10测试过。
作者
Author:
Peter_zhong    时间: 2020-1-2 19:24
liyuanhe211 发表于 2020-1-2 18:59
不是,其他系统理论上都可以,只是仅在Win10测试过。

谢谢老师我改天试试
作者
Author:
liyuanhe211    时间: 2020-2-7 09:23
更新了一个版本,新的文件夹下有一个Draw_RDG_with_PyMOL_MultipleCube.bat文件,可以通过它载入多个等值面文件,但都使用同一套着色cube。其目的是为了支持这一帖子:http://bbs.keinsci.com/thread-16243-1-1.html。使用方法与上类似,一看就知道差别。
作者
Author:
zsu007    时间: 2020-2-7 12:15
好物,谢谢分享!
作者
Author:
wuzhiyi    时间: 2020-2-26 18:46
请教一下老师 我在osx/py3下运行了这个脚本 但是显示
    RDG_cube_object_name = proper_object_name(filename_class(RDG_cube).name_stem)[-20:] + "_RDG"
NameError: name 'proper_object_name' is not defined
想问问proper_object_name是什么啊?
作者
Author:
wuzhiyi    时间: 2020-2-26 19:01
wuzhiyi 发表于 2020-2-26 18:46
请教一下老师 我在osx/py3下运行了这个脚本 但是显示
    RDG_cube_object_name = proper_object_name(fil ...

好像删掉就可以正常运行了
作者
Author:
liyuanhe211    时间: 2021-3-5 21:14
jitou11 发表于 2021-3-5 20:25
感谢您提供脚本。
我有个问题,现在Multiwfn已经支持独立梯度模型(IGM),也能生成类似的cube ...

自已定义恰当的染色坐标就可以了
作者
Author:
qq1063906085    时间: 2022-4-13 21:10
jitou11 发表于 2021-3-5 20:25
感谢您提供脚本。
我有个问题,现在Multiwfn已经支持独立梯度模型(IGM),也能生成类似的cube ...

您好,请问您是怎么操作的呢?我载入dg.cub, dg_intra.cub, dg_inter.cub 和 sl2r.cube, sl2r.structure.mol2后,没有出现等值面,只有一个结构。
作者
Author:
qq1063906085    时间: 2022-4-15 10:45
jitou11 发表于 2022-4-13 21:46
很久以前弄得,现在忘得很干净
我试着弄了回,等值面很顺利就出来了,可能你cube文件没选对,或者等 ...

谢谢您的回复。我自己试出来了。把文件 “Draw_RDG_with_PyMOL.ini” 中的 isovalue=0.5 改为 isovalue=0.004。




欢迎光临 计算化学公社 (http://bbs.keinsci.com/) Powered by Discuz! X3.3