File: FlexibleAlignmentTest.java

package info (click to toggle)
biojava-live 1%3A1.7.1-8
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 55,160 kB
  • sloc: java: 180,820; xml: 6,908; sql: 510; makefile: 50
file content (112 lines) | stat: -rw-r--r-- 3,155 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
 *                    BioJava development code
 *
 * This code may be freely distributed and modified under the
 * terms of the GNU Lesser General Public Licence.  This should
 * be distributed with the code.  If you do not have a copy,
 * see:
 *
 *      http://www.gnu.org/copyleft/lesser.html
 *
 * Copyright for this code is held jointly by the individual
 * authors.  These should be listed in @author doc comments.
 *
 * For more information on the BioJava project and its aims,
 * or to join the biojava-l mailing list, visit the home page
 * at:
 *
 *      http://www.biojava.org/
 */


package org.biojava.bio.alignment;

import java.util.ArrayList;
import java.util.List;

import junit.framework.TestCase;

import org.biojava.bio.seq.DNATools;
import org.biojava.bio.seq.GappedSequence;
import org.biojava.bio.seq.ProteinTools;
import org.biojava.bio.symbol.BasisSymbol;
import org.biojava.bio.symbol.LocationTools;

/* @author Lachlan Coin */
public class FlexibleAlignmentTest extends TestCase {

  public FlexibleAlignmentTest(String name){
    super(name);
  }

    //public static void main(String[] args) throws Exception{
    //	FlexibleAlignmentTest aat = new FlexibleAlignmentTest();
    //	aat.setUp();
    //	aat.testDNA();
    //	aat.testProtein();
    //}


    final static String[] alignment = new String[] {"A-C",
                                       "AGC",
                                       "A-A"};


    final static String[] names = new String[] {"MOUSE", "HUMAN","SCHPO"};

    final static FlexibleAlignment alignDNA = parse(names, alignment, true);
    final static FlexibleAlignment alignProt = parse(names, alignment, false);

    protected void setUp() throws Exception{

    }


  public void testDNA()
      throws Exception
  {
      List syms = ((BasisSymbol) alignDNA.symbolAt(2)).getSymbols();
      assertEquals(syms.get(0), DNATools.getDNA().getGapSymbol());
      assertEquals(syms.get(1), DNATools.g());
  }


  public void testProtein()
      throws Exception
  {
      List syms = ((BasisSymbol) alignProt.symbolAt(2)).getSymbols();
      assertEquals(syms.get(0), ProteinTools.getAlphabet().getGapSymbol());
  }



    private static FlexibleAlignment parse(String[] names, String[] alignment, boolean dna)
    {
        try
        {
            List sequences = new ArrayList();
            for(int i=0; i<alignment.length; i++)
            {
                GappedSequence seq;
                if(dna)
                    seq = DNATools.createGappedDNASequence(alignment[i],names[i]);
                else
                    seq = ProteinTools.createGappedProteinSequence(alignment[i],names[i]);
                AlignmentElement ae = new SimpleAlignmentElement(names[i], seq, LocationTools.makeLocation(1, alignment[i].length()));
                //         System.out.println(seq.seqString());
                sequences.add(ae);
            }
            FlexibleAlignment al = new FlexibleAlignment(sequences);
            return al;
        }
        catch (Throwable t)
        {
            t.printStackTrace();
            //System.exit(0);
            return null;
        }
    }



}