Exampleofcodemlanalysis~Beginningguide~Codeml是PAML软件包下的一个程序,在估算蛋白编码序列同义替换和非同义替换速率以及检测序列是否经受正选择方面受到广泛的使用。在本节中,我将简单描述一个例子来分析编码序列氨基酸位点是否存在正选择作用。简单流程•以下步骤仅仅是针对于想初步了解codeml使用的朋友设计.且以linux下codeml的运行为例.•1.PAML软件包的安装•2.必需文件的准备•3.程序的运行与结果解释PAML的安装•软件下载:•最新PamlX或Paml4.7.以Paml4.7为例,(PamlX具有图形界面,不详述)•下载后解压.至目标文件夹.文件的准备1.序列比对文件准备要求:采用的是基于密码子的比对(核酸序列先翻译,后比对);核酸序列要保证是3的倍数;序列中不能出现纯数字、不能出现特殊符号(-可以);不能有额外的空格、换行符等等;可用bioedit将编码序列翻译后再进行比对,然后保存成phylip格式,paml可以认识phylip格式。文件的准备2.树文件准备要求:任何可以正确描述序列文件中各序列文件的tree都可以.如果没有可借鉴使用的树,可以用序列文件中序列用Mrbayes,Phyml,PAUP等软件建树.先建立无根树。PhyML产生的树格式可以被PAML识别,PAUP产的树可能由于NEXUS格式复杂,可能不被识别,可用figtree软件转保存成NeWick格式.codeml程序运行•将序列比对文件和树文件同时拷到/paml.4.7/bin文件夹下.•或者确保:•codeml程序文件•codeml.ctl配置文件,比对好的•XXX.phy、序列文件•XXX.tree树文件•四个文件处于同一文件夹中.codeml程序运行•控制文件codeml.ctl参数设置:codeml程序运行seqfile=序列比对文件treefile=树文件outfile=输出文件(任意命名,建议txt后缀便于打开)seqtype=1clock=0(使用无根树需设置为0,具体参见说明书)model=0Nsites=078(0,为单一参数模型。7,8为相似模型,均允许局部替换率可以变化,二者有一个参数差异,其二者结果将用于LRST检验以保证结果的可靠性。其余参数不是很重要,不作改变。具体参见英文说明书.codeml程序运行•客户端打开文件目录•输入:codeml按enter键,程序即开始运行•静待结果。。。。产生11个其它文件codeml程序运行•找到outfile的输出文件,即主要结果输出文件,打开。•当前查看结果方式:A考虑序列整体的dN/dS,请查看Model0中结果。codeml程序运行Yourtargetcodeml程序运行B考虑单个氨基酸是的dN/dS,要先比较Model7和Model8的Lnl值,以确定那一个模型更适合序列,然后再选择该模型的结果。方法与公式LRT=2dl=abs(2X(Lnl7-Lnl8))(abs=绝对值)Step1:打开输出文件,找到Model7,和Model8两个lnL值相减,取绝对值,乘以2举例:2*|-5031.979846-(-5014.578562)|=35(小数点后影响不大)Step2:终端打开PAML附带的Chi2程序,分别输入自由度和刚才得到的数.自由度直接取1(因为M7,M8一个参数差异).在程序端输入:chi2135即出现:df=1prob=0.025347319=2.535e-02得到的p小于0.05则M8结果可靠,可以查看M8结果了。值在这里codeml程序运行PAML采用NEB和BEB分析检测显著性,但是作者推荐参考BEB的结果。M8的正选择位点,带有*号的即是通过检验的且结果显著的正选择位点。位置信息•参考资料:••••