File: RegionTable.cpp

package info (click to toggle)
pbseqlib 5.3.5%2Bdfsg-11
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,152 kB
  • sloc: cpp: 77,259; python: 331; sh: 103; makefile: 41
file content (107 lines) | stat: -rw-r--r-- 3,509 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
// Author: Mark Chaisson
// Modified by: Yuan Li

#include <pbdata/reads/RegionTable.hpp>

#include <algorithm>
#include <iostream>
#include <ostream>

RegionTable& RegionTable::Reset()
{
    map_.clear();
    columnNames.clear();
    regionTypes.clear();
    regionDescriptions.clear();
    regionSources.clear();
    regionTypeEnums.clear();
    return *this;
}

std::vector<RegionType> RegionTable::RegionTypeEnums(void) const { return regionTypeEnums; }

std::vector<std::string> RegionTable::RegionTypes(void) const { return regionTypes; }

std::vector<std::string> RegionTable::ColumnNames(void) const { return columnNames; }

std::vector<std::string> RegionTable::RegionDescriptions(void) const { return regionDescriptions; }

std::vector<std::string> RegionTable::RegionSources(void) const { return regionSources; }

RegionTable& RegionTable::ConstructTable(std::vector<RegionAnnotation>& table,
                                         const std::vector<std::string>& regionTypeStrs)
{
    RegionTypes(regionTypeStrs);  //< Set both regionTypes and regionTypeEnums.

    // Must sort region annotations by HoleNumber, RegionTypeIndex, Start, End, and Score
    std::sort(table.begin(), table.end(), compare_region_annotation_by_type);

    // Construct map_<holeNumber, RegionAnnotations>
    if (table.size() > 0) {
        UInt pre_hn = table[0].GetHoleNumber();
        auto itBegin = table.begin();
        for (auto it = table.begin(); it != table.end(); it++) {
            // Discrepency between data type of Regions/HoleNumber and ZMW/HoleNumber
            if (it->GetHoleNumber() > static_cast<int>(pre_hn)) {
                map_.insert(std::pair<UInt, RegionAnnotations>(
                    pre_hn, RegionAnnotations(pre_hn, std::vector<RegionAnnotation>(itBegin, it),
                                              regionTypeEnums)));
                pre_hn = it->GetHoleNumber();
                itBegin = it;
            }
        }

        map_.insert(std::pair<UInt, RegionAnnotations>(
            pre_hn, RegionAnnotations(pre_hn, std::vector<RegionAnnotation>(itBegin, table.end()),
                                      regionTypeEnums)));
    }
    return *this;
}

std::vector<RegionType> RegionTable::DefaultRegionTypes(void)
{
    std::vector<RegionType> ret;
    for (std::string regionTypeString : PacBio::AttributeValues::Regions::regiontypes) {
        ret.push_back(RegionTypeMap::ToRegionType(regionTypeString));
    }
    return ret;
}

RegionTable& RegionTable::RegionTypes(const std::vector<std::string>& regionTypeStrs)
{
    regionTypes = regionTypeStrs;
    for (std::string regionTypeString : regionTypeStrs) {
        regionTypeEnums.push_back(RegionTypeMap::ToRegionType(regionTypeString));
    }
    return *this;
}

RegionTable& RegionTable::ColumnNames(const std::vector<std::string>& in)
{
    columnNames = in;
    return *this;
}

RegionTable& RegionTable::RegionDescriptions(const std::vector<std::string>& in)
{
    regionDescriptions = in;
    return *this;
}

RegionTable& RegionTable::RegionSources(const std::vector<std::string>& in)
{
    regionSources = in;
    return *this;
}

bool RegionTable::HasHoleNumber(const UInt holeNumber) const
{
    return (map_.find(holeNumber) != map_.end());
}

RegionAnnotations RegionTable::operator[](const UInt holeNumber) const
{
    // Must check whether a zmw exists or not first.
    assert(HasHoleNumber(holeNumber) && "Could not find zmw in region table.");
    return map_.find(holeNumber)->second;
}