singlepp
A C++ library for cell type classification
Loading...
Searching...
No Matches
classify_integrated.hpp
Go to the documentation of this file.
1#ifndef SINGLEPP_CLASSIFY_INTEGRATED_HPP
2#define SINGLEPP_CLASSIFY_INTEGRATED_HPP
3
4#include "defs.hpp"
5
6#include "tatami/tatami.hpp"
7
8#include "annotate_cells_integrated.hpp"
10
11#include <vector>
12#include <unordered_map>
13#include <unordered_set>
14
20namespace singlepp {
21
26template<typename Float_ = DefaultFloat>
33
39
44 bool fine_tune = true;
45
50 int num_threads = 1;
51};
52
58template<typename RefLabel_ = DefaultRefLabel, typename Float_ = DefaultFloat>
65
72 std::vector<Float_*> scores;
73
80};
81
125template<typename Value_, typename Index_, typename Label_, typename RefLabel_, typename Float_>
127 const tatami::Matrix<Value_, Index_>& test,
128 const std::vector<const Label_*>& assigned,
132{
133 if (trained.test_nrow != static_cast<Index_>(-1) && trained.test_nrow != test.nrow()) {
134 throw std::runtime_error("number of rows in 'test' is not the same as that used to build 'trained'");
135 }
136 internal::annotate_cells_integrated(
137 test,
138 trained,
139 assigned,
140 options.quantile,
141 options.fine_tune,
142 options.fine_tune_threshold,
143 buffers.best,
144 buffers.scores,
145 buffers.delta,
146 options.num_threads
147 );
148}
149
155template<typename RefLabel_ = DefaultRefLabel, typename Float_ = DefaultFloat>
161 scores.reserve(nrefs);
162 for (size_t r = 0; r < nrefs; ++r) {
163 scores.emplace_back(ncells);
164 }
165 }
174 std::vector<RefLabel_> best;
175
181 std::vector<std::vector<Float_> > scores;
182
187 std::vector<Float_> delta;
188};
189
204template<typename RefLabel_ = DefaultRefLabel, typename Value_, typename Index_, typename Label_, typename Float_>
206 const tatami::Matrix<Value_, Index_>& test,
207 const std::vector<const Label_*>& assigned,
210{
213 buffers.best = results.best.data();
214 buffers.delta = results.delta.data();
215 buffers.scores.reserve(results.scores.size());
216 for (auto& s : results.scores) {
217 buffers.scores.emplace_back(s.data());
218 }
220 return results;
221}
222
223}
224
225#endif
Common definitions for singlepp.
Cell type classification using the SingleR algorithm in C++.
Definition classify_single.hpp:19
void classify_integrated(const tatami::Matrix< Value_, Index_ > &test, const std::vector< const Label_ * > &assigned, const TrainedIntegrated< Index_ > &trained, ClassifyIntegratedBuffers< RefLabel_, Float_ > &buffers, const ClassifyIntegratedOptions< Float_ > &options)
Integrate classifications from multiple references.
Definition classify_integrated.hpp:126
std::vector< std::vector< std::vector< Index_ > > > Markers
Definition Markers.hpp:40
Output buffers for classify_single().
Definition classify_integrated.hpp:59
RefLabel_ * best
Definition classify_integrated.hpp:64
Float_ * delta
Definition classify_integrated.hpp:79
std::vector< Float_ * > scores
Definition classify_integrated.hpp:72
Options for classify_integrated().
Definition classify_integrated.hpp:27
bool fine_tune
Definition classify_integrated.hpp:44
int num_threads
Definition classify_integrated.hpp:50
Float_ quantile
Definition classify_integrated.hpp:32
Float_ fine_tune_threshold
Definition classify_integrated.hpp:38
Results of classify_integrated().
Definition classify_integrated.hpp:156
std::vector< std::vector< Float_ > > scores
Definition classify_integrated.hpp:181
std::vector< RefLabel_ > best
Definition classify_integrated.hpp:174
std::vector< Float_ > delta
Definition classify_integrated.hpp:187
Prepare for integrated classification across references.