Skip to content
Snippets Groups Projects
groupingexperiment.h 1.9 KiB
Newer Older

/*******************************************************************************
 * Copyright (c) 2017 Olivier Langella <olivier.langella@u-psud.fr>.
 *
 * This file is part of XTPcpp.
 *
 *     XTPcpp is free software: you can redistribute it and/or modify
 *     it under the terms of the GNU General Public License as published by
 *     the Free Software Foundation, either version 3 of the License, or
 *     (at your option) any later version.
 *
 *     XTPcpp is distributed in the hope that it will be useful,
 *     but WITHOUT ANY WARRANTY; without even the implied warranty of
 *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *     GNU General Public License for more details.
 *
 *     You should have received a copy of the GNU General Public License
 *     along with XTPcpp.  If not, see <http://www.gnu.org/licenses/>.
 *
 * Contributors:
 *     Olivier Langella <olivier.langella@u-psud.fr> - initial API and
 *implementation
 ******************************************************************************/
#include "../utils/types.h"
Langella Olivier's avatar
Langella Olivier committed
#include "../utils/workmonitor.h"
#include <pappsomspp/grouping/grpexperiment.h>

Langella Olivier's avatar
Langella Olivier committed
#pragma once
class ProteinMatch;
class PeptideEvidence;
class GroupingExperiment
{
  public:
  GroupingExperiment(WorkMonitorInterface *p_work_monitor);
  ~GroupingExperiment();

  static GroupingExperiment *newInstance(const GroupingType &grouping_type,
                                         WorkMonitorInterface *p_work_monitor);

  virtual pappso::GrpProteinSp &
  getGrpProteinSp(ProteinMatch *p_protein_match) = 0;
  virtual pappso::GrpPeptideSp &
  setGrpPeptide(pappso::GrpProteinSp proteinSp,
                PeptideEvidence *p_peptide_evidence) = 0;
  virtual void
  addPostGroupingGrpProteinSpRemoval(pappso::GrpProteinSp sp_protein) = 0;
  virtual void startGrouping()                                        = 0;

  protected:
  WorkMonitorInterface *_p_work_monitor;