A simple container of DataPoint instances.
More...
#include <trace.h>
A simple container of DataPoint instances.
Definition at line 131 of file trace.h.
◆ Trace() [1/8]
◆ Trace() [2/8]
Definition at line 381 of file trace.cpp.
size_t initialize(const std::vector< pappso_double > &xVector, const std::vector< pappso_double > &yVector)
References initialize().
◆ Trace() [3/8]
Definition at line 388 of file trace.cpp.
391 reserve(dataPoints.size());
393 for(
auto &dataPoint : dataPoints)
395 push_back(DataPoint(dataPoint));
References sortX().
◆ Trace() [4/8]
pappso::Trace::Trace |
( |
const std::vector< DataPoint > & |
dataPoints | ) |
|
Definition at line 405 of file trace.cpp.
406 : std::vector<DataPoint>(dataPoints)
References sortX().
◆ Trace() [5/8]
pappso::Trace::Trace |
( |
const std::vector< DataPoint > && |
dataPoints | ) |
|
Definition at line 415 of file trace.cpp.
416 : std::vector<DataPoint>(std::move(dataPoints))
References sortX().
◆ Trace() [6/8]
pappso::Trace::Trace |
( |
const MapTrace & |
map_trace | ) |
|
|
explicit |
Definition at line 427 of file trace.cpp.
429 for(
auto &&item : map_trace)
430 push_back(DataPoint(item.first, item.second));
◆ Trace() [7/8]
pappso::Trace::Trace |
( |
const Trace & |
other | ) |
|
Definition at line 435 of file trace.cpp.
435 : std::vector<DataPoint>(other)
◆ Trace() [8/8]
pappso::Trace::Trace |
( |
const Trace && |
other | ) |
|
Definition at line 440 of file trace.cpp.
440 : std::vector<DataPoint>(std::move(other))
◆ ~Trace()
pappso::Trace::~Trace |
( |
| ) |
|
|
virtual |
◆ containsX()
Definition at line 657 of file trace.cpp.
664 double left_most = value - delta;
665 double right_most = value + delta;
672 std::find_if(begin(),
674 [value, precision_p, delta, left_most, right_most](
675 const DataPoint &data_point) {
691 double diff_to_left_most = data_point.x - left_most;
692 double diff_to_right_most = data_point.x - right_most;
740 if(diff_to_left_most >= 0 && diff_to_right_most <= 0)
758 return (data_point.x == value);
762 if(iterator != end())
double pappso_double
A type definition for doubles.
References pappso::PrecisionBase::delta(), and pappso::DataPoint::x.
◆ dataPointCstIteratorWithX()
std::vector< DataPoint >::const_iterator pappso::Trace::dataPointCstIteratorWithX |
( |
pappso_double |
value | ) |
const |
|
protected |
◆ dataPointIndexWithX()
std::size_t pappso::Trace::dataPointIndexWithX |
( |
pappso_double |
value | ) |
const |
|
protected |
Return a reference to the DataPoint instance that has its y member equal to value
.
Definition at line 644 of file trace.cpp.
646 std::vector<DataPoint>::const_iterator iterator =
649 if(iterator != end())
650 return std::distance(begin(), iterator);
652 return std::numeric_limits<std::size_t>::max();
std::vector< DataPoint >::const_iterator dataPointCstIteratorWithX(pappso_double value) const
References dataPointCstIteratorWithX().
◆ dataPointIteratorWithX()
Definition at line 620 of file trace.cpp.
623 std::find_if(begin(), end(), [value](
const DataPoint &dataPoint) {
624 return (dataPoint.x == value);
References pappso::DataPoint::x.
◆ filter()
◆ initialize() [1/3]
Definition at line 487 of file trace.cpp.
491 erase(begin(), end());
493 for(
auto &&item : map)
495 push_back(DataPoint(item.first, item.second));
◆ initialize() [2/3]
Definition at line 454 of file trace.cpp.
458 if(xVector.size() != yVector.size())
459 throw ExceptionNotPossible(
460 "trace.cpp -- ERROR xVector and yVector must have the same size.");
463 erase(begin(), end());
465 for(std::size_t iter = 0; iter < xVector.size(); ++iter)
467 push_back(DataPoint(xVector.at(iter), yVector.at(iter)));
476 for(
auto &item : *
this)
478 std::cout << item.x <<
"-" << item.y;
References sortX().
Referenced by Trace().
◆ initialize() [3/3]
size_t pappso::Trace::initialize |
( |
const Trace & |
other | ) |
|
◆ makeTraceCstSPtr()
Definition at line 538 of file trace.cpp.
540 return std::make_shared<const Trace>(*
this);
◆ makeTraceSPtr()
TraceSPtr pappso::Trace::makeTraceSPtr |
( |
| ) |
const |
Definition at line 531 of file trace.cpp.
533 return std::make_shared<Trace>(*
this);
◆ maxY() [1/2]
◆ maxY() [2/2]
pappso_double pappso::Trace::maxY |
( |
double |
mzStart, |
|
|
double |
mzEnd |
|
) |
| const |
Definition at line 860 of file trace.cpp.
862 std::vector<DataPoint>::const_iterator begin_it =
869 if(begin_it->y > max_y)
std::vector< DataPoint >::iterator findFirstEqualOrGreaterX(std::vector< DataPoint >::iterator begin, std::vector< DataPoint >::iterator end, const double &value)
find the first element in which X is equal or greater than the value searched important : it implies ...
std::vector< DataPoint >::iterator findFirstGreaterX(std::vector< DataPoint >::iterator begin, std::vector< DataPoint >::iterator end, const double &value)
find the first element in which X is greater than the value searched important : it implies that Trac...
References pappso::findFirstEqualOrGreaterX(), and pappso::findFirstGreaterX().
◆ maxYDataPoint()
const DataPoint & pappso::Trace::maxYDataPoint |
( |
| ) |
const |
◆ minY()
◆ minYDataPoint()
const DataPoint & pappso::Trace::minYDataPoint |
( |
| ) |
const |
◆ operator=() [1/2]
Trace & pappso::Trace::operator= |
( |
const Trace & |
x | ) |
|
|
virtual |
Definition at line 514 of file trace.cpp.
516 assign(other.begin(), other.end());
◆ operator=() [2/2]
Definition at line 523 of file trace.cpp.
525 vector<DataPoint>::operator=(std::move(other));
◆ sortX()
void pappso::Trace::sortX |
( |
| ) |
|
Definition at line 878 of file trace.cpp.
880 std::sort(begin(), end(), [](
const DataPoint &a,
const DataPoint &b) {
References pappso::a, and pappso::b.
Referenced by pappso::IonIsotopeRatioScore::IonIsotopeRatioScore(), Trace(), pappso::MsRunRetentionTime< T >::align(), pappso::TimsFrame::cumulateScanToTrace(), pappso::FilterChargeDeconvolution::filter(), pappso::FilterComplementIonEnhancer::filter(), pappso::FilterMzExclusion::filter(), pappso::FilterGreatestYperWindow::filter(), pappso::FilterRemoveC13::filter(), pappso::FilterTriangle::filter(), pappso::MsRunRetentionTime< T >::getCommonDeltaRt(), pappso::TimsFrameBase::getTraceFromCumulatedScans(), pappso::TimsFrameBase::getTraceFromCumulatedScansBuiltinCentroid(), initialize(), pappso::Xic::sortByRetentionTime(), and pappso::MassSpectrum::sortMz().
◆ sortY()
void pappso::Trace::sortY |
( |
| ) |
|
◆ sumY() [1/2]
◆ sumY() [2/2]
pappso_double pappso::Trace::sumY |
( |
double |
mzStart, |
|
|
double |
mzEnd |
|
) |
| const |
◆ toMap()
Definition at line 573 of file trace.cpp.
575 std::map<pappso_double, pappso_double> map;
577 std::pair<std::map<pappso_double, pappso_double>::iterator,
bool> ret;
579 for(
auto &&dataPoint : *
this)
582 std::pair<pappso_double, pappso_double>(dataPoint.x, dataPoint.y));
584 if(ret.second ==
false)
586 qDebug() << __FILE__ <<
"@" << __LINE__ << __FUNCTION__ <<
"()"
587 <<
"It is odd that the Trace contains multiple same keys.";
590 ret.first->second += dataPoint.y;
◆ toString()
QString pappso::Trace::toString |
( |
| ) |
const |
◆ unique()
void pappso::Trace::unique |
( |
| ) |
|
◆ xValues()
◆ yValues()
◆ MassSpectrumCombinerInterface
friend class MassSpectrumCombinerInterface |
|
friend |
◆ TraceCombiner
◆ TraceMinusCombiner
◆ TracePlusCombiner
The documentation for this class was generated from the following files: