NVBIO
Main Page
Modules
Classes
Examples
File List
File Members
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
examples
qmap
util.h
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
#pragma once
29
30
#include <
nvbio/basic/numbers.h
>
31
32
using namespace
nvbio;
33
34
// divide by two
35
//
36
struct
divide_by_two
37
{
38
typedef
uint32
argument_type
;
39
typedef
uint32
result_type
;
40
41
NVBIO_FORCEINLINE
NVBIO_HOST_DEVICE
42
result_type
operator() (
const
argument_type
op)
const
{
return
op / 2u; }
43
};
44
45
// return 1 or 0 depending on whether a number is >= than a given threshold
46
struct
above_threshold
47
{
48
typedef
int16
argument_type
;
49
typedef
uint32
result_type
;
50
51
// constructor
52
NVBIO_FORCEINLINE
NVBIO_HOST_DEVICE
53
above_threshold
(
const
int16
_t) : t(_t) {}
54
55
// functor operator
56
NVBIO_FORCEINLINE
NVBIO_HOST_DEVICE
57
uint32
operator() (
const
int16
s) {
return
s >= t ? 1u : 0u; }
58
59
const
int16
t;
60
};
61
62
// update the best scores vector
63
//
64
__global__
65
void
update_scores_kernel
(
66
const
uint32
n,
67
const
uint32
* reads,
68
const
int16
* scores,
69
int16
* best)
70
{
71
const
uint32
i = threadIdx.x + blockIdx.x * blockDim.x;
72
if
(i >= n)
return
;
73
74
const
uint32
read_id = reads[i];
75
const
int16
score = scores[i];
76
77
best[ read_id ] =
nvbio::max
( best[ read_id ], score );
78
}
79
80
// update the best scores vector
81
//
82
void
update_scores
(
83
const
uint32
n,
84
const
uint32
* reads,
85
const
int16
* scores,
86
int16
* best)
87
{
88
const
uint32
block_dim = 128;
89
const
uint32
n_blocks =
util::divide_ri
( n, block_dim );
90
91
update_scores_kernel<<<n_blocks,block_dim>>>( n, reads, scores, best );
92
}
Generated on Wed Feb 25 2015 08:32:49 for NVBIO by
1.8.4