亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? trees.c

?? 生物序列比對程序clustw的源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
	if ((bootstrap==BS_NODE_LABELS) && (boot_totals[start_row]>0))			fprintf(tree,"%d",(pint)boot_totals[start_row]);		return(start_row);}void print_phylip_tree(char **tree_description, FILE *tree, sint bootstrap){	sint old_row;		if(last_seq-first_seq+1==2) {		fprintf(tree,"(%s:%7.5f,%s:%7.5f);",names[first_seq],tmat[first_seq][first_seq+1],names[first_seq+1],tmat[first_seq][first_seq+1]);		return;	}	fprintf(tree,"(\n"); 	old_row=two_way_split(tree_description, tree, last_seq-first_seq+1-2,1,bootstrap);	fprintf(tree,":%7.5f",left_branch[last_seq-first_seq+1-2]);	if ((bootstrap==BS_BRANCH_LABELS) && (old_row>0) && (boot_totals[old_row]>0))		fprintf(tree,"[%d]",(pint)boot_totals[old_row]);	fprintf(tree,",\n");	old_row=two_way_split(tree_description, tree, last_seq-first_seq+1-2,2,bootstrap);	fprintf(tree,":%7.5f",left_branch[last_seq-first_seq+1-1]);	if ((bootstrap==BS_BRANCH_LABELS) && (old_row>0) && (boot_totals[old_row]>0))		fprintf(tree,"[%d]",(pint)boot_totals[old_row]);	fprintf(tree,",\n");	old_row=two_way_split(tree_description, tree, last_seq-first_seq+1-2,3,bootstrap);	fprintf(tree,":%7.5f",left_branch[last_seq-first_seq+1]);	if ((bootstrap==BS_BRANCH_LABELS) && (old_row>0) && (boot_totals[old_row]>0))		fprintf(tree,"[%d]",(pint)boot_totals[old_row]);	fprintf(tree,")");        if (bootstrap==BS_NODE_LABELS) fprintf(tree,"TRICHOTOMY");	fprintf(tree,";\n");}sint two_way_split(char **tree_description, FILE *tree, sint start_row, sint flag, sint bootstrap){	sint row, new_row = 0, old_row, col, test_col = 0;	Boolean single_seq;	if(start_row != last_seq-first_seq+1-2) fprintf(tree,"(\n"); 	for(col=1; col<=last_seq-first_seq+1; col++) {		if(tree_description[start_row][col] == flag) {			test_col = col;			break;		}	}	single_seq = TRUE;	for(row=start_row-1; row>=1; row--) 		if(tree_description[row][test_col] == 1) {			single_seq = FALSE;			new_row = row;			break;		}	if(single_seq) {		tree_description[start_row][test_col] = 0;		fprintf(tree,"%.*s",max_names,names[test_col+first_seq-1]);		if(start_row == last_seq-first_seq+1-2) {			return(0);		}		fprintf(tree,":%7.5f,\n",left_branch[start_row]);	}	else {		for(col=1; col<=last_seq-first_seq+1; col++) {		    if((tree_description[start_row][col]==1)&&		       (tree_description[new_row][col]==1))				tree_description[start_row][col] = 0;		}		old_row=two_way_split(tree_description, tree, new_row, (sint)1, bootstrap);		if(start_row == last_seq-first_seq+1-2) {			return(new_row);		}		fprintf(tree,":%7.5f",left_branch[start_row]);		if ((bootstrap==BS_BRANCH_LABELS) && (boot_totals[old_row]>0))			fprintf(tree,"[%d]",(pint)boot_totals[old_row]);		fprintf(tree,",\n");	}	for(col=1; col<=last_seq-first_seq+1; col++) 		if(tree_description[start_row][col] == flag) {			test_col = col;			break;		}		single_seq = TRUE;	new_row = 0;	for(row=start_row-1; row>=1; row--) 		if(tree_description[row][test_col] == 1) {			single_seq = FALSE;			new_row = row;			break;		}	if(single_seq) {		tree_description[start_row][test_col] = 0;		fprintf(tree,"%.*s",max_names,names[test_col+first_seq-1]);		fprintf(tree,":%7.5f)\n",right_branch[start_row]);	}	else {		for(col=1; col<=last_seq-first_seq+1; col++) {		    if((tree_description[start_row][col]==1)&&		       (tree_description[new_row][col]==1))				tree_description[start_row][col] = 0;		}		old_row=two_way_split(tree_description, tree, new_row, (sint)1, bootstrap);		fprintf(tree,":%7.5f",right_branch[start_row]);		if ((bootstrap==BS_BRANCH_LABELS) && (boot_totals[old_row]>0))			fprintf(tree,"[%d]",(pint)boot_totals[old_row]);		fprintf(tree,")\n");	}	if ((bootstrap==BS_NODE_LABELS) && (boot_totals[start_row]>0))			fprintf(tree,"%d",(pint)boot_totals[start_row]);		return(start_row);}void print_tree(char **tree_description, FILE *tree, sint *totals){	sint row,col;	fprintf(tree,"\n");	for(row=1; row<=last_seq-first_seq+1-3; row++)  {		fprintf(tree," \n");		for(col=1; col<=last_seq-first_seq+1; col++) { 			if(tree_description[row][col] == 0)				fprintf(tree,"*");			else				fprintf(tree,".");		}		if(totals[row] > 0)			fprintf(tree,"%7d",(pint)totals[row]);	}	fprintf(tree," \n");	for(col=1; col<=last_seq-first_seq+1; col++) 		fprintf(tree,"%1d",(pint)tree_description[last_seq-first_seq+1-2][col]);	fprintf(tree,"\n");}sint dna_distance_matrix(FILE *tree){   	sint m,n;	sint j,i;	sint res1, res2;    sint overspill = 0;	double p,q,e,a,b,k;		tree_gap_delete();  /* flag positions with gaps (tree_gaps[i] = 1 ) */		if(verbose) {		fprintf(tree,"\n");		fprintf(tree,"\n DIST   = percentage divergence (/100)");		fprintf(tree,"\n p      = rate of transition (A <-> G; C <-> T)");		fprintf(tree,"\n q      = rate of transversion");		fprintf(tree,"\n Length = number of sites used in comparison");		fprintf(tree,"\n");	    if(tossgaps) {		fprintf(tree,"\n All sites with gaps (in any sequence) deleted!");		fprintf(tree,"\n");	    }	    if(kimura) {		fprintf(tree,"\n Distances corrected by Kimura's 2 parameter model:");		fprintf(tree,"\n\n Kimura, M. (1980)");		fprintf(tree," A simple method for estimating evolutionary ");		fprintf(tree,"rates of base");		fprintf(tree,"\n substitutions through comparative studies of ");		fprintf(tree,"nucleotide sequences.");		fprintf(tree,"\n J. Mol. Evol., 16, 111-120.");		fprintf(tree,"\n\n");	    }	}	for(m=1;   m<last_seq-first_seq+1;  ++m)     /* for every pair of sequence */	for(n=m+1; n<=last_seq-first_seq+1; ++n) {		p = q = e = 0.0;		tmat[m][n] = tmat[n][m] = 0.0;		for(i=1; i<=seqlen_array[first_seq]; ++i) {			j = boot_positions[i];                    	if(tossgaps && (tree_gaps[j] > 0) ) 				goto skip;          /* gap position */			res1 = seq_array[m+first_seq-1][j];			res2 = seq_array[n+first_seq-1][j];			if( (res1 == gap_pos1)     || (res1 == gap_pos2) ||                            (res2 == gap_pos1) || (res2 == gap_pos2)) 				goto skip;          /* gap in a seq*/			if(!use_ambiguities)			if( is_ambiguity(res1) || is_ambiguity(res2))				goto skip;          /* ambiguity code in a seq*/			e = e + 1.0;                        if(res1 != res2) {				if(transition(res1,res2))					p = p + 1.0;				else					q = q + 1.0;			}		        skip:;		}	/* Kimura's 2 parameter correction for multiple substitutions */		if(!kimura) {			if (e == 0) {				fprintf(stdout,"\n WARNING: sequences %d and %d are non-overlapping\n",m,n);				k = 0.0;				p = 0.0;				q = 0.0;			}			else {				k = (p+q)/e;				if(p > 0.0)					p = p/e;				else					p = 0.0;				if(q > 0.0)					q = q/e;				else					q = 0.0;			}			tmat[m][n] = tmat[n][m] = k;			if(verbose)                    /* if screen output */				fprintf(tree,         	     "%4d vs.%4d:  DIST = %7.4f; p = %6.4f; q = %6.4f; length = %6.0f\n"        	                 ,(pint)m,(pint)n,k,p,q,e);		}		else {			if (e == 0) {				fprintf(stdout,"\n WARNING: sequences %d and %d are non-overlapping\n",m,n);				p = 0.0;				q = 0.0;			}			else {				if(p > 0.0)					p = p/e;				else					p = 0.0;				if(q > 0.0)					q = q/e;				else					q = 0.0;			}			if( ((2.0*p)+q) == 1.0 )				a = 0.0;			else				a = 1.0/(1.0-(2.0*p)-q);			if( q == 0.5 )				b = 0.0;			else				b = 1.0/(1.0-(2.0*q));/* watch for values going off the scale for the correction. */			if( (a<=0.0) || (b<=0.0) ) {				overspill++;				k = 3.5;  /* arbitrary high score */ 			}			else 				k = 0.5*log(a) + 0.25*log(b);			tmat[m][n] = tmat[n][m] = k;			if(verbose)                      /* if screen output */	   			fprintf(tree,             "%4d vs.%4d:  DIST = %7.4f; p = %6.4f; q = %6.4f; length = %6.0f\n"        	                ,(pint)m,(pint)n,k,p,q,e);		}	}	return overspill;	/* return the number of off-scale values */}sint prot_distance_matrix(FILE *tree){	sint m,n;	sint j,i;	sint res1, res2;    sint overspill = 0;	double p,e,k, table_entry;		tree_gap_delete();  /* flag positions with gaps (tree_gaps[i] = 1 ) */		if(verbose) {		fprintf(tree,"\n");		fprintf(tree,"\n DIST   = percentage divergence (/100)");		fprintf(tree,"\n Length = number of sites used in comparison");		fprintf(tree,"\n\n");	        if(tossgaps) {			fprintf(tree,"\n All sites with gaps (in any sequence) deleted");			fprintf(tree,"\n");		}	    	if(kimura) {			fprintf(tree,"\n Distances up tp 0.75 corrected by Kimura's empirical method:");			fprintf(tree,"\n\n Kimura, M. (1983)");			fprintf(tree," The Neutral Theory of Molecular Evolution.");			fprintf(tree,"\n Page 75. Cambridge University Press, Cambridge, England.");			fprintf(tree,"\n\n");	    	}	}	for(m=1;   m<nseqs;  ++m)     /* for every pair of sequence */	for(n=m+1; n<=nseqs; ++n) {		p = e = 0.0;		tmat[m][n] = tmat[n][m] = 0.0;		for(i=1; i<=seqlen_array[1]; ++i) {			j = boot_positions[i];	            	if(tossgaps && (tree_gaps[j] > 0) ) goto skip; /* gap position */			res1 = seq_array[m][j];			res2 = seq_array[n][j];			if( (res1 == gap_pos1)     || (res1 == gap_pos2) ||                            (res2 == gap_pos1) || (res2 == gap_pos2))                                     goto skip;   /* gap in a seq*/			e = e + 1.0;                        if(res1 != res2) p = p + 1.0;		        skip:;		}		if(p <= 0.0) 			k = 0.0;		else			k = p/e;/* DES debug *//* fprintf(stdout,"Seq1=%4d Seq2=%4d  k =%7.4f \n",(pint)m,(pint)n,k); *//* DES debug */		if(kimura) {			if(k < 0.75) { /* use Kimura's formula */				if(k > 0.0) k = - log(1.0 - k - (k * k/5.0) );			}			else {				if(k > 0.930) {				   overspill++;				   k = 10.0; /* arbitrarily set to 1000% */				}				else {				   table_entry = (k*1000.0) - 750.0;                                   k = (double)dayhoff_pams[(int)table_entry];                                   k = k/100.0;				}			}		}		tmat[m][n] = tmat[n][m] = k;		    if(verbose)                    /* if screen output */			fprintf(tree,         	                 "%4d vs.%4d  DIST = %6.4f;  length = %6.0f\n", 	                 (pint)m,(pint)n,k,e);	}	return overspill;}void guide_tree(FILE *tree,sint firstseq,sint numseqs)/*    Routine for producing unrooted NJ trees from seperately aligned   pairwise distances.  This produces the GUIDE DENDROGRAMS in   PHYLIP format.*/{        static char **standard_tree;        sint i;	float dist;	phylip_phy_tree_file=tree;        verbose = FALSE;	first_seq=firstseq;	last_seq=first_seq+numseqs-1;  	if(numseqs==2) {		dist=tmat[firstseq][firstseq+1]/2.0;		fprintf(tree,"(%s:%0.5f,%s:%0.5f);\n",			names[firstseq],dist,names[firstseq+1],dist);	}	else {        standard_tree   = (char **) ckalloc( (last_seq-first_seq+2) * sizeof (char *) );        for(i=0; i<last_seq-first_seq+2; i++)                standard_tree[i]  = (char *) ckalloc( (last_seq-first_seq+2) * sizeof(char));        nj_tree(standard_tree,clustal_phy_tree_file);        print_phylip_tree(standard_tree,phylip_phy_tree_file,0);        if(left_branch != NULL) left_branch=ckfree((void *)left_branch);        if(right_branch != NULL) right_branch=ckfree((void *)right_branch);        if(tkill != NULL) tkill=ckfree((void *)tkill);        if(av != NULL) av=ckfree((void *)av);        for (i=1;i<last_seq-first_seq+2;i++)                standard_tree[i]=ckfree((void *)standard_tree[i]);        standard_tree=ckfree((void *)standard_tree);	}        fclose(phylip_phy_tree_file);}static Boolean is_ambiguity(char c){        int i;	char codes[]="ACGTU";        if(use_ambiguities==TRUE)        {         return FALSE;        }	for(i=0;i<5;i++)        	if(amino_acid_codes[c]==codes[i])             	   return FALSE;        return TRUE;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩高清一区二区三区| 91玉足脚交白嫩脚丫在线播放| 亚洲人一二三区| 中文在线资源观看网站视频免费不卡| 欧美美女喷水视频| 欧美亚洲一区三区| 欧美日韩一二三| 制服丝袜日韩国产| www久久久久| 国产精品久久久久一区| 国产精品国产自产拍高清av王其 | 久久免费电影网| 91国模大尺度私拍在线视频| 91啦中文在线观看| 色屁屁一区二区| 欧美网站大全在线观看| 日韩欧美视频在线 | 成人av网站免费观看| 精品一区免费av| 成人精品视频一区| 久久综合丝袜日本网| 亚洲乱码日产精品bd| 久久精品久久精品| 91视频xxxx| 2023国产精品视频| 国产网红主播福利一区二区| 99视频精品在线| 日韩av在线播放中文字幕| 国产综合色精品一区二区三区| 激情小说亚洲一区| 日韩午夜电影在线观看| 最新日韩av在线| 国产一区在线看| 在线观看视频欧美| 亚洲天堂精品视频| 亚洲欧美色图小说| 3d动漫精品啪啪一区二区竹菊 | 成人午夜视频在线观看| 精品久久久久久亚洲综合网| 老司机免费视频一区二区三区| 欧美日本在线一区| 一卡二卡欧美日韩| 99视频在线精品| 亚洲精品成a人| 色婷婷亚洲精品| 国产精品美女www爽爽爽| 中文字幕日韩av资源站| 成人免费视频免费观看| 欧美午夜精品久久久久久超碰| 亚洲另类在线一区| 欧美日韩一卡二卡| 日本不卡123| 国产午夜精品久久久久久免费视| 国产资源在线一区| 国产日韩精品一区| 在线观看成人免费视频| 婷婷久久综合九色综合伊人色| 91精品国产黑色紧身裤美女| 麻豆精品视频在线观看免费| 国产精品蜜臀在线观看| 欧美精品三级日韩久久| 国产精品资源站在线| 一区二区三区在线视频播放| 在线播放91灌醉迷j高跟美女| 不卡av免费在线观看| 天堂精品中文字幕在线| 久久精品人人爽人人爽| 欧美亚洲国产一卡| 国产激情一区二区三区桃花岛亚洲| 伊人婷婷欧美激情| 欧美国产禁国产网站cc| 欧美一区二区三区不卡| 91极品视觉盛宴| 99久久国产综合精品麻豆| 人人狠狠综合久久亚洲| 亚洲综合成人网| 亚洲日本一区二区三区| 91视频在线观看免费| 欧美极品aⅴ影院| 欧美大胆一级视频| 日韩一级片在线观看| 欧美三电影在线| 欧美影视一区二区三区| eeuss鲁片一区二区三区在线观看| 久久草av在线| 国产二区国产一区在线观看| 亚洲猫色日本管| 成人欧美一区二区三区1314| 国产精品视频你懂的| 国产午夜亚洲精品理论片色戒| 久久综合狠狠综合久久激情| 欧美成人免费网站| 一个色综合av| 欧美剧情电影在线观看完整版免费励志电影| 国产成人8x视频一区二区| 国产一区二区美女诱惑| 欧美日韩精品一二三区| 717成人午夜免费福利电影| 欧美精品在线观看一区二区| 欧美一区二区三区在线电影| 日韩免费看的电影| 久久久久久毛片| 中文字幕一区二区三区在线观看 | 黄一区二区三区| 日韩一级完整毛片| 中文字幕不卡在线播放| 一区二区三区视频在线看| 日韩av一二三| 成人精品视频.| 欧美一区二区三区视频在线 | 一区免费观看视频| 亚洲第一电影网| 国产suv精品一区二区三区| 欧美日韩国产高清一区二区| 欧美精品一区二区不卡| 亚洲美女视频在线| 韩国av一区二区三区在线观看| www.成人网.com| 日韩一区二区视频| 日韩成人av影视| 国产成人av一区| 欧美一级高清片| 亚洲午夜日本在线观看| 成人动漫一区二区| 欧美精品一区二区三区很污很色的| 亚洲美女精品一区| 成人aa视频在线观看| 亚洲国产精品精华液ab| 久久精品国产一区二区| 欧美日韩美少妇| 亚洲国产精品一区二区久久| 99麻豆久久久国产精品免费优播| 久久午夜色播影院免费高清| 麻豆成人91精品二区三区| 欧美日韩亚洲综合在线| 亚洲国产毛片aaaaa无费看 | 国产亚洲欧美激情| 国产成人精品免费视频网站| 国产免费观看久久| 波多野洁衣一区| 午夜国产精品影院在线观看| 在线免费观看日本一区| 午夜精品久久一牛影视| 日韩视频在线永久播放| 日本欧美一区二区三区乱码| 欧美www视频| 99在线热播精品免费| 亚洲激情自拍偷拍| 国产精品美日韩| 久久99国产精品免费网站| 国产成人久久精品77777最新版本| 99视频精品全部免费在线| 3d成人动漫网站| 国产精品一二三| 一区二区三区四区激情| 日韩欧美一区二区久久婷婷| 国产在线精品一区二区不卡了 | 久久天天做天天爱综合色| 韩国一区二区三区| 国产精品免费观看视频| 日韩一区二区在线看片| 99在线精品一区二区三区| 亚洲第一av色| 亚洲视频一二区| 久久理论电影网| 在线观看视频91| 成+人+亚洲+综合天堂| 久久精品72免费观看| 亚洲视频在线一区二区| 精品剧情v国产在线观看在线| 欧美体内she精高潮| caoporn国产一区二区| 久久99国产精品久久99果冻传媒| 亚洲丝袜精品丝袜在线| 国产午夜精品福利| 日韩免费性生活视频播放| 这里只有精品99re| 欧美欧美午夜aⅴ在线观看| 91久久人澡人人添人人爽欧美| 国产在线精品一区二区夜色| 香蕉加勒比综合久久| 亚洲最大色网站| 亚洲一区电影777| 日本不卡视频在线观看| 亚洲成人久久影院| 三级一区在线视频先锋| 日韩av中文字幕一区二区| 日韩成人免费电影| 美美哒免费高清在线观看视频一区二区| 樱花草国产18久久久久| 亚洲综合自拍偷拍| 亚洲精品免费一二三区| 亚洲国产欧美在线人成| 蜜臀精品久久久久久蜜臀| 免费xxxx性欧美18vr| 色域天天综合网| 91捆绑美女网站| 欧美成人伊人久久综合网| 久久久三级国产网站| 中文字幕一区二区三区乱码在线|