NVBIO
Main Page
Modules
Classes
Examples
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
nvbio
io
output
output_batch.cpp
Go to the documentation of this file.
1
/*
2
* nvbio
3
* Copyright (c) 2011-2014, NVIDIA CORPORATION. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
* * Redistributions of source code must retain the above copyright
8
* notice, this list of conditions and the following disclaimer.
9
* * Redistributions in binary form must reproduce the above copyright
10
* notice, this list of conditions and the following disclaimer in the
11
* documentation and/or other materials provided with the distribution.
12
* * Neither the name of the NVIDIA CORPORATION nor the
13
* names of its contributors may be used to endorse or promote products
14
* derived from this software without specific prior written permission.
15
*
16
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
17
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19
* DISCLAIMED. IN NO EVENT SHALL NVIDIA CORPORATION BE LIABLE FOR ANY
20
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
*/
27
28
#include <
nvbio/io/output/output_batch.h
>
29
#include <
nvbio/basic/timer.h
>
30
#include <
nvbio/basic/vector.h
>
31
32
#include <stdio.h>
33
#include <stdarg.h>
34
35
namespace
nvbio {
36
namespace
io {
37
38
void
HostOutputBatchSE::readback
(
const
DeviceOutputBatchSE
batch)
39
{
40
count
= batch.
count
;
41
batch.
readback_scores
(
alignments
);
42
batch.
readback_cigars
(
cigar
);
43
batch.
readback_mds
(
mds
);
44
batch.
readback_mapq
(
mapq
);
45
batch.
readback_ids
(
read_ids
);
46
}
47
48
void
HostOutputBatchPE::readback
(
const
DeviceOutputBatchSE
batch,
const
AlignmentMate
mate)
49
{
50
count
= batch.
count
;
51
batch.
readback_scores
(
alignments
[mate] );
52
batch.
readback_cigars
(
cigar
[mate] );
53
batch.
readback_mds
(
mds
[mate] );
54
batch.
readback_mapq
(
mapq
[mate] );
55
56
if
(mate ==
MATE_1
)
57
batch.
readback_ids
(
read_ids
);
58
}
59
60
// copy scoring data to host, converting to io::AlignmentResult
61
void
DeviceOutputBatchSE::readback_scores
(thrust::host_vector<io::Alignment>& host_alignments)
const
62
{
63
// copy alignment data into a staging buffer
64
host_alignments =
alignments
;
65
}
66
67
// copy CIGARs into host memory
68
void
DeviceOutputBatchSE::readback_cigars
(
io::HostCigarArray
& host_cigar)
const
69
{
70
host_cigar.
array
=
cigar
.array;
71
nvbio::cuda::thrust_copy_vector(host_cigar.
coords
,
cigar
.coords);
72
}
73
74
// copy MD strings back to the host
75
void
DeviceOutputBatchSE::readback_mds
(
nvbio::HostVectorArray<uint8>
& host_mds)
const
76
{
77
host_mds =
mds
;
78
}
79
80
// copy mapq back to the host
81
void
DeviceOutputBatchSE::readback_mapq
(thrust::host_vector<uint8>& host_mapq)
const
82
{
83
host_mapq =
mapq
;
84
}
85
86
// copy mapq back to the host
87
void
DeviceOutputBatchSE::readback_ids
(thrust::host_vector<uint32>& host_ids)
const
88
{
89
if
(
read_ids
)
90
host_ids = *
read_ids
;
91
else
92
host_ids.resize(0);
93
}
94
95
}
// namespace io
96
}
// namespace nvbio
Generated on Wed Feb 25 2015 08:33:00 for NVBIO by
1.8.4