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


Java Ion類代碼示例

本文整理匯總了Java中com.compomics.util.experiment.biology.Ion的典型用法代碼示例。如果您正苦於以下問題:Java Ion類的具體用法?Java Ion怎麽用?Java Ion使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Ion類屬於com.compomics.util.experiment.biology包,在下文中一共展示了Ion類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getMatchKey

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Returns the key for the ion match uniquely representing a peak
 * annotation. If a cache is given it will be used to store keys, ignored if
 * null.
 *
 * @param ion the ion matched
 * @param charge the charge
 * @param ionMatchKeysCache a cache for the ion match keys
 *
 * @return the key for the ion match
 */
public static String getMatchKey(Ion ion, int charge, IonMatchKeysCache ionMatchKeysCache) {
    if (ionMatchKeysCache != null) {
        return ionMatchKeysCache.getMatchKey(ion, charge);
    }
    Ion.IonType ionType = ion.getType();
    int ionTypeIndex = ionType.index;
    int ionSubType = ion.getSubType();
    int fragmentIonNumber;
    if (ionType == Ion.IonType.PEPTIDE_FRAGMENT_ION) {
        PeptideFragmentIon fragmentIon = ((PeptideFragmentIon) ion);
        fragmentIonNumber = fragmentIon.getNumber();
    } else if (ionType == Ion.IonType.TAG_FRAGMENT_ION) {
        TagFragmentIon tagFragmentIon = ((TagFragmentIon) ion);
        fragmentIonNumber = tagFragmentIon.getNumber();
    } else {
        fragmentIonNumber = 0;
    }
    String neutralLossesAsString = ion.getNeutralLossesAsString();
    String key = getMatchKey(ionTypeIndex, ionSubType, fragmentIonNumber, neutralLossesAsString, charge);
    return key;
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:33,代碼來源:IonMatch.java

示例2: clone

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Clones the settings.
 *
 * @return a clone of this object
 */
public AnnotationSettings clone() {
    AnnotationSettings annotationSettings = new AnnotationSettings();
    annotationSettings.setYAxisZoomExcludesBackgroundPeaks(yAxisZoomExcludesBackgroundPeaks);
    annotationSettings.setShowAllPeaks(showAllPeaks);
    annotationSettings.setIntensityLimit(intensityLimit);
    annotationSettings.setAutomaticAnnotation(automaticAnnotation);
    annotationSettings.setFragmentIonAccuracy(fragmentIonAccuracy);
    annotationSettings.setFragmentIonPpm(fragmentIonPpm);
    annotationSettings.setShowForwardIonDeNovoTags(showForwardIonDeNovoTags);
    annotationSettings.setShowRewindIonDeNovoTags(showRewindIonDeNovoTags);
    annotationSettings.setDeNovoCharge(deNovoCharge);
    annotationSettings.setTiesResolution(getTiesResolution());
    annotationSettings.setNeutralLossesSequenceAuto(neutralLossesAuto);
    annotationSettings.setReporterIons(getReporterIons());
    annotationSettings.setReporterIons(getRelatedIons());
    for (NeutralLoss neutralLoss : neutralLossesList) {
        annotationSettings.addNeutralLoss(neutralLoss);
    }
    for (Ion.IonType ionType : selectedIonsMap.keySet()) {
        for (Integer subType : selectedIonsMap.get(ionType)) {
            annotationSettings.addIonType(ionType, subType);
        }
    }
    return annotationSettings;
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:31,代碼來源:AnnotationSettings.java

示例3: setPeptide

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Sets a new peptide to match.
 *
 * @param peptide the new peptide
 * @param possibleFragmentIons the possible fragment ions of the peptide
 * @param precursorCharge the new precursor charge
 * @param specificAnnotationSettings if provided, only the ions detectable
 * using these settings will be selected
 */
public void setPeptide(Peptide peptide, HashMap<Integer, HashMap<Integer, ArrayList<Ion>>> possibleFragmentIons, int precursorCharge, SpecificAnnotationSettings specificAnnotationSettings) {
    if (specificAnnotationSettings != null && super.specificAnnotationSettings == null
            || specificAnnotationSettings == null && super.specificAnnotationSettings != null
            || specificAnnotationSettings != null && super.specificAnnotationSettings != null && specificAnnotationSettings != super.specificAnnotationSettings
            || this.peptide == null
            || !this.peptide.getKey().equals(peptide.getKey())
            || !this.peptide.sameModificationsAs(peptide)
            || this.precursorCharge != precursorCharge) {

        // Set new values
        this.peptide = peptide;
        this.precursorCharge = precursorCharge;
        if (possibleFragmentIons == null) {
            theoreticalFragmentIons = fragmentFactory.getFragmentIons(peptide, specificAnnotationSettings);
        } else {
            theoreticalFragmentIons = possibleFragmentIons;
        }
        if (massShift != 0 || massShiftNTerm != 0 || massShiftCTerm != 0) {
            updateMassShifts();
        }
    }
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:32,代碼來源:PeptideSpectrumAnnotator.java

示例4: matchInSpectrum

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Matches a theoretic ion in the spectrum. Returns an IonMatch containing
 * the ion and the peak. Null if not found.
 *
 * @param theoreticIon the theoretic ion
 * @param inspectedCharge the expected charge
 *
 * @return the IonMatch between the ion and the peak
 */
protected IonMatch matchInSpectrum(Ion theoreticIon, Integer inspectedCharge) {

    double fragmentMz = theoreticIon.getTheoreticMz(inspectedCharge);

    // Get the peaks matching the desired m/z
    ArrayList<Peak> matchedPeaks = spectrumIndex.getMatchingPeaks(fragmentMz);

    if (matchedPeaks.isEmpty()) {
        return null;
    }

    // Select the most accurate or most intense according to the annotation settings
    IonMatch ionMatch = new IonMatch(null, theoreticIon, inspectedCharge);
    ionMatch.peak = (matchedPeaks.size() == 1) ? matchedPeaks.get(0) : getBestPeak(matchedPeaks, ionMatch);
    return ionMatch;
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:26,代碼來源:SpectrumAnnotator.java

示例5: chargeValidated

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Returns a boolean indicating whether the given charge can be found on the
 * given fragment ion.
 *
 * @param theoreticIon the ion of interest
 * @param charge the candidate charge
 * @param precursorCharge the precursor charge
 *
 * @return a boolean indicating whether the given charge can be found on the
 * given fragment ion
 */
public boolean chargeValidated(Ion theoreticIon, int charge, int precursorCharge) {
    if (charge == 1) {
        return true;
    }
    switch (theoreticIon.getType()) {
        case IMMONIUM_ION:
        case RELATED_ION: // note: it is possible to implement higher charges but then modify IonMatch.getPeakAnnotation(boolean html) as well to see the charge displayed on the spectrum
            return false;
        case REPORTER_ION: // note: it is possible to implement higher charges but then modify IonMatch.getPeakAnnotation(boolean html) as well to see the charge displayed on the spectrum
            return false;
        case PEPTIDE_FRAGMENT_ION:
            PeptideFragmentIon peptideFragmentIon = ((PeptideFragmentIon) theoreticIon);
            return charge <= peptideFragmentIon.getNumber() && charge < precursorCharge;
        case TAG_FRAGMENT_ION:
            TagFragmentIon tagFragmentIon = ((TagFragmentIon) theoreticIon);
            return charge <= tagFragmentIon.getNumber() && charge < precursorCharge;
        case PRECURSOR_ION:
            return charge >= precursorCharge;
        default:
            throw new UnsupportedOperationException("Ion type " + theoreticIon.getTypeAsString() + " not implemented in the spectrum annotator.");
    }
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:34,代碼來源:SpectrumAnnotator.java

示例6: Identify

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 *
 * @param ms an MSnSpectrum object to compared
 * @param peptide a selected peptide entry from db within given precursor
 * tolerance
 * @param fragment_tolerance
 * @param isSequestLikeScore true:SEQUEST-like score, false:Andromeda-like
 * score
 * @param isCorrectMatch true:correct match if either target/UPS,
 * false:incorrect match if either decoy/Pfu
 * @param totalScoredPeps total number of peptides matched to a given ms
 * @param correctionFactor correction factor value for SEQUEST-like scoring
 * (to compute Xcorr)
 * @param hasAllPossCharge true: ions with all possible charges, false: only
 * up to doubly charged ions
 */
public Identify(MSnSpectrum ms, Peptide peptide, double fragment_tolerance, boolean isSequestLikeScore, boolean isCorrectMatch, int totalScoredPeps, int correctionFactor, boolean hasAllPossCharge) {
    this.isSequestLikeScore = isSequestLikeScore;
    this.fragment_tolerance = fragment_tolerance;
    this.isCorrectMatch = isCorrectMatch;
    spectrum = ms;
    this.peptide = peptide;
    // get theoretical ions..
    HashMap<Integer, ArrayList<Ion>> product_ions_peptideA = fragmentFactory.getFragmentIons(peptide).get(0);
    // add all b- ions and y-ions with uniform intensity of 50
    theoretical_ions = product_ions_peptideA.get(PeptideFragmentIon.Y_ION);
    theoretical_ions.addAll(product_ions_peptideA.get(PeptideFragmentIon.B_ION));
    int prec = spectrum.getPrecursor().getPossibleCharges().get(0).value;
    if (hasAllPossCharge) {
        generate_theoretical_ions(prec);
    } else if (!hasAllPossCharge && prec >= 2) {
        generate_theoretical_ions(2);
    } else {
        generate_theoretical_ions(1);
    }
    this.totalScoredPeps = totalScoredPeps;
    this.correctionFactor = correctionFactor;
    score = match_and_score();
}
 
開發者ID:compomics,項目名稱:spectrum_similarity,代碼行數:40,代碼來源:Identify.java

示例7: LookUpFragmentMZ

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
public float LookUpFragmentMZ(PeptideFragmentIon.IonType fragmentIonType, int num) {
    for (Ion frag : GetFragments()) {
        if (frag.getType() == fragmentIonType && "".equals(frag.getNeutralLossesAsString()) && ((PeptideFragmentIon) frag).getNumber() == num) {
            return (float) (frag.getTheoreticMass() + ElementaryIon.proton.getTheoreticMass());
        }
    }
    return 0f;
}
 
開發者ID:YcheCourseProject,項目名稱:DIA-Umpire-Maven,代碼行數:9,代碼來源:PepIonID.java

示例8: SetFragments

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
private void SetFragments() {
    peptide = GetPepFactory();
    HashMap<Integer, HashMap<Integer, ArrayList<Ion>>> allfragment = IonFactory.getInstance().getFragmentIons(peptide);
    Fragments = new ArrayList<>();
    Fragments.addAll(allfragment.get(Ion.IonType.PEPTIDE_FRAGMENT_ION.index).get(PeptideFragmentIon.B_ION));
    Fragments.addAll(allfragment.get(Ion.IonType.PEPTIDE_FRAGMENT_ION.index).get(PeptideFragmentIon.Y_ION));
}
 
開發者ID:YcheCourseProject,項目名稱:DIA-Umpire-Maven,代碼行數:8,代碼來源:PepIonID.java

示例9: getCurrentFragmentIonTypes

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Returns a map of the currently selected fragment ion types.
 *
 * @return a map of the currently selected fragment ion types
 */
private HashMap<IonType, ArrayList<Integer>> getCurrentFragmentIonTypes() {

    HashMap<IonType, ArrayList<Integer>> fragmentIontypes = new HashMap<IonType, ArrayList<Integer>>();
    fragmentIontypes.put(IonType.PEPTIDE_FRAGMENT_ION, new ArrayList<Integer>());

    if (aIonsJCheckBox.isSelected()) {
        fragmentIontypes.get(IonType.PEPTIDE_FRAGMENT_ION).add(PeptideFragmentIon.A_ION);
    }

    if (bIonsJCheckBox.isSelected()) {
        fragmentIontypes.get(IonType.PEPTIDE_FRAGMENT_ION).add(PeptideFragmentIon.B_ION);
    }

    if (cIonsJCheckBox.isSelected()) {
        fragmentIontypes.get(IonType.PEPTIDE_FRAGMENT_ION).add(PeptideFragmentIon.C_ION);
    }

    if (xIonsJCheckBox.isSelected()) {
        fragmentIontypes.get(IonType.PEPTIDE_FRAGMENT_ION).add(PeptideFragmentIon.X_ION);
    }

    if (yIonsJCheckBox.isSelected()) {
        fragmentIontypes.get(IonType.PEPTIDE_FRAGMENT_ION).add(PeptideFragmentIon.Y_ION);
    }

    if (zIonsJCheckBox.isSelected()) {
        fragmentIontypes.get(IonType.PEPTIDE_FRAGMENT_ION).add(PeptideFragmentIon.Z_ION);
    }

    if (otherIonsJCheckBox.isSelected()) {
        fragmentIontypes.put(IonType.IMMONIUM_ION, Ion.getPossibleSubtypes(IonType.IMMONIUM_ION));
        fragmentIontypes.put(IonType.PRECURSOR_ION, Ion.getPossibleSubtypes(IonType.PRECURSOR_ION));
        fragmentIontypes.put(IonType.REPORTER_ION, Ion.getPossibleSubtypes(IonType.REPORTER_ION));
    }

    return fragmentIontypes;
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:43,代碼來源:UtilitiesDemo.java

示例10: isSameAs

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
@Override
public boolean isSameAs(Ion anotherIon) {
    if (anotherIon instanceof ReporterIon) {
        ReporterIon otherIon = (ReporterIon) anotherIon;
        return isSameAs(otherIon);
    }
    return false;
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:9,代碼來源:ReporterIon.java

示例11: isSameAs

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
@Override
public boolean isSameAs(Ion anotherIon) {
    return anotherIon.getType() == Ion.IonType.TAG_FRAGMENT_ION
            && anotherIon.getSubType() == subType
            && ((PeptideFragmentIon) anotherIon).getNumber() == number
            && anotherIon.getNeutralLossesAsString().equals(getNeutralLossesAsString());
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:8,代碼來源:TagFragmentIon.java

示例12: isSameAs

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
@Override
public boolean isSameAs(Ion anotherIon) {
    if (anotherIon instanceof RelatedIon) {
        RelatedIon otherIon = (RelatedIon) anotherIon;
        return isSameAs(otherIon);
    }
    return false;
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:9,代碼來源:RelatedIon.java

示例13: isSameAs

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
@Override
public boolean isSameAs(Ion anotherIon) {
    return anotherIon.getType() == IonType.ELEMENTARY_ION
            && anotherIon.getSubType() == subType
            && anotherIon.getTheoreticMass() == theoreticMass1
            && anotherIon.getNeutralLossesAsString().equals(getNeutralLossesAsString());
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:8,代碼來源:ElementaryIon.java

示例14: isSameAs

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
@Override
public boolean isSameAs(Ion anotherIon) {
    return anotherIon.getType() == IonType.PEPTIDE_FRAGMENT_ION
            && anotherIon.getSubType() == subType
            && ((PeptideFragmentIon) anotherIon).getNumber() == number
            && anotherIon.getNeutralLossesAsString().equals(getNeutralLossesAsString());
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:8,代碼來源:PeptideFragmentIon.java

示例15: getScore

import com.compomics.util.experiment.biology.Ion; //導入依賴的package包/類
/**
 * Scores the match between the given peptide and spectrum using the
 * complementarity of the matched peaks. For every residue, a list of
 * matched peaks is established and if any is found, the score per residue
 * is the log of the number of matched ions. The peptide score is the
 * average of the residue scores.
 *
 * @param peptide the peptide of interest
 * @param spectrum the spectrum of interest
 * @param annotationPreferences the general spectrum annotation preferences
 * @param specificAnnotationPreferences the annotation preferences specific to this psm
 * @param peptideSpectrumAnnotator the spectrum annotator to use
 *
 * @return the score of the match
 * 
 * @throws java.lang.InterruptedException exception thrown if the thread is
 * interrupted
 * @throws org.apache.commons.math.MathException exception thrown if a math exception occurred when estimating the noise level 
 */
public double getScore(Peptide peptide, MSnSpectrum spectrum, AnnotationSettings annotationPreferences, SpecificAnnotationSettings specificAnnotationPreferences, PeptideSpectrumAnnotator peptideSpectrumAnnotator) throws InterruptedException, MathException {

    int sequenceLength = peptide.getSequence().length();

    ArrayList<IonMatch> matches = peptideSpectrumAnnotator.getSpectrumAnnotation(annotationPreferences, specificAnnotationPreferences,
            spectrum, peptide);

    HashMap<Integer, Double> residueToMatchesMap = new HashMap<Integer, Double>(sequenceLength);
    for (int i = 1; i <= sequenceLength; i++) {
        residueToMatchesMap.put(i, 0.0);
    }
    for (IonMatch ionMatch : matches) {
        Ion ion = ionMatch.ion;
        if (ion instanceof PeptideFragmentIon) {
            PeptideFragmentIon peptideFragmentIon = (PeptideFragmentIon) ion;
            int number = peptideFragmentIon.getNumber();
            residueToMatchesMap.put(number, residueToMatchesMap.get(number) + 1);
        }
    }

    ArrayList<Double> scorePerResidue = new ArrayList<Double>(residueToMatchesMap.size());
    for (int number = 1; number <= sequenceLength; number++) {
        Double nIons = residueToMatchesMap.get(number);
        if (nIons != null) {
            scorePerResidue.add(FastMath.log(nIons) / log2);
        }
    }
    
    double mean = 0;
    
    if (!scorePerResidue.isEmpty()) {
        mean = BasicMathFunctions.mean(scorePerResidue);
    }

    return Math.pow(2, mean);
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:56,代碼來源:ComplementarityScore.java


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