24小时热门版块排行榜    

查看: 655  |  回复: 0

endlesslov

新虫 (初入文坛)

[交流] 计算化学多任务及数据提取 – perl程序的应用

有时,我们需要进行较为重复的多任务计算并从输出文件中提取数据。例如一维和二维势能面计算,可能多达几千个任务。所以,不可能每个任务都由手工操作,一定要通过自动化的程序实现。Perl语言的文档数据处理极为强大,易学易用,且已内嵌到Linux中(windows需安装程序)。这里通过一个例子,达到抛砖引玉的作用。即使从未接触过perl,也能迅速开始计算工作。当然,如果需要更多,还需对perl多加学习。
这是一个一维势能面计算,原始g09输入文件m062x.com中的zzz为势能面的一维变量。所以在循环中(变量为$step),每一次将原始输入文件复制为新文件,并将zzz替换为$step,然后计算。这是gaussian09的例子,当然可以改成任何其它计算程序。最后从g09输出文件提取能量数值并写入表格 m062x.summary。
最后,感谢Alex最初提供给我一个例子,使我进入perl应用的领域,极大地提高了效率。

#!/usr/bin/perl -w

# MODULES
# -----------------------------------------------
use strict;
use sigtrap;
use diagnostics;
use File::Copy;
# -----------------------------------------------

my $summary = "m062x.summary";
open (SUM, "> $summary" or die "Cannot open $summary : $!\n";

printf SUM "# STEP\t\t\t\tEnergy\n";

foreach my $step ('0.0001','0.25','0.50','0.75','1.00','1.25','1.50','1.75','2.00') {

      printf SUM "\t\%16.8E", $step;

      my $origfname = "m062x.com";  
      my $newfname  = "m062x-$step.com";
      my $newfnamet = "m062x-$step.log";

      copy($origfname, $newfname) or die "Copy failed: $!";
      system("perl -p -i -e s/'zzz'/$step/g $newfname";

      my $return = system("g09 $newfname 2>&1";
      die "System failed ($return)\n\n" if ($return != 0);

                my $ener;
                # EXTRACT INFO FROM OUTPUT
                open (OUT, "< $newfnamet" or die "Cannot open $newfnamet : $!\n";
                while (<OUT> {
                      $ener = (split /\s+/)[5] if (/SCF Done:/);
                }
                close OUT;
                printf SUM "\t\%16.8E", $ener;

                printf SUM "\n";

}


# -----------------------------------------------

exit 0;

转载自 http://blog.sciencenet.cn/blog-2854406-1076151.html
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 endlesslov 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿南航材料专317分求调剂 +3 炸呀炸呀炸薯条 2026-03-23 3/150 2026-03-23 20:47 by pswait
[考研] 环境学硕288求调剂 +7 皮皮皮123456 2026-03-22 7/350 2026-03-23 20:47 by baobaoye
[考研] 求调剂一志愿武汉理工大学材料工程(085601) +3 WW.' 2026-03-23 5/250 2026-03-23 17:18 by 枫翼ljj
[考研] 一志愿南京理工大学085701资源与环境302分求调剂 +5 葵梓卫队 2026-03-18 7/350 2026-03-23 16:26 by lingjue
[考研] 317求调剂 +12 申子申申 2026-03-19 18/900 2026-03-22 22:23 by luoyongfeng
[考研] 319求调剂 +4 小力气珂珂 2026-03-20 4/200 2026-03-22 15:53 by ColorlessPI
[考研] 260求调剂 +3 朱芷琳 2026-03-20 4/200 2026-03-22 15:12 by 朱芷琳
[考研] 0703化学调剂 +4 妮妮ninicgb 2026-03-21 4/200 2026-03-21 18:39 by 学员8dgXkO
[考研] 278求调剂 +9 烟火先于春 2026-03-17 9/450 2026-03-21 17:47 by 学员8dgXkO
[考研] 0703化学297求调剂 +3 Daisy☆ 2026-03-20 3/150 2026-03-21 17:45 by ColorlessPI
[考研] 求调剂 +3 .m.. 2026-03-21 4/200 2026-03-21 16:25 by barlinike
[考研] 材料学学硕080502 337求调剂-一志愿华中科技大学 +4 顺顺顺mr 2026-03-18 5/250 2026-03-21 10:22 by luoyongfeng
[考研] 303求调剂 +5 睿08 2026-03-17 7/350 2026-03-21 03:11 by JourneyLucky
[考研] 一志愿华中科技大学,080502,354分求调剂 +5 守候夕阳CF 2026-03-18 5/250 2026-03-21 01:06 by JourneyLucky
[考研] 304求调剂 +6 曼殊2266 2026-03-18 6/300 2026-03-21 00:32 by JourneyLucky
[考研] 288求调剂 +16 于海海海海 2026-03-19 16/800 2026-03-20 22:28 by JourneyLucky
[考研] 求调剂 +3 eation27 2026-03-20 3/150 2026-03-20 19:32 by JourneyLucky
[考研] 0856调剂,是学校就去 +8 sllhht 2026-03-19 9/450 2026-03-20 14:25 by 无懈可击111
[考研] 085600材料与化工调剂 324分 +10 llllkkkhh 2026-03-18 12/600 2026-03-19 14:33 by llllkkkhh
[考研] 0703化学调剂 +5 pupcoco 2026-03-17 8/400 2026-03-19 13:58 by houyaoxu
信息提示
请填处理意见