Skip to content

Commit

Permalink
Updated FilterePsms to only iterate through PSMs once
Browse files Browse the repository at this point in the history
  • Loading branch information
Alexander-Sol committed Oct 28, 2024
1 parent c2d5a41 commit 4dc85e0
Showing 1 changed file with 50 additions and 36 deletions.
86 changes: 50 additions & 36 deletions MetaMorpheus/TaskLayer/FilteredPsms.cs
Original file line number Diff line number Diff line change
Expand Up @@ -112,45 +112,41 @@ public static FilteredPsms Filter(IEnumerable<SpectralMatch> psms,
}
}

if (!includeHighQValuePsms)
{
filteredPsms = filterType.Equals(FilterType.QValue)
? psms.Where(p => p.GetFdrInfo(filterAtPeptideLevel) != null
&& p.GetFdrInfo(filterAtPeptideLevel).QValue <= filterThreshold
&& p.GetFdrInfo(filterAtPeptideLevel).QValueNotch <= filterThreshold).ToList()
: psms.Where(p => p.GetFdrInfo(filterAtPeptideLevel) != null && p.GetFdrInfo(filterAtPeptideLevel).PEP_QValue <= filterThreshold).ToList();
}
else
{
filteredPsms = psms.ToList();
}
filteredPsms = FilterByQValue(psms, includeHighQValuePsms, filterThreshold, filterAtPeptideLevel, filterType)
.Where(psm =>
(includeDecoys || !psm.IsDecoy)
&& (includeContaminants || !psm.IsContaminant)
&& (includeAmbiguous || !psm.BaseSequence.IsNullOrEmpty())
&& (includeAmbiguousMods || !psm.FullSequence.IsNullOrEmpty()))
.CollapseToPeptides(filterAtPeptideLevel)
.ToList();

if (!includeDecoys)
{
filteredPsms.RemoveAll(p => p.IsDecoy);
}
if (!includeContaminants)
{
filteredPsms.RemoveAll(p => p.IsContaminant);
}
if (!includeAmbiguous)
{
filteredPsms.RemoveAll(p => p.BaseSequence.IsNullOrEmpty());
}
if (!includeAmbiguousMods)
{
filteredPsms.RemoveAll(p => p.FullSequence.IsNullOrEmpty());
}
if (filterAtPeptideLevel)
return new FilteredPsms(filteredPsms, filterType, filterThreshold, filteringNotPerformed, filterAtPeptideLevel);
}

public static IEnumerable<SpectralMatch> FilterByQValue(IEnumerable<SpectralMatch> psms, bool includeHighQValuePsms, double qValueThreshold, bool filterAtPeptideLevel, FilterType filterType)
{
foreach(var psm in psms)
{
//Choose the top scoring PSM for each peptide
filteredPsms = filteredPsms
.OrderByDescending(p => p)
.GroupBy(b => b.FullSequence)
.Select(b => b.FirstOrDefault()).ToList();
if(includeHighQValuePsms)
{
yield return psm;
}
else if (filterType == FilterType.PepQValue)
{
if (psm.GetFdrInfo(filterAtPeptideLevel).PEP_QValue <= qValueThreshold)
{
yield return psm;
}
}
else
{
if (psm.GetFdrInfo(filterAtPeptideLevel).QValue <= qValueThreshold && psm.GetFdrInfo(filterAtPeptideLevel).QValueNotch <= qValueThreshold)
{
yield return psm;
}
}
}

return new FilteredPsms(filteredPsms, filterType, filterThreshold, filteringNotPerformed, filterAtPeptideLevel);
}

public IEnumerator<SpectralMatch> GetEnumerator()
Expand All @@ -163,4 +159,22 @@ System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
return FilteredPsmsList.GetEnumerator();
}
}

public static class FilteredPsmsExtensions
{
public static IEnumerable<SpectralMatch> CollapseToPeptides(this IEnumerable<SpectralMatch> psms, bool filterAtPeptideLevel)
{
if(!filterAtPeptideLevel)
{
return psms;
}
else
{
return psms
.OrderByDescending(p => p)
.GroupBy(b => b.FullSequence)
.Select(b => b.FirstOrDefault());
}
}
}
}

0 comments on commit 4dc85e0

Please sign in to comment.