]> git.donarmstrong.com Git - mothur.git/blob - distclearcut.h
modified precluster to use less memory.
[mothur.git] / distclearcut.h
1 /*
2  * dist.h
3  *
4  * $Id$
5  *
6  *****************************************************************************
7  *
8  * Copyright (c) 2004,  Luke Sheneman
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without 
12  * modification, are permitted provided that the following conditions 
13  * are met:
14  * 
15  *  + Redistributions of source code must retain the above copyright 
16  *    notice, this list of conditions and the following disclaimer. 
17  *  + Redistributions in binary form must reproduce the above copyright 
18  *    notice, this list of conditions and the following disclaimer in 
19  *    the documentation and/or other materials provided with the 
20  *    distribution. 
21  *  + The names of its contributors may not be used to endorse or promote 
22  *    products derived  from this software without specific prior 
23  *    written permission. 
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
26  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
27  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
28  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 
29  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
30  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
31  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
32  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
33  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
34  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
35  * POSSIBILITY OF SUCH DAMAGE.  
36  *
37  *****************************************************************************
38  *
39  * Compute a distance matrix given a set of sequences
40  *
41  *****************************************************************************
42  *
43  * AUTHOR:
44  * 
45  *   Luke Sheneman
46  *   sheneman@cs.uidaho.edu
47  *
48  */
49
50
51 #ifndef _INC_DIST_H_
52 #define _INC_DIST_H_ 1
53
54 #include "fasta.h"
55 #include "clearcut.h"
56
57
58
59 /* 
60  * An arbitrarily large distance to represent distances
61  * which are too great to accurately correct.
62  */
63 #define NJ_BIGDIST 10.0  
64
65
66
67 /* some function prototypes */
68 DMAT *
69 NJ_build_distance_matrix(NJ_ARGS *nj_args);
70
71 DMAT *
72 NJ_compute_dmat(NJ_ARGS *nj_args,
73                 NJ_alignment *alignment);
74
75
76 float
77 NJ_pw_percentid(NJ_alignment *alignment,
78                 long int x,
79                 long int y);
80
81 long int
82 NJ_pw_differences(NJ_alignment *alignment,
83                   long int x,
84                   long int y,
85                   long int *residues);
86
87 void
88 NJ_no_correction(DMAT *dmat,
89                  NJ_alignment *alignment);
90
91 void
92 NJ_DNA_jc_correction(DMAT *dmat,
93                      NJ_alignment *alignment);
94
95 void
96 NJ_PROTEIN_jc_correction(DMAT *dmat,
97                          NJ_alignment *alignment);
98
99 void
100 NJ_DNA_k2p_correction(DMAT *dmat,
101                       NJ_alignment *alignment);
102
103 void
104 NJ_PROTEIN_kimura_correction(DMAT *dmat,
105                              NJ_alignment *alignment);
106
107 void
108 NJ_DNA_count_tt(NJ_alignment *alignment,
109                 long int x,
110                 long int y,
111                 long int *transitions,
112                 long int *transversions,
113                 long int *residues);
114
115
116 #endif /* _INC_DIST_H_ */
117
118
119
120
121
122
123
124
125