deepwalk源码解读8: scoring.py

此博客将对walkwalk的scoring.py源码进行解读,但具体内容待后续补充。

这里留待以后来写

这个错误提示: ``` TypeError: __init__(): incompatible constructor arguments. ``` 表示你调用 `DockingHighRes(scorefxn)` 时,**参数顺序或类型不匹配**。根据错误信息,`DockingHighRes` 的构造函数需要 **先提供 `rb_jump`(刚体跳跃编号)**,然后再是 `scorefxn` 和可选的 `scorefxn_pack`。 --- ### ✅ 正确使用 `DockingHighRes` 构造函数 你需要传入一个整数 `rb_jump`,它表示在 Pose 中哪一条链通过跳跃连接(通常为 1 表示配体相对于受体的移动)。如果你不确定,可以设为默认值 `1`。 #### ✅ 修改后的代码示例: ```python from pyrosetta import init, pose_from_pdb from pyrosetta.rosetta.protocols.docking import DockingProtocol, DockingHighRes from pyrosetta.rosetta.core.scoring import get_score_function # 初始化 PyRosetta init() # 加载两个蛋白结构作为受体和配体 pose_receptor = pose_from_pdb("protein1.pdb") pose_ligand = pose_from_pdb("protein2.pdb") # 创建评分函数 scorefxn = get_score_function() # 创建高分辨率对接协议:必须指定 rb_jump 和 scorefxn rb_jump = 1 # 刚体跳跃编号,通常为1 docking_highres = DockingHighRes(rb_jump, scorefxn) # 设置对接流程 docking_protocol = DockingProtocol() docking_protocol.set_docking_prot(docking_highres) docking_protocol.set_num_cycles(10) # 设置采样次数 # 执行对接 print("开始对接...") docked_pose = docking_protocol.apply(pose_receptor, pose_ligand) # 输出结果 print("保存对接结果...") docked_pose.dump_pdb("docked_result.pdb") ``` --- ### 🔍 常见原因总结: - `DockingHighRes()` 构造函数需要 **第一个参数是 `rb_jump`**,不能直接只传 `scorefxn`。 - 如果你省略了 `rb_jump` 参数,就会出现此类型不匹配错误。 - 多数情况下,对接系统中使用 `rb_jump=1` 即可。 ---
评论 5
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值