writer.write("Validation" + SEPARATOR);
writer.write("Decoy" + SEPARATOR);
writer.write(System.getProperty("line.separator"));
PSParameter psParameter = new PSParameter();
int psmCounter = 0;
HashMap<String, ArrayList<String>> spectrumKeys = identification.getSpectrumIdentificationMap();
int fileCounter = 0;
for (String spectrumFile : spectrumKeys.keySet()) {
progressDialog.setTitle("Loading Spectrum Matches. Please Wait... (" + ++fileCounter + "/" + spectrumKeys.size() + ")");
identification.loadSpectrumMatches(spectrumKeys.get(spectrumFile), progressDialog);
progressDialog.setTitle("Loading Spectrum Matches Details. Please Wait... (" + fileCounter + "/" + spectrumKeys.size() + ")");
identification.loadSpectrumMatchParameters(spectrumKeys.get(spectrumFile), psParameter, progressDialog);
progressDialog.setTitle("Copying Spectrum Matches Phospho Details to File. Please Wait... (" + fileCounter + "/" + spectrumKeys.size() + ")");
progressDialog.setMaxPrimaryProgressCounter(spectrumKeys.get(spectrumFile).size());
progressDialog.setValue(0);
for (String psmKey : spectrumKeys.get(spectrumFile)) {
if (progressDialog.isRunCanceled()) {
break;
}
SpectrumMatch spectrumMatch = identification.getSpectrumMatch(psmKey);
psParameter = (PSParameter) identification.getSpectrumMatchParameter(psmKey, psParameter);
PeptideAssumption bestAssumption = spectrumMatch.getBestPeptideAssumption();
writer.write(++psmCounter + SEPARATOR);
String proteinAccessions = "";
String proteinDescriptions = "";
for (String protein : bestAssumption.getPeptide().getParentProteins(peptideShakerGUI.getSequenceMatchingPreferences())) {
if (!proteinAccessions.equals("")) {
proteinAccessions += ", ";
proteinDescriptions += "; ";
}
proteinAccessions += protein;
proteinDescriptions += sequenceFactory.getHeader(protein).getSimpleProteinDescription();
}
writer.write(proteinAccessions + SEPARATOR);
writer.write(proteinDescriptions + SEPARATOR);
String sequence = bestAssumption.getPeptide().getSequence();
writer.write(sequence + SEPARATOR);
HashMap<String, ArrayList<Integer>> modMap = new HashMap<String, ArrayList<Integer>>();
for (ModificationMatch modificationMatch : bestAssumption.getPeptide().getModificationMatches()) {
if (modificationMatch.isVariable()) {
if (!modMap.containsKey(modificationMatch.getTheoreticPtm())) {
modMap.put(modificationMatch.getTheoreticPtm(), new ArrayList<Integer>());
}
modMap.get(modificationMatch.getTheoreticPtm()).add(modificationMatch.getModificationSite());
}
}
boolean first = true, first2;
ArrayList<String> mods = new ArrayList<String>(modMap.keySet());
Collections.sort(mods);
for (String mod : mods) {
if (first) {
first = false;
} else {
writer.write(", ");
}
first2 = true;
writer.write(mod + "(");
for (int aa : modMap.get(mod)) {
if (first2) {
first2 = false;
} else {
writer.write(", ");
}
writer.write(aa + "");
}
writer.write(")");
}
writer.write(SEPARATOR);
int nPhospho = 0;
ArrayList<String> modList = new ArrayList<String>();
for (ModificationMatch modificationMatch : bestAssumption.getPeptide().getModificationMatches()) {
if (modificationMatch.isVariable()) {
String ptmName = modificationMatch.getTheoreticPtm();
if (ptmName.contains("phospho")) {
nPhospho++;
}
PTM refPtm = ptmFactory.getPTM(ptmName);
for (String equivalentPtm : ptmProfile.getSimilarNotFixedModifications(refPtm.getMass())) {
if (!modList.contains(equivalentPtm)) {
modList.add(equivalentPtm);
}
}
}
}
Collections.sort(modList);
PSPtmScores ptmScores = new PSPtmScores();
first = true;
StringBuilder dLocalizations = new StringBuilder();
StringBuilder probabilisticLocalizations = new StringBuilder();
String mdLocation = "";
String mdScore = "";
String[] split = sequence.split("[STY]");
int nSites = split.length - 1;
ArrayList<String> phosphoNames = new ArrayList<String>();
for (String mod : modList) {
if (mod.contains("phospho")) {
phosphoNames.add(mod);
if (spectrumMatch.getUrParam(ptmScores) != null) {
ptmScores = (PSPtmScores) spectrumMatch.getUrParam(new PSPtmScores());
if (ptmScores != null && ptmScores.getPtmScoring(mod) != null) {
PtmScoring ptmScoring = ptmScores.getPtmScoring(mod);
ArrayList<Integer> sites = new ArrayList<Integer>(ptmScoring.getProbabilisticSites());
Collections.sort(sites);
for (Integer site : sites) {
if (probabilisticLocalizations.length() > 0) {
probabilisticLocalizations.append(", ");
}
probabilisticLocalizations.append(site.toString()).append(": ").append(ptmScoring.getProbabilisticScore(site));
}
sites = new ArrayList<Integer>(ptmScoring.getDSites());
Collections.sort(sites);
for (Integer site : sites) {
if (dLocalizations.length() > 0) {
dLocalizations.append(", ");
}
dLocalizations.append(site.toString()).append(": ").append(ptmScoring.getDeltaScore(site));
}
}
}
}
}
if (algorithms.size() == 1 && algorithms.get(0) == Advocate.mascot.getIndex()) {
if (!phosphoNames.isEmpty() && spectrumMatch.hasAssumption(Advocate.mascot.getIndex())) {
PeptideAssumption mascotAssumption = null;
double bestScore = 0;
for (ArrayList<SpectrumIdentificationAssumption> peptideAssumptionList : spectrumMatch.getAllAssumptions(Advocate.mascot.getIndex()).values()) {
for (SpectrumIdentificationAssumption assumption : peptideAssumptionList) {
PeptideAssumption peptideAssumption = (PeptideAssumption) assumption;
MascotScore mascotScore = new MascotScore();
mascotScore = (MascotScore) peptideAssumption.getUrParam(mascotScore);
if (mascotScore.getScore() > bestScore) {
mascotAssumption = peptideAssumption;
bestScore = mascotScore.getScore();
}
}
}
if (mascotAssumption != null) {
Peptide mascotPeptide = mascotAssumption.getPeptide();
Double score = MDScore.getMDScore(spectrumMatch, mascotPeptide, phosphoNames, peptideShakerGUI.getSequenceMatchingPreferences());
if (score != null) {
mdScore = score.toString();
}
ArrayList<Integer> sites = new ArrayList<Integer>();
for (ModificationMatch modificationMatch : mascotPeptide.getModificationMatches()) {
if (modificationMatch.getTheoreticPtm().contains("phospho")) {
sites.add(modificationMatch.getModificationSite());
}
}
Collections.sort(sites);
for (int site : sites) {
if (!mdLocation.equals("")) {
mdLocation += ", ";
}
mdLocation += site;
}
}
}
}
if (ptmScoringPreferences.isProbabilitsticScoreCalculation()) {
writer.write(probabilisticLocalizations + SEPARATOR);
}
writer.write(dLocalizations + SEPARATOR);
if (algorithms.size() == 1 && algorithms.get(0) == Advocate.mascot.getIndex()) {
writer.write(mdLocation + SEPARATOR);
writer.write(mdScore + SEPARATOR);
}
writer.write(nPhospho + SEPARATOR);
writer.write(nSites + SEPARATOR);
writer.write(spectrumFile + SEPARATOR);
writer.write(Spectrum.getSpectrumTitle(spectrumMatch.getKey()) + SEPARATOR);
Precursor prec = spectrumFactory.getPrecursor(spectrumMatch.getKey());
writer.write(prec.getMz() + SEPARATOR);
writer.write(bestAssumption.getIdentificationCharge().value + SEPARATOR);
writer.write(prec.getRt() + SEPARATOR);
writer.write(bestAssumption.getPeptide().getMass() + SEPARATOR);
writer.write(bestAssumption.getDeltaMass(prec.getMz(), peptideShakerGUI.getSearchParameters().isPrecursorAccuracyTypePpm()) + SEPARATOR);
writer.write(bestAssumption.getIsotopeNumber(prec.getMz()) + SEPARATOR);
writer.write(psParameter.getPsmConfidence() + SEPARATOR);
MatchValidationLevel matchValidationLevel = psParameter.getMatchValidationLevel();
writer.write(matchValidationLevel.toString());
if (matchValidationLevel == MatchValidationLevel.doubtful && !psParameter.getReasonDoubtful().equals("")) {
writer.write(" (" + psParameter.getReasonDoubtful() + ")");
}
writer.write(SEPARATOR);
if (bestAssumption.getPeptide().isDecoy(peptideShakerGUI.getSequenceMatchingPreferences())) {
writer.write(1 + SEPARATOR);
} else {
writer.write(0 + SEPARATOR);
}
writer.write(System.getProperty("line.separator"));
progressDialog.increasePrimaryProgressCounter();
}
}
writer.close();
try {
File outputFile = new File(selectedFile.getParent(), reducedName + "_Proteins_phospho.txt");
writer = new BufferedWriter(new FileWriter(outputFile));
} catch (IOException e) {
JOptionPane.showMessageDialog(null, "An error occurred when saving the protein details.", "Saving Failed", JOptionPane.ERROR_MESSAGE);
e.printStackTrace();
return;
}
ArrayList<String> targetedPtms = new ArrayList<String>();
for (String ptm : ptmProfile.getAllNotFixedModifications()) {
if (ptm.contains("phospho")) {
targetedPtms.add(ptm);
}
}
writer.write(SEPARATOR);
writer.write("Accession" + SEPARATOR);
writer.write("Other Protein(s)" + SEPARATOR);
writer.write("Protein Inference Class" + SEPARATOR);
writer.write("Description" + SEPARATOR);
writer.write("Sequence Coverage (%)" + SEPARATOR);
writer.write("Observable Coverage (%)" + SEPARATOR);
writer.write("Confident Phosphorylation Sites" + SEPARATOR);
writer.write("# Confident" + SEPARATOR);
writer.write("Other Phosphorylation Sites" + SEPARATOR);
writer.write("# Other" + SEPARATOR);
writer.write("#Validated Peptides" + SEPARATOR);
writer.write("#Validated Spectra" + SEPARATOR);
writer.write("NSAF" + SEPARATOR);
writer.write("MW (kDa)" + SEPARATOR);
writer.write("Confidence" + SEPARATOR);
writer.write("Validation" + SEPARATOR);
writer.write("Decoy" + SEPARATOR);
writer.write(System.getProperty("line.separator"));
PSParameter proteinPSParameter = new PSParameter();
int proteinCounter = 0;
progressDialog.setTitle("Loading Protein Matches. Please Wait...");
identification.loadProteinMatches(progressDialog);
progressDialog.setTitle("Loading Protein Details. Please Wait...");
identification.loadProteinMatchParameters(proteinPSParameter, progressDialog);
progressDialog.setPrimaryProgressCounterIndeterminate(false);
progressDialog.setMaxPrimaryProgressCounter(identification.getProteinIdentification().size());
progressDialog.setValue(0);
progressDialog.setTitle("Copying Protein Phospho Details to File. Please Wait...");
for (String proteinKey : identification.getProteinIdentification()) {
if (progressDialog.isRunCanceled()) {
break;
}
proteinPSParameter = (PSParameter) identification.getProteinMatchParameter(proteinKey, proteinPSParameter);
writer.write(++proteinCounter + SEPARATOR);
ProteinMatch proteinMatch = identification.getProteinMatch(proteinKey);
String accession = proteinMatch.getMainMatch();
writer.write(accession + SEPARATOR);
boolean first = true;
for (String otherProtein : proteinMatch.getTheoreticProteinsAccessions()) {
if (!otherProtein.equals(accession)) {
if (first) {
first = false;
} else {
writer.write(", ");
}
writer.write(otherProtein);
}
}
writer.write(SEPARATOR);
writer.write(proteinPSParameter.getProteinInferenceClassAsString() + SEPARATOR);
try {
writer.write(sequenceFactory.getHeader(proteinMatch.getMainMatch()).getSimpleProteinDescription() + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
try {
HashMap<Integer, Double> sequenceCoverage;
try {
sequenceCoverage = peptideShakerGUI.getIdentificationFeaturesGenerator().getSequenceCoverage(proteinKey);
} catch (Exception e) {
peptideShakerGUI.catchException(e);
sequenceCoverage = new HashMap<Integer, Double>();
}
Double sequenceCoverageConfident = 100 * sequenceCoverage.get(MatchValidationLevel.confident.getIndex());
Double sequenceCoverageDoubtful = 100 * sequenceCoverage.get(MatchValidationLevel.doubtful.getIndex());
Double validatedCoverage = sequenceCoverageConfident + sequenceCoverageDoubtful;
writer.write(validatedCoverage + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
try {
writer.write(peptideShakerGUI.getIdentificationFeaturesGenerator().getObservableCoverage(proteinKey) * 100 + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
try {
writer.write(peptideShakerGUI.getIdentificationFeaturesGenerator().getConfidentPtmSites(proteinKey, targetedPtms) + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
try {
writer.write(peptideShakerGUI.getIdentificationFeaturesGenerator().getAmbiguousPtmSites(proteinKey, targetedPtms) + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
try {
writer.write(peptideShakerGUI.getIdentificationFeaturesGenerator().getNValidatedPeptides(proteinKey) + SEPARATOR);
} catch (Exception e) {
peptideShakerGUI.catchException(e);
writer.write(Double.NaN + SEPARATOR);
}
try {
writer.write(peptideShakerGUI.getIdentificationFeaturesGenerator().getNValidatedSpectra(proteinKey) + SEPARATOR);
} catch (Exception e) {
peptideShakerGUI.catchException(e);
writer.write(Double.NaN + SEPARATOR);
}
try {
writer.write(peptideShakerGUI.getIdentificationFeaturesGenerator().getSpectrumCounting(proteinKey,
SpectrumCountingPreferences.SpectralCountingMethod.NSAF) + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
try {
Double proteinMW = sequenceFactory.computeMolecularWeight(proteinMatch.getMainMatch());
writer.write(proteinMW + SEPARATOR);
} catch (Exception e) {
writer.write("error: " + e.getLocalizedMessage() + SEPARATOR);
}
writer.write(proteinPSParameter.getProteinConfidence() + SEPARATOR);
MatchValidationLevel matchValidationLevel = proteinPSParameter.getMatchValidationLevel();
writer.write(matchValidationLevel.toString());
if (matchValidationLevel == MatchValidationLevel.doubtful && !proteinPSParameter.getReasonDoubtful().equals("")) {
writer.write(" (" + proteinPSParameter.getReasonDoubtful() + ")");
}
writer.write(SEPARATOR);
if (proteinMatch.isDecoy()) {
writer.write(1 + SEPARATOR);
} else {