关于Primer3的版权:
1 使用Primer3大致分为两类人:(1)第一类人为直接使用者,使用Primer3,一定程度上要求引用上述文献;(2)程序员,当将Primer3的源代码加入到你的程序中时,要遵循GPL2.如果只是调用Primer3,则不作要求。
在UNIX/LINUX上安装Primer3
12345678 $ unzip primer3-.tar.gz$ tar xvf primer3-.tar$ cd primer3-/src$ make all# You should have created executables primer3_core, ntdpal,# olgotm, and long_seq_tm_test$ make test# You should not see 'FAILED' during the tests.
如果perl命令不是perl,而是诸如perl5,则需要修正test/文件夹中的Makefile.
调用 Primer3_core
基本用法
1234 primer3_core [ -format_output ] [ -default_version=1|-default_version=2 ] [ -io_version=3|-io_version=4 ] [ -p3_settings_file= ] [ -echo_settings_file ] [ -strict_tags ] [ -output= ] [ -error= ] [ input_file ]
如果没有input file,则 primer3_core 从标准输入读取数据。
命令参数
123456789101112131415161718192021 -about 显示primer3版本号并退出-default_version=n 默认设置为n=2,让primer3使用最新的默认设置;n=1则让程序使用 2.23 或之前版本的设置-format_output 让 primer3_core 产生人类易读的结果,否则产生机器易读的结果。-strict_tags 要求严格的标签。如果设置文件中的标签不能被机器识别,则产生重大错误。-p3_settings_file=file_path 指定primer_core的设置文件,该设置文件的设定取代默认设置。当然,input file的设置也能取代这个文件的设置。-echo_settings_file 打印出p3_settings_file中的设置信息。如果没有指定设置文件,或含有-format_output,则该参数失效。-io_version=n n=3时,软件向低版本兼容;n=4是默认设置,能使用2.0版本和以后版本的一些新功能。-output=file_path 指定输出文件路径,如果不指定,则输出到标准输出。-error=file_path 指定错误信息输出路径,如果不指定,则输出到stderr中。
输入和输出的规则
默认设置下,primer3的输入文件为Boulder-IO格式的,该格式有利于程序间的相互交流。同时输出文件的格式也为Boulder-IO的。该文件格式是文本形式的,每一个引物设计的记录的结尾以“=\n”进行分隔。每个记录由多个标签和对应的值构成。例如:
12345678910111213141516 SEQUENCE_ID=exampleSEQUENCE_TEMPLATE=GTAGTCAGTAGACNATGACNACTGACGATGCAGACNACACACACACACACAGCACACAGGTATTAGTGGGCCATTCGATCCCGACCCAAATCGATAGCTACGATGACGSEQUENCE_TARGET=37,21PRIMER_TASK=genericPRIMER_PICK_LEFT_PRIMER=1PRIMER_PICK_INTERNAL_OLIGO=1PRIMER_PICK_RIGHT_PRIMER=1PRIMER_OPT_SIZE=18PRIMER_MIN_SIZE=15PRIMER_MAX_SIZE=21PRIMER_MAX_NS_ACCEPTED=1PRIMER_PRODUCT_SIZE_RANGE=75-100P3_FILE_FLAG=1SEQUENCE_INTERNAL_EXCLUDED_REGION=37,21PRIMER_EXPLAIN_FLAG=1=
IO-version
primer3发布2.0后,许多的Boulder-IO的标签有了变动,而且新增了许多标签。标签分三类:分别以SEQUENCE_, PRIMER_ 和 P3_开头。关于标签的变动,具体参考本文开头的参考网址。
SEQUENCE 标签
SEQUENCE_ID (string; default empty)
1 作为序列的名称,为序列的简要描述
SEQUENCE_TEMPLATE (nucleotide sequence; default empty)
12 进行引物设计的模板琏,方向必须是从5'到3'。碱基大小写都行,但要注意PRIMER_LOWERCASE_MASKING标签的设定。
SEQUENCE_INCLUDED_REGION (interval list; default empty)
12 该标签的值为:<tt><em><start></em></tt>,<tt><em><length></em></tt>。即在从序列的第<tt><em><start></em></tt>位点的碱基开始,到往后<tt><em><length></em></tt>长度的子序列中设计引物。
SEQUENCE_TARGET (interval list; default empty)
12 该标签的值为:<tt><em><start></em></tt>,<tt><em><length></em></tt>。即从序列的第<tt><em><start></em></tt>位点的碱基开始,到往后<em><length></em>长度的区域是要扩增的目的片段,设计的引物必须在此区域的侧翼。<tt></tt>
SEQUENCE_EXCLUDED_REGION (interval list; default empty)
12 该标签的值为:<tt><em><start></em></tt>,<tt><em><length></em></tt>。设计引物时要避开此段子序列区域。比如此区域含有诸如ALUs或者LINEs等重复序列时。
SEQUENCE_PRIMER_PAIR_OK_REGION_LIST (semicolon separated list of integer “quadruples”; default empty)
12345678 该标签的值为多个,值和值之间用“;“隔开,单个值为:<tt><em><left_start></em></tt>,<tt><em><left_length></em></tt>,<tt><em><right_start></em></tt>,<tt><em><right_length></em></tt>。比如:SEQUENCE_PRIMER_PAIR_OK_REGION_LIST=100,50,300,50 ; 900,60,, ; ,,930,100表明有引物设计有三种选择:左引物在100~150bp区间进行设计,右引物在300~350bp的区间进行设计;左引物在900~960bp区间进行设计,右引物随意;右引物在930~1030bp区间进行设计,左引物随意。
SEQUENCE_OVERLAP_JUNCTION_LIST (space separated integers; default empty)
123456789101112131415161718192021 引物设计时,左引物或右引物必须有一个和指定的位点重叠。和PRIMER_MIN_3_PRIME_OVERLAP_OF_JUNCTION标签和PRIMER_MIN_5_PRIME_OVERLAP_OF_JUNCTION共同完成设置。For example:SEQUENCE_OVERLAP_JUNCTION_LIST=20# 1-based indexesPRIMER_MIN_3_PRIME_OVERLAP_OF_JUNCTION=4template: atcataggccatgcctgagc^gctacgactok ...gagc^gcta-3'(left primer)not ok ...gagc^gct-3' (left primer)ok 3'-ctcg^cgat...(right pimer)not ok3'-tcg^cgat...(right primer)PRIMER_MIN_5_PRIME_OVERLAP_OF_JUNCTION=5ok 5'-tgagc^gccg...(left primer)not ok5'-gagc^gccg...(left primer)ok ...tgagc^gctac-5' (right primer)not ok ...tgagc^gcta-5'(right primer)
SEQUENCE_INTERNAL_EXCLUDED_REGION (interval list; default empty)
1 该标签的值为:<tt><em><start></em></tt>,<tt><em><length></em></tt>。中间oligos的设计避开此段子序列。
SEQUENCE_PRIMER (nucleotide sequence; default empty)
12 该标签的值为左引物序列,该序列必须是SEQUENCE_TEMPLATE的一段子序列;程序运行时会检查该子序列并在其附近设计右引物或中间oligos.
SEQUENCE_INTERNAL_OLIGO (nucleotide sequence; default empty)
12 该标签的值为中间oligo序列,该序列必须是SEQUENCE_TEMPLATE的一段子序列;程序运行时会检查该子序列并在其附近设计左右引物。
SEQUENCE_PRIMER_REVCOMP (nucleotide sequence; default empty)
12 该标签的值为右引物序列,该序列必须是SEQUENCE_TEMPLATE的一段反向互补子序列;程序运行时会检查该子序列并在其附近设计左引物。
SEQUENCE_START_CODON_POSITION (int; default -1000000)
12345 标记起始密码子的第一个碱基位点,从而让primer3在起始密码子的左边设计左引物,只有在必要时才在起始密码子的右边设计左引物。可以设置为负数,表示起始密码子在整条序列不可见的左边。如果该值为非负数且该位点处的碱基不是ATG,则primer3会发出一个错误。如果值小于或等于-10^6,则忽略该参数。primer3从起始密码子开始扫描,直到获得一个终止密码子,理想状况下设计的右引物结束于该终止密码子或其后的碱基。
SEQUENCE_QUALITY (space separated integers; default empty)
1 该标签的值是一系列的以空格隔开的碱基质量值,每一个碱基质量值对应着模板琏上的碱基。
SEQUENCE_FORCE_LEFT_START (int; default -1000000)
12 强制左引物的5'端从指定的位点开始,不管是否违背了一些其它的条件。默认值表示左引物的起始位点是任意位置。
SEQUENCE_FORCE_LEFT_END (int; default -1000000)
12 强制左引物的3'端到指定位点结束,不管是否违背了一些其它的条件。默认值表示左引物的结束位点是任意位置。
SEQUENCE_FORCE_RIGHT_START (int; default -1000000)
12 强制右引物的5'端从指定的位点开始,不管是否违背了一些其它的条件。默认值表示左引物的起始位点是任意位置。
SEQUENCE_FORCE_RIGHT_END (int; default -1000000)
12 强制右引物的3'端到指定位点结束,不管是否违背了一些其它的条件。默认值表示左引物的结束位点是任意位置。
全局输入标签 PRIMER_ Tags
PRIMER_TASK (string; default generic)
该标签要求primer3来进行什么类型的工作,其有效的值有:
generic
1 经典的primer3任务,设计引物对
Primer3的主页:http://primer3.sourceforge.net/。主页上能看到对于Primer3的简要介绍和下载通道。
Primer3的网页版:http://primer3.wi.mit.edu/。
Primer3的源代码:http://sourceforge.net/projects/primer3/.
Primer3文献:http://purl.com/STEVEROZEN/papers/rozen-and-skaletsky-2000-primer3.pdf
Steve Rozen and Helen J. Skaletsky (2000) Primer3 on the WWW for general users and for biologist programmers. In: Krawetz S, Misener S (eds) Bioinformatics Methods and Protocols: Methods in Molecular Biology. Humana Press, Totowa, NJ, pp 365-386
参考自:http://primer3.wi.mit.edu/primer3web_help.htm
原文链接:http://www.hzaumycology.com/chenlianfu_blog/?p=284