24小时热门版块排行榜    

查看: 317  |  回复: 2
【奖励】 本帖被评价2次,作者pumbaa增加金币 2
当前主题已经存档。

pumbaa

金虫 (初入文坛)


[资源] 【讨论】关于hyperchem自动获取参数


使用hyperchem软件计算分子的描述符参数是比较简单的一件事,但是如果要计算很多的分子就必然需要能够自动计算并获取参数。我尝试使用Excel的vba功能通过DDE(动态数据交互)调用hyperchem,在该软件的安装目录的DirHyperchem/CDK/excel下有一个例子Hyper_VBA.xls,我在其基础上做了改进,代码如下:
Private Const n = 5, molpath$ = "C:\Hyper80\Samples\Aromatic\", hcpath$ = "C:\Hyper80\Program\"
Dim Channel, NewChan, wsn$, wbn$, datreq$(n)
Public Sub Calc()
On Error GoTo ErrorHandler
    datreq$(1) = "total-energy"
    datreq$(2) = "stretch-energy"
    datreq$(3) = "bend-energy"
    datreq$(4) = "torsion-energy"
    datreq$(5) = "nonbond-energy"
    Range("A2".Select   
    wsn$ = ActiveSheet.Name         ' Gets the names of the active worksheet and workbook
    wbn$ = ActiveWorkbook.Name
    MsgBox "Make sure this is the correct path of HyperChem & the needed files:" & Chr(13) & Chr(13) & hcpath$ + "chem.exe" & Chr(13) & "" & molpath$ & "filename.hin"
    Shell hcpath$ + "chem.exe", 6     '6 means non-selected iconized window.
    Channel = Application.DDEInitiate("HyperChem", "System"
###   NewChan = Application.DDEInitiate("HCQSAR", "System"
    Application.DDEExecute Channel, "[query-response-has-tag(no)]"
###    Application.DDEExecute NewChan, "[qsar-property logp]"
    CurrentCell = ActiveCell.FormulaR1C1
    Do While Not CurrentCell = ""
'Reads the molecule into the HyperChem and switches to Molecular Mechanic Calculation
        Application.DDEExecute Channel, "[file-format(hin)][open-file(" + molpath$ & Selection() & ".hin)]"
        Application.DDEExecute Channel, "[calculation-method molecular-mechanics]"
        Application.DDEExecute Channel, "[molecular-mechanics-method mm+]"
        Application.DDEExecute Channel, "[optim-algorithm polakribiere]"
        Application.DDEExecute Channel, "[optim-convergence 0.1]" '收敛标准
    Application.DDEExecute Channel, "[optim-max-cycles 100]" '最大优化回数
    Application.DDEExecute Channel, "[do-optimization]"
        Application.DDEExecute Channel, "[do-single-point]"        
###     Application.DDEExecute NewChan, "[do-calculation]"
###     Application.DDERequest NewChan, "[QSARResult]"
            For ci = 1 To n
                ActiveCell.Offset(rowOffset:=0, columnOffset:=ci).Value = Application.DDERequest(Channel, datreq$(ci))
            Next
        ActiveCell.Offset(rowOffset:=1, columnOffset:=0).Select
        CurrentCell = ActiveCell.FormulaR1C1
    Loop
    Application.DDEExecute Channel, "[menu-file-exit]"
    Application.DDETerminate Channel
Exit Sub

ErrorHandler:    ' Error-handling routine.
    Dim Msg As String
    Dim Style, Response   
    Msg = "Error # " & Str(Err.Number) & " was generated by " _
     & Err.Source & Chr(13) & Err.Description _
     & Chr(13) & Chr(13) & "Resume?"
    Style = vbYesNo + vbCritical + vbDefaultButton2   
    Response = MsgBox(Msg, Style, "Error", Err.HelpFile, Err.HelpContext)   
    If Response = vbYes Then: Resume   
End Sub
不过很可惜,我始终不能调用QSAR计算模块,虽然我参照其文档使用了Application.DDEInitiate("HCQSAR", "System"(相关语句在代码中前面标示了###),运行时总是体现“不问访问远程数据”的诡异错误。
其中excel中内容为:
Molecule        Total        Stretch        Bend        Torsion        vdW
benzene
在此我仅作为抛砖引玉了,盼望有高人解决!!


[ Last edited by zdhlover on 2009-11-15 at 13:36 ]
回复此楼

» 猜你喜欢

» 本主题相关商家推荐: (我也要在这里推广)

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

samtyty

铁杆木虫 (著名写手)


★★★★★ 五星级,优秀推荐

这个要支持的,继续研究啊
2楼2009-06-07 16:16:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zeoliters

木虫 (正式写手)


★★★★★ 五星级,优秀推荐

优秀推荐
3楼2009-06-07 20:44:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 pumbaa 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 环境工程调剂 +6 大可digkids 2026-03-16 6/300 2026-03-16 17:16 by barlinike
[考研] 0703化学调剂 +6 妮妮ninicgb 2026-03-15 9/450 2026-03-16 16:40 by houyaoxu
[考研] 材料与化工求调剂 +3 为学666 2026-03-16 3/150 2026-03-16 15:09 by 加号+
[考研] 材料与化工专硕调剂 +3 heming3743 2026-03-16 3/150 2026-03-16 15:05 by peike
[考研] 274求调剂 +4 时间点 2026-03-13 4/200 2026-03-15 15:29 by Rambo13
[考研] 材料与化工 323 英一+数二+物化,一志愿:哈工大 本人本科双一流 +4 自由的_飞翔 2026-03-13 5/250 2026-03-14 19:39 by hmn_wj
[基金申请] 现在如何回避去年的某一个专家,不知道名字 +3 zk200107 2026-03-12 6/300 2026-03-14 17:13 by zk200107
[基金申请] 有必要更换申报口吗 20+3 fannyamoy 2026-03-11 3/150 2026-03-14 00:52 by zhanghaozhu
[考研] 求调剂,一志愿江南大学环境工程085701 +3 Djdjj12 2026-03-10 4/200 2026-03-14 00:31 by JourneyLucky
[考研] 279求调剂 +3 抓着星星的女孩 2026-03-10 3/150 2026-03-13 23:47 by userper
[考研] 26调剂/材料/英一数二/总分289/已过A区线 +6 步川酷紫123 2026-03-13 6/300 2026-03-13 21:59 by 星空星月
[考研] 290求调剂 +9 ADT 2026-03-11 9/450 2026-03-13 21:55 by JourneyLucky
[考研] 工科,求调剂 +3 我887 2026-03-11 3/150 2026-03-13 21:39 by JourneyLucky
[考研] 281求调剂 +9 Koxui 2026-03-12 11/550 2026-03-13 20:50 by Koxui
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 08食品或轻工求调剂,本科发表3篇sci一区top论文,一志愿南师大食品科学与工程 +3 我是一个兵, 2026-03-10 3/150 2026-03-13 10:21 by Yuyi.
[考研] 321求调剂(食品/专硕) +3 xc321 2026-03-12 6/300 2026-03-13 08:45 by xc321
[考研] 081200-11408-276学硕求调剂 +3 崔wj 2026-03-12 4/200 2026-03-12 19:33 by 求调剂zz
[考研] 研究生招生 +3 徐海涛11 2026-03-10 7/350 2026-03-12 14:26 by 徐海涛11
[考研] 085602化工求调剂 +7 董boxing 2026-03-10 7/350 2026-03-10 17:07 by BruceLiu320
信息提示
请填处理意见