当前位置: 首页>>代码示例>>Java>>正文


Java SAMSequenceDictionary.size方法代码示例

本文整理汇总了Java中htsjdk.samtools.SAMSequenceDictionary.size方法的典型用法代码示例。如果您正苦于以下问题:Java SAMSequenceDictionary.size方法的具体用法?Java SAMSequenceDictionary.size怎么用?Java SAMSequenceDictionary.size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在htsjdk.samtools.SAMSequenceDictionary的用法示例。


在下文中一共展示了SAMSequenceDictionary.size方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: MRUCachingSAMSequenceDictionary

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
/**
 * Create a new MRUCachingSAMSequenceDictionary that provides information about sequences in dict
 *
 * @param dict a non-null, non-empty sequencing dictionary
 */
public MRUCachingSAMSequenceDictionary(final SAMSequenceDictionary dict) {
    if (dict == null) throw new IllegalArgumentException("Dictionary cannot be null");
    if (dict.size() == 0)
        throw new IllegalArgumentException("Dictionary cannot have size zero");

    this.dict = dict;
}
 
开发者ID:PAA-NCIC,项目名称:SparkSeq,代码行数:13,代码来源:MRUCachingSAMSequenceDictionary.java

示例2: prettyPrintSequenceRecords

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
public static String prettyPrintSequenceRecords ( SAMSequenceDictionary sequenceDictionary ) {
    String[] sequenceRecordNames = new String[sequenceDictionary.size()];
    int sequenceRecordIndex = 0;
    for (SAMSequenceRecord sequenceRecord : sequenceDictionary.getSequences())
        sequenceRecordNames[sequenceRecordIndex++] = sequenceRecord.getSequenceName();
    return Arrays.deepToString(sequenceRecordNames);
}
 
开发者ID:PAA-NCIC,项目名称:SparkSeq,代码行数:8,代码来源:ReadUtils.java

示例3: correctCoordsAgainstSeqDict

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
public void correctCoordsAgainstSeqDict(SAMSequenceDictionary samSeqDict) throws InvalidGenomicCoordsException, IOException{

		if(samSeqDict == null || samSeqDict.size() == 0){
			// Just check start pos
			if (this.from <=0 ){
				this.from= 1;
			}			
			return;
		}
		
		if(this.chrom == null){ // Nothing to do
			return;
		}
		if(samSeqDict.getSequence(this.chrom) == null){ // Not found: Nullify everything
			this.chrom= null;
			this.from= null;
			this.to= null;
			return;
		} 
		// Reset min coords
		if( this.from != null && this.from < 1) {
			this.from= 1;
		}
		// Reset max coords
		if( this.from != null && this.from > samSeqDict.getSequence(this.chrom).getSequenceLength() ) {
			this.from= samSeqDict.getSequence(this.chrom).getSequenceLength() - this.getGenomicWindowSize() + 1;
			if(this.from <= 0){
				this.from= 1;
			}
			this.to= this.from + this.getGenomicWindowSize() - 1;
			if(this.to > samSeqDict.getSequence(this.chrom).getSequenceLength()){
				this.to= samSeqDict.getSequence(this.chrom).getSequenceLength();
			}
		}
		if( this.to != null && this.to > samSeqDict.getSequence(this.chrom).getSequenceLength() ) {			
			this.to= samSeqDict.getSequence(this.chrom).getSequenceLength();
		}
	}
 
开发者ID:dariober,项目名称:ASCIIGenome,代码行数:39,代码来源:GenomicCoords.java

示例4: compareDictionaries

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
/**
 * Workhorse routine that takes two dictionaries and returns their compatibility.
 *
 * @param dict1 first sequence dictionary
 * @param dict2 second sequence dictionary
 * @param checkContigOrdering if true, perform checks related to contig ordering: forbid lexicographically-sorted
 *                            dictionaries, and require common contigs to be in the same relative order and at the
 *                            same absolute indices
 * @return A SequenceDictionaryCompatibility enum value describing the compatibility of the two dictionaries
 */
public static SequenceDictionaryCompatibility compareDictionaries( final SAMSequenceDictionary dict1, final SAMSequenceDictionary dict2, final boolean checkContigOrdering ) {
    if ( checkContigOrdering && (nonCanonicalHumanContigOrder(dict1) || nonCanonicalHumanContigOrder(dict2)) ) {
        return SequenceDictionaryCompatibility.NON_CANONICAL_HUMAN_ORDER;
    }

    final Set<String> commonContigs = getCommonContigsByName(dict1, dict2);

    if (commonContigs.isEmpty()) {
        return SequenceDictionaryCompatibility.NO_COMMON_CONTIGS;
    }
    else if ( ! commonContigsHaveSameLengths(commonContigs, dict1, dict2) ) {
        return SequenceDictionaryCompatibility.UNEQUAL_COMMON_CONTIGS;
    }

    final boolean commonContigsAreInSameRelativeOrder = commonContigsAreInSameRelativeOrder(commonContigs, dict1, dict2);

    if ( checkContigOrdering && ! commonContigsAreInSameRelativeOrder ) {
        return SequenceDictionaryCompatibility.OUT_OF_ORDER;
    }
    else if ( commonContigsAreInSameRelativeOrder && commonContigs.size() == dict1.size() && commonContigs.size() == dict2.size() ) {
        return SequenceDictionaryCompatibility.IDENTICAL;
    }
    else if ( checkContigOrdering && ! commonContigsAreAtSameIndices(commonContigs, dict1, dict2) ) {
        return SequenceDictionaryCompatibility.DIFFERENT_INDICES;
    }
    else if ( supersets(dict1, dict2) ) {
        return SequenceDictionaryCompatibility.SUPERSET;
    }
    else {
        return SequenceDictionaryCompatibility.COMMON_SUBSET;
    }
}
 
开发者ID:broadinstitute,项目名称:gatk,代码行数:43,代码来源:SequenceDictionaryUtils.java

示例5: prettyPrintSequenceRecords

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
public static String prettyPrintSequenceRecords( final SAMSequenceDictionary sequenceDictionary ) {
    final String[] sequenceRecordNames = new String[sequenceDictionary.size()];
    int sequenceRecordIndex = 0;
    for (final SAMSequenceRecord sequenceRecord : sequenceDictionary.getSequences()) {
        sequenceRecordNames[sequenceRecordIndex++] = sequenceRecord.getSequenceName();
    }
    return Arrays.deepToString(sequenceRecordNames);
}
 
开发者ID:broadinstitute,项目名称:gatk,代码行数:9,代码来源:ReadUtils.java

示例6: getChromosomeNames

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
private String[] getChromosomeNames(SAMSequenceDictionary dict) {
    String[] chrs = new String[dict.size()];
    for(int i = 0; i < dict.size(); i++) 
        chrs[i] = dict.getSequence(i).getSequenceName();
    return chrs;
}
 
开发者ID:biointec,项目名称:halvade,代码行数:7,代码来源:ChromosomeSplitter.java

示例7: getReferenceSequenceDictionaryFromMap

import htsjdk.samtools.SAMSequenceDictionary; //导入方法依赖的package包/类
/**
 * Given a reference map, get a SAMSequenceDictionary that lists its contigs and their length.
 * Note that this does NOT use the referenceContig order from the API. Instead, we'll sort them
 * and try to match the read sequence dictionary order, if given.
 *
 * @param referenceMap - return value from getReferenceNameToReferenceTable
 * @param optReadSequenceDictionaryToMatch - (optional) the sequence dictionary of the reads, we'll match its order if possible.
 * @return a SAMSequenceDictionary that lists the referenceset's contigs and their length.
 */
public SAMSequenceDictionary getReferenceSequenceDictionaryFromMap(final Map<String, Reference> referenceMap, final SAMSequenceDictionary optReadSequenceDictionaryToMatch) {
    SAMSequenceDictionary refDictionary = new SAMSequenceDictionary();
    ArrayList<SAMSequenceRecord> refContigs = new ArrayList<>();

    for (Map.Entry<String, Reference> e : referenceMap.entrySet()) {
        if (e.getKey()!=null && e.getValue().getLength()!=null) {
            refContigs.add(new SAMSequenceRecord(e.getKey(), e.getValue().getLength().intValue()));
        }
    }

    HashMap<String,Integer> indexBuilder = null;
    if (null!=optReadSequenceDictionaryToMatch) {
        indexBuilder = new LinkedHashMap<>();
        for (int i=0; i<optReadSequenceDictionaryToMatch.size(); i++) {
            final SAMSequenceRecord sequence = optReadSequenceDictionaryToMatch.getSequence(i);
            indexBuilder.put(sequence.getSequenceName(), i);
        }
    }
    final Map<String,Integer> optReadSequenceDictionaryToMatchIndex = indexBuilder;

    // GATK requires human contigs in karyotypic order: 1, 2, ..., 10, 11, ..., 20, 21, 22, X, Y with M either leading or trailing these contigs.
    // So we sort them.
    Collections.sort(refContigs, new Comparator<SAMSequenceRecord>() {
        @Override
        public int compare(SAMSequenceRecord o1, SAMSequenceRecord o2) {

            // if those are ordered in the readDictionary, then match that order
            if (null != optReadSequenceDictionaryToMatchIndex) {
                if (optReadSequenceDictionaryToMatchIndex.containsKey(o1.getSequenceName()) && optReadSequenceDictionaryToMatchIndex.containsKey(o2.getSequenceName())) {
                    return optReadSequenceDictionaryToMatchIndex.get(o1.getSequenceName()).compareTo(optReadSequenceDictionaryToMatchIndex.get(o2.getSequenceName()));
                }
            }

            // otherwise, order them in karyotypic order.
            int r1 = getRank(o1.getSequenceName());
            int r2 = getRank(o2.getSequenceName());
            if (r1 < r2) return -1;
            if (r2 < r1) return 1;
            return o1.getSequenceName().compareTo(o2.getSequenceName());
        }

        private int getRank(String name) {
            if (name.equalsIgnoreCase("x")) return 23;
            if (name.equalsIgnoreCase("y")) return 24;
            if (name.equalsIgnoreCase("m")) return 25;
            if (name.equalsIgnoreCase("mt")) return 25;
            StringBuilder b = new StringBuilder();
            for (char c : name.toCharArray()) {
                if (Character.isDigit(c)) {
                    b.append(c);
                }
            }
            String numsOnly = b.toString();
            if (numsOnly.isEmpty()) return 0;
            return Integer.parseInt(numsOnly);
        }
    });

    for (SAMSequenceRecord s : refContigs) {
        refDictionary.addSequence(s);
    }
    return refDictionary;
}
 
开发者ID:broadinstitute,项目名称:gatk,代码行数:73,代码来源:ReferenceAPISource.java


注:本文中的htsjdk.samtools.SAMSequenceDictionary.size方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。