spectrum = SpectrumFactory.getInstance().getSpectrum(spectrumKey);
return spectrum.getMaxIntensity() + "";
case intensity_coverage:
spectrum = SpectrumFactory.getInstance().getSpectrum(spectrumKey);
double coveredIntensity = 0;
Peptide peptide = peptideAssumption.getPeptide();
ArrayList<IonMatch> matches = peptideSpectrumAnnotator.getSpectrumAnnotation(
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value,
(MSnSpectrum) spectrum, peptide, 0, searchParameters.getFragmentIonAccuracy(), false, true);
for (IonMatch ionMatch : matches) {
coveredIntensity += ionMatch.peak.intensity;
}
double coverage = 100 * coveredIntensity / spectrum.getTotalIntensity();
return coverage + "";
case mz_error:
precursor = SpectrumFactory.getInstance().getPrecursor(spectrumKey);
return peptideAssumption.getDeltaMass(precursor.getMz(), true) + "";
case rt:
precursor = SpectrumFactory.getInstance().getPrecursor(spectrumKey);
return precursor.getRt() + "";
case algorithm_score:
int id = peptideAssumption.getAdvocate();
double score = peptideAssumption.getScore();
return Advocate.getAdvocate(id).getName() + " (" + score + ")";
case sequence:
return peptideAssumption.getPeptide().getSequence();
case missed_cleavages:
String sequence = peptideAssumption.getPeptide().getSequence();
return Peptide.getNMissedCleavages(sequence, searchParameters.getEnzyme()) + "";
case modified_sequence:
return peptideAssumption.getPeptide().getTaggedModifiedSequence(searchParameters.getModificationProfile(), false, false, true) + "";
case spectrum_charge:
precursor = SpectrumFactory.getInstance().getPrecursor(spectrumKey);
return precursor.getPossibleChargesAsString() + "";
case spectrum_file:
String spectrumFile = Spectrum.getSpectrumFile(spectrumKey);
return spectrumFile;
case spectrum_scan_number:
return SpectrumFactory.getInstance().getSpectrum(spectrumKey).getScanNumber();
case spectrum_title:
return Spectrum.getSpectrumTitle(spectrumKey);
case starred:
if (psParameter.isStarred()) {
return "1";
} else {
return "0";
}
case theoretical_mass:
return peptideAssumption.getPeptide().getMass() + "";
case validated:
return psParameter.getMatchValidationLevel().toString();
case fragment_mz_accuracy_score:
score = PsmScores.getDecreasingScore(peptideAssumption.getPeptide(),
(MSnSpectrum) SpectrumFactory.getInstance().getSpectrum(spectrumKey),
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value, searchParameters, PsmScores.aa_ms2_mz_fidelity.index);
return score + "";
case intensity_score:
score = PsmScores.getDecreasingScore(peptideAssumption.getPeptide(),
(MSnSpectrum) SpectrumFactory.getInstance().getSpectrum(spectrumKey),
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value, searchParameters, PsmScores.aa_intensity.index);
return score + "";
case sequence_coverage:
peptide = peptideAssumption.getPeptide();
spectrum = SpectrumFactory.getInstance().getSpectrum(spectrumKey);
matches = peptideSpectrumAnnotator.getSpectrumAnnotation(
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value,
(MSnSpectrum) spectrum, peptide, 0, searchParameters.getFragmentIonAccuracy(), false, true);
int sequenceLength = peptide.getSequence().length();
boolean[] aaCoverage = new boolean[sequenceLength];
for (IonMatch ionMatch : matches) {
Ion ion = ionMatch.ion;
if (ion instanceof PeptideFragmentIon) {
PeptideFragmentIon peptideFragmentIon = (PeptideFragmentIon) ion;
int number = peptideFragmentIon.getNumber();
aaCoverage[number - 1] = true;
}
}
double nIons = 0.0;
for (boolean aa : aaCoverage) {
if (aa) {
nIons += 1;
}
}
coverage = 100 * nIons / sequenceLength;
return coverage + "";
case longest_amino_acid_sequence_annotated:
peptide = peptideAssumption.getPeptide();
matches = peptideSpectrumAnnotator.getSpectrumAnnotation(
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value,
(MSnSpectrum) SpectrumFactory.getInstance().getSpectrum(spectrumKey), peptide, 0, searchParameters.getFragmentIonAccuracy(), false, true);
sequence = peptide.getSequence();
sequenceLength = sequence.length();
boolean[] coverageForward = new boolean[sequenceLength];
boolean[] coverageRewind = new boolean[sequenceLength];
for (IonMatch ionMatch : matches) {
Ion ion = ionMatch.ion;
if (ion instanceof PeptideFragmentIon) {
PeptideFragmentIon peptideFragmentIon = (PeptideFragmentIon) ion;
int number = peptideFragmentIon.getNumber();
if (peptideFragmentIon.getSubType() == PeptideFragmentIon.A_ION
|| peptideFragmentIon.getSubType() == PeptideFragmentIon.B_ION
|| peptideFragmentIon.getSubType() == PeptideFragmentIon.C_ION) {
coverageForward[number - 1] = true;
} else {
coverageRewind[number - 1] = true;
}
}
}
aaCoverage = new boolean[sequenceLength];
boolean previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = coverageForward[aaIndex];
if (current && previous) {
aaCoverage[aaIndex] = true;
}
previous = current;
}
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = coverageRewind[aaIndex];
if (current && previous) {
aaCoverage[sequenceLength - aaIndex - 1] = true;
}
previous = current;
}
StringBuilder currentTag = new StringBuilder();
String longestTag = new String();
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
if (aaCoverage[aaIndex]) {
currentTag.append(sequence.charAt(aaIndex));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.toString();
}
currentTag = new StringBuilder();
}
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.toString();
}
return longestTag;
case longest_amino_acid_sequence_annotated_single_serie:
peptide = peptideAssumption.getPeptide();
matches = peptideSpectrumAnnotator.getSpectrumAnnotation(
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value,
(MSnSpectrum) SpectrumFactory.getInstance().getSpectrum(spectrumKey), peptide, 0, searchParameters.getFragmentIonAccuracy(), false, true);
sequence = peptide.getSequence();
sequenceLength = sequence.length();
HashMap<Integer, boolean[]> ionCoverage = new HashMap<Integer, boolean[]>(6);
ionCoverage.put(PeptideFragmentIon.A_ION, new boolean[sequenceLength]);
ionCoverage.put(PeptideFragmentIon.B_ION, new boolean[sequenceLength]);
ionCoverage.put(PeptideFragmentIon.C_ION, new boolean[sequenceLength]);
ionCoverage.put(PeptideFragmentIon.X_ION, new boolean[sequenceLength]);
ionCoverage.put(PeptideFragmentIon.Y_ION, new boolean[sequenceLength]);
ionCoverage.put(PeptideFragmentIon.Z_ION, new boolean[sequenceLength]);
for (IonMatch ionMatch : matches) {
if (ionMatch.charge.value == 1) {
Ion ion = ionMatch.ion;
if (ion instanceof PeptideFragmentIon) {
PeptideFragmentIon peptideFragmentIon = (PeptideFragmentIon) ion;
int number = peptideFragmentIon.getNumber();
if (peptideFragmentIon.getSubType() == PeptideFragmentIon.A_ION && peptideFragmentIon.getNeutralLosses().isEmpty()) {
ionCoverage.get(PeptideFragmentIon.A_ION)[number - 1] = true;
} else if (peptideFragmentIon.getSubType() == PeptideFragmentIon.B_ION && peptideFragmentIon.getNeutralLosses().isEmpty()) {
ionCoverage.get(PeptideFragmentIon.B_ION)[number - 1] = true;
} else if (peptideFragmentIon.getSubType() == PeptideFragmentIon.C_ION && peptideFragmentIon.getNeutralLosses().isEmpty()) {
ionCoverage.get(PeptideFragmentIon.C_ION)[number - 1] = true;
} else if (peptideFragmentIon.getSubType() == PeptideFragmentIon.X_ION && peptideFragmentIon.getNeutralLosses().isEmpty()) {
ionCoverage.get(PeptideFragmentIon.X_ION)[number - 1] = true;
} else if (peptideFragmentIon.getSubType() == PeptideFragmentIon.Y_ION && peptideFragmentIon.getNeutralLosses().isEmpty()) {
ionCoverage.get(PeptideFragmentIon.Y_ION)[number - 1] = true;
} else if (peptideFragmentIon.getSubType() == PeptideFragmentIon.Z_ION && peptideFragmentIon.getNeutralLosses().isEmpty()) {
ionCoverage.get(PeptideFragmentIon.Z_ION)[number - 1] = true;
}
}
}
}
longestTag = new String();
currentTag = new StringBuilder();
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = ionCoverage.get(PeptideFragmentIon.A_ION)[aaIndex];
if (current && previous) {
currentTag.append(sequence.charAt(aaIndex));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.toString();
}
currentTag = new StringBuilder();
}
previous = current;
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = ionCoverage.get(PeptideFragmentIon.B_ION)[aaIndex];
if (current && previous) {
currentTag.append(sequence.charAt(aaIndex));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.toString();
}
currentTag = new StringBuilder();
}
previous = current;
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = ionCoverage.get(PeptideFragmentIon.C_ION)[aaIndex];
if (current && previous) {
currentTag.append(sequence.charAt(aaIndex));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.toString();
}
currentTag = new StringBuilder();
}
previous = current;
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = ionCoverage.get(PeptideFragmentIon.X_ION)[aaIndex];
if (current && previous) {
currentTag.append(sequence.charAt(sequenceLength - aaIndex - 1));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
}
previous = current;
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = ionCoverage.get(PeptideFragmentIon.Y_ION)[aaIndex];
if (current && previous) {
currentTag.append(sequence.charAt(sequenceLength - aaIndex - 1));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
}
previous = current;
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
previous = true;
for (int aaIndex = 0; aaIndex < sequenceLength; aaIndex++) {
boolean current = ionCoverage.get(PeptideFragmentIon.Z_ION)[aaIndex];
if (current && previous) {
currentTag.append(sequence.charAt(sequenceLength - aaIndex - 1));
} else {
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
currentTag = new StringBuilder();
}
previous = current;
}
if (currentTag.length() > longestTag.length()) {
longestTag = currentTag.reverse().toString();
}
return longestTag;
case amino_acids_annotated:
peptide = peptideAssumption.getPeptide();
spectrum = SpectrumFactory.getInstance().getSpectrum(spectrumKey);
matches = peptideSpectrumAnnotator.getSpectrumAnnotation(
annotationPreferences.getIonTypes(), annotationPreferences.getNeutralLosses(), annotationPreferences.getValidatedCharges(),
peptideAssumption.getIdentificationCharge().value,
(MSnSpectrum) spectrum, peptide, 0, searchParameters.getFragmentIonAccuracy(), false, true);
sequence = peptide.getSequence();
sequenceLength = sequence.length();
coverageForward = new boolean[sequenceLength];
coverageRewind = new boolean[sequenceLength];
for (IonMatch ionMatch : matches) {
Ion ion = ionMatch.ion;