Skip to content

Instantly share code, notes, and snippets.

@hansbogert
Created April 17, 2014 11:24
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save hansbogert/10975461 to your computer and use it in GitHub Desktop.
Save hansbogert/10975461 to your computer and use it in GitHub Desktop.
boost::compute::sort fails with 33 items
#include <algorithm>
#include <iostream>
#include <vector>
#include <boost/compute/system.hpp>
#include <boost/compute/algorithm/copy.hpp>
#include <boost/compute/algorithm/sort.hpp>
#include <boost/compute/container/vector.hpp>
namespace compute = boost::compute;
int rand_int()
{
return rand() % 100;
}
// this example demonstrates how to sort a vector of ints on the GPU
int main(int argc, char * argv[])
{
// create vector of random values on the host
std::vector<int> host_vector(33);
std::generate(host_vector.begin(), host_vector.end(), rand_int);
// print out input vector
std::cout << "input: [ ";
for(size_t i = 0; i < host_vector.size(); i++){
std::cout << host_vector[i];
if(i != host_vector.size() - 1){
std::cout << ", ";
}
}
std::cout << " ]" << std::endl;
// transfer the values to the device
compute::vector<int> device_vector = host_vector;
// sort the values on the device
compute::sort(device_vector.begin(), device_vector.end());
// transfer the values back to the host
compute::copy(device_vector.begin(),
device_vector.end(),
host_vector.begin());
// print out the sorted vector
std::cout << "output: [ ";
for(size_t i = 0; i < host_vector.size(); i++){
std::cout << host_vector[i];
if(i != host_vector.size() - 1){
std::cout << ", ";
}
}
std::cout << " ]" << std::endl;
return 0;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment