當前位置: 首頁>>代碼示例>>Java>>正文


Java PairwiseSequenceAligner.getPair方法代碼示例

本文整理匯總了Java中org.biojava.nbio.alignment.template.PairwiseSequenceAligner.getPair方法的典型用法代碼示例。如果您正苦於以下問題:Java PairwiseSequenceAligner.getPair方法的具體用法?Java PairwiseSequenceAligner.getPair怎麽用?Java PairwiseSequenceAligner.getPair使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.biojava.nbio.alignment.template.PairwiseSequenceAligner的用法示例。


在下文中一共展示了PairwiseSequenceAligner.getPair方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testComplex

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
@Test
	public void testComplex() throws Exception {

		short match = 2, gop = -5, gep = -3; // 2, 5, and 3 are coprime; -2 is the mismatch score
		SimpleSubstitutionMatrix<NucleotideCompound> mx = new SimpleSubstitutionMatrix<NucleotideCompound>(new DNACompoundSet(), match, (short)-match);

		DNASequence a = new DNASequence("CGTAT  ATATCGCGCGCGCGATATATATATCT TCTCTAAAAAAA".replaceAll(" ", ""));
		DNASequence b = new DNASequence("GGTATATATATCGCGCGCACGAT TATATATCTCTCTCTAAAAAAA".replaceAll(" ", ""));
//                                       --CGTATATATCGCGCGCGCGATATATATATCT-TCTCTAAAAAAA
//                                       GGTATATATATCGCGCGCACGAT-TATATATCTCTCTCTAAAAAAA
//  mismatches:                             ^              ^
// The two alignments should have the same score. The bottom one is the one the aligner found.

		PairwiseSequenceAligner<DNASequence, NucleotideCompound> aligner = Alignments.getPairwiseAligner(a, b, Alignments.PairwiseSequenceAlignerType.GLOBAL, new SimpleGapPenalty(gop, gep), mx);
		SequencePair<DNASequence, NucleotideCompound> pair = aligner.getPair();


		int nMatches = "--CGTATATATCGCGCGCGCGATATATATATCT-TCTCTAAAAAAA".length() - 2 - 4;
		double expectedScore = nMatches * match
									   - 2 * match // there are two mismatches
									   + 3 * gop + 4 * gep; // there are 3 gap opens and either 1 or 4 extensions, depending on the def
		assertEquals(expectedScore, aligner.getScore(), 0.00000001);
	}
 
開發者ID:biojava,項目名稱:biojava,代碼行數:24,代碼來源:NeedlemanWunschTest.java

示例2: align

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
@Nonnull
public SequenceAlignment<S, C> align(@Nonnull S a, @Nonnull S b) {
	PairwiseSequenceAligner<S, C> aligner = Alignments.getPairwiseAligner(a, b, m_type, m_gapPenalty, m_matrix);
	//noinspection ConstantConditions
	if (aligner == null) {
		throw new RuntimeException("Couldn't create aligner; something is wrong in Biojava");
	}
	// this actually performs the alignment; do it first
	SequencePair<S, C> pair = aligner.getPair();
	return new SequenceAlignment<>(toIntExact(aligner.getScore()), aligner.getSimilarity(), pair);
}
 
開發者ID:dmyersturnbull,項目名稱:sequence-alignment,代碼行數:12,代碼來源:SequenceAligner.java

示例3: main

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {

		String query = "AGGATGAACGCTGGCGGCGTGCTTAACACATGCAAGTCGAACGGTGAAGCCCAGCTTGCTGGGTGGATCA" +
		"GTGGCGAACGGGTGAGTAACACGTGAGCAACCTGCCCCTGACTCTGGGATAAGCGCTGGAAACGGTGTCT" +
		"AATACTGGATATGAGCTACCACCGCATGGTGAGTGGTTGGAAAGATTTTTCGGTTGGGGATGGGCTCGCG" +
		"GCCTATCAGCTTGTTGGTGAGGTAATGGCTCACCAAGGCGTCGACGGGTAGCCGGCCTGAGAGGGTGACC" +
		"GGCCACACTGGGACTGAGACACGGCCCAGACTCTACGGGAGGCAGCAGTGGGGAATATTGCACAATGGGC" +
		"GGAAGCCTGATGCAGCAACGCCGCGTGAGGGACGACGGCTTCGGGTTGTAAACCTCTTTTAGCAGGGAAG" +
		"AAGCGAGAGTGACGGTACCTGCAGAAAAAGCGCCGGCTAACTACGTGCCAGCAGCCGCGGTAATACGTAG" +
		"GGCGCAAGCGTTATCCGGAATTATTGGGCGTAAAGAGCTCGTAGGCGGTTTGTCGCGTCTGCTGTGAAAA" +
		"CCCGAGGCTCAACCTNNGGGCTGCAGTGGGTACGGGCAGACTAGAGTGCGGTAGGGGAGATTGGAATTCC" +
		"TGGTGTAGCGGTGGAATGCGCAGATATCAGGAGGAACACCGATGGCGAAGGCAGATCTCTGGGCCGTAAC" +
		"TGACGCTGAGGAGCGAAAGGGTGGGGAGCAAACAGGCTTAGATACCCTGGTAGTCCACCCCGTAAACGTT" +
		"GGGAACTAGTTGTGGGGTCCTTTCCACGGATTCCGTGACGCACGTAACGCATTAAGTTCCCCGCCTGGGG" +
		"AGTACGGCCGCAAGGCTAAAACTCAAAGGAATTGACGGGGACCCGCACAAGCGGCGGAGCATGCGGATTA" +
		"AATCGATGCAACGCGAAGAACCTTACCAAGGCTTGACATACACGAGAACGCTGCAGAAATGTAGAACTCT" +
		"TTGGACACTCGTGAACAGGTGGTGCATGGTTGTCGTCAGCTCGTGTCGTGAGATGTTGGGTTAAGTCCCG" +
		"CAACGAGCGCAACCCTCGTTCTATGTTGCCAGCACGTAATGGTGGGAACTCATGGGATACTGCCGGGGTC" +
		"AACTCGGAGGAAGGTGGGGATGACGTCAAATCATCATGCCCCTTATGTCTTGGGCTTCACGCATGCTACA" +
		"ATGGCCGGTACAAAGGGCTGCAATACCGTGAGGTGGAGCGAATCCCAAAAAGCCGGTCCCAGTTCGGATT" +
		"GAGGTCTGCAACTCGACCTCATGAAGTCGGAGTCGCTAGTAATCGCAGATCAGCAACGCTGCGGTGAATA" +
		"CGTTCCCGGGTCTTGTACACACCGCCCGTCAAGTCATGAAAGTCGGTAACACCTGAAGCCGGTGGCCTAA" +
		"CCCTTGTGGAGGGAGCCGGTAATTAAA";

		String target = "CTGGCCGCCTGCTTAACACATCCAAGTCGAACGGTGAAGCCCCANCTTACTGGGTGGATCAGTGCCGAAC" +
		"GGGTGAGTAACACGTGAGCAACCTCCCCCTGACTCTGGGATAAGCGCTGGAANCGGTGTCTAATACTGGA" +
		"TATGAGCTACCACCGCATGGTGAGTGGTTGGAAAGATTTTTCGGTTGGGGATGGGCTCGCGCCCTATGAG" +
		"CTTGTTGGTGAGGTAATGGCTCACCAAGCCGTCGACGGGTAGCCGGCCTGAGAGGGTGACCGNCCACACT" +
		"GGGACTGAGACACGGCCCAGACTCCTACGGGAGGCAGCAGTGGGGAATATTGCACAATGGGCGGAAGCCT" +
		"GATTCANCAACCCCGCGTGAGGGACGACGGCCTTCGGGTTGTAAACCTCTTTTAGCAGGGAAGAAGCGAG" +
		"AGTGACGGTACCTGCAGAAAAAGCCCCGGCTAACTACGTGCCAGCAGCCGCGGTAATACGTAGGGCGCAA" +
		"GCGTTATCCGGAATTATTGGGCGTAAAGAGCTCGTAGGCGGTTTGTCGCGTCTGCTGTGAAAACCCGAGG" +
		"CTCAACCTCGGGCCTGCAGTGGGTACGGGCAGACTAGAGTGCGGTAGGGGAGATTGGAATTCCTGGTGTA" +
		"GCGGTGGAATGCGCAGATATCAGGAGGAACACCGATGGCGAAGGCAGATCTCTGGGCCGTAACTGACGCT" +
		"GAGGAGCGAAAGGGTGGGGAGCAAACAGGCTTAGATACCCTGGTAGTCCACCCCGTAAACGTTGGGAACT" +
		"AGTTGTGGGGTCCTTTCCACGGATTCCGTGACGCAGCTAACGCATTAAGTTCCCCGCCTGGGGAGTACGG" +
		"CCGCAAGGCTAAAACTCAAAGGAATTGACGGGGACCCGCACAAGCGGCGGAGCATGCGGATTAATTCGAT" +
		"GCAACGCGAAGAACCTTACCAAGGCTTGACATACACGAGAACGCTGCAGAAATGTAGAACTCTTTGGACA" +
		"CTCGTGAACAGGTGGTGCATGGTTGTCGTCAGCTCGTGTCGTGAGATGTTGGGTTAAGTCCCGCAACGAG" +
		"CGCAACCCTCGTTCTATGTTGCCAGCACGTAATGGTGGGAACTCATGGGATACTGCCGGGGTCAACTCGG" +
		"AGGAAGGTGGGGATGACGTCAAATCATCATGCCCCTTATGTCTTGGGCTTCACGCATGCTACAATGGCCG" +
		"GTACAAAGGGCTGCAATACCGTGAGGTGGAGCGAATCCCAAAAAGCCGGTCCCAGTTCGGATTGAGGTCT" +
		"GCAACTCGACCTCATGAAGTCGGAGTCGCTAGTAATCGCAGATCAGCAACGCTGCGGTGAATACGTTCCC" +
		"GGGTCTTGTACACACCGCCCGTCAAGTCATGAAAGTCGGTAACACCTGAAGCCGGTGGCCCAACCCTTGT" +
		"GGAGGGAGCCGTCGAAGGTGGGATCGGTAATTAGGACTAAGTCGTAACAAGGTAGCCGTACC";

		GapPenalty penalty = new SimpleGapPenalty(-14, -4);
		PairwiseSequenceAligner<DNASequence, NucleotideCompound> aligner = Alignments.getPairwiseAligner(
				new DNASequence(query, AmbiguityDNACompoundSet.getDNACompoundSet()),
				new DNASequence(target, AmbiguityDNACompoundSet.getDNACompoundSet()),
				PairwiseSequenceAlignerType.GLOBAL,
				penalty, SubstitutionMatrixHelper.getNuc4_4());
		SequencePair<DNASequence, NucleotideCompound>
		alignment = aligner.getPair();

		System.out.println("Alignment: "+ alignment);

		int identical = alignment.getNumIdenticals();
		System.out.println("Number of identical residues: "+ identical);
		System.out.println("% identical query: "+ identical / (float) query.length());
		System.out.println("% identical target: "+ identical / (float) target.length());
	}
 
開發者ID:biojava,項目名稱:biojava,代碼行數:63,代碼來源:TestDNANeedlemanWunsch.java

示例4: alignProtein

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
private static SequencePair<ProteinSequence, AminoAcidCompound> alignProtein(ProteinSequence s1, ProteinSequence s2) {
	SubstitutionMatrix<AminoAcidCompound> matrix = SubstitutionMatrixHelper.getIdentity();

	GapPenalty penalty = new SimpleGapPenalty(8, 1);

	PairwiseSequenceAligner<ProteinSequence, AminoAcidCompound> nw =
			Alignments.getPairwiseAligner(s1, s2, PairwiseSequenceAlignerType.GLOBAL, penalty, matrix);

	return nw.getPair();
}
 
開發者ID:biojava,項目名稱:biojava,代碼行數:11,代碼來源:EntityFinder.java

示例5: alignDNA

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
private static SequencePair<DNASequence, NucleotideCompound> alignDNA(DNASequence s1, DNASequence s2) {
	SubstitutionMatrix<NucleotideCompound> matrix = SubstitutionMatrixHelper.getNuc4_4();

	GapPenalty penalty = new SimpleGapPenalty(8, 1);

	PairwiseSequenceAligner<DNASequence, NucleotideCompound> nw =
			Alignments.getPairwiseAligner(s1, s2, PairwiseSequenceAlignerType.GLOBAL, penalty, matrix);

	return nw.getPair();
}
 
開發者ID:biojava,項目名稱:biojava,代碼行數:11,代碼來源:EntityFinder.java

示例6: alignRNA

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
private static SequencePair<RNASequence, NucleotideCompound> alignRNA(RNASequence s1, RNASequence s2) {
	SubstitutionMatrix<NucleotideCompound> matrix = SubstitutionMatrixHelper.getNuc4_4();

	GapPenalty penalty = new SimpleGapPenalty(8, 1);

	PairwiseSequenceAligner<RNASequence, NucleotideCompound> nw =
			Alignments.getPairwiseAligner(s1, s2, PairwiseSequenceAlignerType.GLOBAL, penalty, matrix);

	return nw.getPair();
}
 
開發者ID:biojava,項目名稱:biojava,代碼行數:11,代碼來源:EntityFinder.java

示例7: main

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {

		String uniprotID1 = "P69905";
		String uniprotID2 = "P68871";

		ProteinSequence s1 = getSequenceForId(uniprotID1);
		ProteinSequence s2 = getSequenceForId(uniprotID2);

		SubstitutionMatrix<AminoAcidCompound> matrix = SubstitutionMatrixHelper.getBlosum65();

		GapPenalty penalty = new SimpleGapPenalty();

		int gop = 8;
		int extend = 1;
		penalty.setOpenPenalty(gop);
		penalty.setExtensionPenalty(extend);


		PairwiseSequenceAligner<ProteinSequence, AminoAcidCompound> smithWaterman =
				Alignments.getPairwiseAligner(s1, s2, PairwiseSequenceAlignerType.LOCAL, penalty, matrix);

		SequencePair<ProteinSequence, AminoAcidCompound> pair = smithWaterman.getPair();


		System.out.println(pair.toString(60));


	}
 
開發者ID:biojava,項目名稱:biojava,代碼行數:29,代碼來源:DemoAlignProteins.java

示例8: call

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
@Override
public Tuple5<String,String,Float,Float,Float> call(Tuple2<Tuple2<String,String>,Tuple2<String,String>> tuple) throws Exception {

    Tuple2<String,String> p1 = tuple._1();
    Tuple2<String,String> p2 = tuple._2();

    SubstitutionMatrix matrix = SubstitutionMatrixHelper.getBlosum65();
    GapPenalty penalty = new SimpleGapPenalty();
    penalty.setOpenPenalty(8);
    penalty.setExtensionPenalty(1);

    ProteinSequence prot1 = new ProteinSequence(p1._2());
    ProteinSequence prot2 = new ProteinSequence(p2._2());

    try {
        PairwiseSequenceAligner<ProteinSequence, AminoAcidCompound> smithWaterman =
                Alignments.getPairwiseAligner(
                        prot1,
                        prot2,
                        Alignments.PairwiseSequenceAlignerType.LOCAL,
                        penalty,
                        matrix);

        SequencePair<ProteinSequence, AminoAcidCompound> alignment = smithWaterman.getPair();

        if ( debug )
         System.out.println(alignment.toString(60));



        int numIdenticals = alignment.getNumIdenticals();

        int aligLength = alignment.getLength();

        float percentIdenticals = (numIdenticals / (float) aligLength);


        // test overlaps

        int l1 = prot1.getLength();
        int l2 = prot2.getLength();

        int size = alignment.getLength();

        AlignedSequence alignedSequence1 = alignment.getAlignedSequence(1);
        AlignedSequence alignedSequence2 = alignment.getAlignedSequence(2);

        String alignedSeq1 = alignedSequence1.getSequenceAsString().replaceAll("-","");
        String alignedSeq2 = alignedSequence2.getSequenceAsString().replaceAll("-","");

        int size1 = alignedSeq1.length();
        int size2 = alignedSeq2.length();

        float overlap1 = size1 / (float) l1;
        float overlap2 = size2 / (float) l2;

        if ( debug )
            System.out.println(p1._1() + " " + p2._1() + " size:" + size + " l1: " + l1 + " l2: " + l2 + " overlap1 " + overlap1 + " overlap2 " + overlap2 + " %id: " + percentIdenticals);

        return new Tuple5<String, String, Float,Float,Float>(p1._1(),p2._1(),overlap1,overlap2,percentIdenticals);
    } catch (Exception e) {
        System.err.println("Could not align " + p1._1() + " vs." + p2._1());
    }


    return new  Tuple5<String, String, Float,Float,Float>(p1._1(),p2._1(),0f,0f,0f);
}
 
開發者ID:biojava,項目名稱:biojava-spark,代碼行數:68,代碼來源:PairwiseSequenceComparison.java

示例9: call

import org.biojava.nbio.alignment.template.PairwiseSequenceAligner; //導入方法依賴的package包/類
@Override
public Tuple5<String,String,Float,Float,Float> call(Tuple2<Tuple2<String,String>,Tuple2<String,String>> tuple) throws Exception {

	Tuple2<String,String> p1 = tuple._1();
	Tuple2<String,String> p2 = tuple._2();

	SubstitutionMatrix<AminoAcidCompound> matrix = SubstitutionMatrixHelper.getBlosum65();
	GapPenalty penalty = new SimpleGapPenalty();
	penalty.setOpenPenalty(8);
	penalty.setExtensionPenalty(1);

	ProteinSequence prot1 = new ProteinSequence(p1._2());
	ProteinSequence prot2 = new ProteinSequence(p2._2());

	try {
		PairwiseSequenceAligner<ProteinSequence, AminoAcidCompound> smithWaterman = Alignments.getPairwiseAligner(prot1,
				prot2,
				Alignments.PairwiseSequenceAlignerType.LOCAL, penalty, matrix);

		SequencePair<ProteinSequence, AminoAcidCompound> alignment = smithWaterman.getPair();

		if ( debug )
			System.out.println(alignment.toString(60));



		int numIdenticals = alignment.getNumIdenticals();

		int aligLength = alignment.getLength();

		float percentIdenticals = (numIdenticals / (float) aligLength);


		// test overlaps

		int l1 = prot1.getLength();
		int l2 = prot2.getLength();

		int size = alignment.getLength();

		float overlap1 = l1 / (float) size;
		float overlap2 = l2 / (float) size;

		if ( debug )
			System.out.println(p1._1() + " " + p2._1() + " size:" + size + " l1: " + l1 + " l2: " + l2 + " overlap1 " + overlap1 + " overlap2 " + overlap2 + " %id: " + percentIdenticals);


		return new Tuple5<String, String, Float,Float,Float>(p1._1(),p2._1(),overlap1,overlap2,percentIdenticals);
	} catch (Exception e) {
		e.printStackTrace();
	}


	return new  Tuple5<String, String, Float,Float,Float>(p1._1(),p2._1(),0f,0f,0f);
}
 
開發者ID:biojava,項目名稱:biojava-spark,代碼行數:56,代碼來源:PairwiseSequenceComparison.java


注:本文中的org.biojava.nbio.alignment.template.PairwiseSequenceAligner.getPair方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。