340 lines
8.5 KiB
C++
340 lines
8.5 KiB
C++
|
//---------------------------------------------------------------------------//
|
||
|
// Copyright (c) 2013 Kyle Lutz <kyle.r.lutz@gmail.com>
|
||
|
//
|
||
|
// Distributed under the Boost Software License, Version 1.0
|
||
|
// See accompanying file LICENSE_1_0.txt or copy at
|
||
|
// http://www.boost.org/LICENSE_1_0.txt
|
||
|
//
|
||
|
// See http://boostorg.github.com/compute for more information.
|
||
|
//---------------------------------------------------------------------------//
|
||
|
|
||
|
#ifndef BOOST_COMPUTE_CONTAINER_FLAT_SET_HPP
|
||
|
#define BOOST_COMPUTE_CONTAINER_FLAT_SET_HPP
|
||
|
|
||
|
#include <cstddef>
|
||
|
#include <utility>
|
||
|
|
||
|
#include <boost/compute/algorithm/find.hpp>
|
||
|
#include <boost/compute/algorithm/lower_bound.hpp>
|
||
|
#include <boost/compute/algorithm/upper_bound.hpp>
|
||
|
#include <boost/compute/container/vector.hpp>
|
||
|
|
||
|
namespace boost {
|
||
|
namespace compute {
|
||
|
|
||
|
template<class T>
|
||
|
class flat_set
|
||
|
{
|
||
|
public:
|
||
|
typedef T key_type;
|
||
|
typedef typename vector<T>::value_type value_type;
|
||
|
typedef typename vector<T>::size_type size_type;
|
||
|
typedef typename vector<T>::difference_type difference_type;
|
||
|
typedef typename vector<T>::reference reference;
|
||
|
typedef typename vector<T>::const_reference const_reference;
|
||
|
typedef typename vector<T>::pointer pointer;
|
||
|
typedef typename vector<T>::const_pointer const_pointer;
|
||
|
typedef typename vector<T>::iterator iterator;
|
||
|
typedef typename vector<T>::const_iterator const_iterator;
|
||
|
typedef typename vector<T>::reverse_iterator reverse_iterator;
|
||
|
typedef typename vector<T>::const_reverse_iterator const_reverse_iterator;
|
||
|
|
||
|
explicit flat_set(const context &context = system::default_context())
|
||
|
: m_vector(context)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
flat_set(const flat_set<T> &other)
|
||
|
: m_vector(other.m_vector)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
flat_set<T>& operator=(const flat_set<T> &other)
|
||
|
{
|
||
|
if(this != &other){
|
||
|
m_vector = other.m_vector;
|
||
|
}
|
||
|
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
~flat_set()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
iterator begin()
|
||
|
{
|
||
|
return m_vector.begin();
|
||
|
}
|
||
|
|
||
|
const_iterator begin() const
|
||
|
{
|
||
|
return m_vector.begin();
|
||
|
}
|
||
|
|
||
|
const_iterator cbegin() const
|
||
|
{
|
||
|
return m_vector.cbegin();
|
||
|
}
|
||
|
|
||
|
iterator end()
|
||
|
{
|
||
|
return m_vector.end();
|
||
|
}
|
||
|
|
||
|
const_iterator end() const
|
||
|
{
|
||
|
return m_vector.end();
|
||
|
}
|
||
|
|
||
|
const_iterator cend() const
|
||
|
{
|
||
|
return m_vector.cend();
|
||
|
}
|
||
|
|
||
|
reverse_iterator rbegin()
|
||
|
{
|
||
|
return m_vector.rbegin();
|
||
|
}
|
||
|
|
||
|
const_reverse_iterator rbegin() const
|
||
|
{
|
||
|
return m_vector.rbegin();
|
||
|
}
|
||
|
|
||
|
const_reverse_iterator crbegin() const
|
||
|
{
|
||
|
return m_vector.crbegin();
|
||
|
}
|
||
|
|
||
|
reverse_iterator rend()
|
||
|
{
|
||
|
return m_vector.rend();
|
||
|
}
|
||
|
|
||
|
const_reverse_iterator rend() const
|
||
|
{
|
||
|
return m_vector.rend();
|
||
|
}
|
||
|
|
||
|
const_reverse_iterator crend() const
|
||
|
{
|
||
|
return m_vector.crend();
|
||
|
}
|
||
|
|
||
|
size_type size() const
|
||
|
{
|
||
|
return m_vector.size();
|
||
|
}
|
||
|
|
||
|
size_type max_size() const
|
||
|
{
|
||
|
return m_vector.max_size();
|
||
|
}
|
||
|
|
||
|
bool empty() const
|
||
|
{
|
||
|
return m_vector.empty();
|
||
|
}
|
||
|
|
||
|
size_type capacity() const
|
||
|
{
|
||
|
return m_vector.capacity();
|
||
|
}
|
||
|
|
||
|
void reserve(size_type size, command_queue &queue)
|
||
|
{
|
||
|
m_vector.reserve(size, queue);
|
||
|
}
|
||
|
|
||
|
void reserve(size_type size)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
reserve(size, queue);
|
||
|
queue.finish();
|
||
|
}
|
||
|
|
||
|
void shrink_to_fit()
|
||
|
{
|
||
|
m_vector.shrink_to_fit();
|
||
|
}
|
||
|
|
||
|
void clear()
|
||
|
{
|
||
|
m_vector.clear();
|
||
|
}
|
||
|
|
||
|
std::pair<iterator, bool>
|
||
|
insert(const value_type &value, command_queue &queue)
|
||
|
{
|
||
|
iterator location = upper_bound(value, queue);
|
||
|
|
||
|
if(location != begin()){
|
||
|
value_type current_value;
|
||
|
::boost::compute::copy_n(location - 1, 1, ¤t_value, queue);
|
||
|
if(value == current_value){
|
||
|
return std::make_pair(location - 1, false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
m_vector.insert(location, value, queue);
|
||
|
return std::make_pair(location, true);
|
||
|
}
|
||
|
|
||
|
std::pair<iterator, bool> insert(const value_type &value)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
std::pair<iterator, bool> result = insert(value, queue);
|
||
|
queue.finish();
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
iterator erase(const const_iterator &position, command_queue &queue)
|
||
|
{
|
||
|
return erase(position, position + 1, queue);
|
||
|
}
|
||
|
|
||
|
iterator erase(const const_iterator &position)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
iterator iter = erase(position, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
iterator erase(const const_iterator &first,
|
||
|
const const_iterator &last,
|
||
|
command_queue &queue)
|
||
|
{
|
||
|
return m_vector.erase(first, last, queue);
|
||
|
}
|
||
|
|
||
|
iterator erase(const const_iterator &first, const const_iterator &last)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
iterator iter = erase(first, last, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
size_type erase(const key_type &value, command_queue &queue)
|
||
|
{
|
||
|
iterator position = find(value, queue);
|
||
|
|
||
|
if(position == end()){
|
||
|
return 0;
|
||
|
}
|
||
|
else {
|
||
|
erase(position, queue);
|
||
|
return 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
size_type erase(const key_type &value)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
size_type result = erase(value, queue);
|
||
|
queue.finish();
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
iterator find(const key_type &value, command_queue &queue)
|
||
|
{
|
||
|
return ::boost::compute::find(begin(), end(), value, queue);
|
||
|
}
|
||
|
|
||
|
iterator find(const key_type &value)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
iterator iter = find(value, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
const_iterator find(const key_type &value, command_queue &queue) const
|
||
|
{
|
||
|
return ::boost::compute::find(begin(), end(), value, queue);
|
||
|
}
|
||
|
|
||
|
const_iterator find(const key_type &value) const
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
const_iterator iter = find(value, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
size_type count(const key_type &value, command_queue &queue) const
|
||
|
{
|
||
|
return find(value, queue) != end() ? 1 : 0;
|
||
|
}
|
||
|
|
||
|
size_type count(const key_type &value) const
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
size_type result = count(value, queue);
|
||
|
queue.finish();
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
iterator lower_bound(const key_type &value, command_queue &queue)
|
||
|
{
|
||
|
return ::boost::compute::lower_bound(begin(), end(), value, queue);
|
||
|
}
|
||
|
|
||
|
iterator lower_bound(const key_type &value)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
iterator iter = lower_bound(value, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
const_iterator lower_bound(const key_type &value, command_queue &queue) const
|
||
|
{
|
||
|
return ::boost::compute::lower_bound(begin(), end(), value, queue);
|
||
|
}
|
||
|
|
||
|
const_iterator lower_bound(const key_type &value) const
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
const_iterator iter = lower_bound(value, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
iterator upper_bound(const key_type &value, command_queue &queue)
|
||
|
{
|
||
|
return ::boost::compute::upper_bound(begin(), end(), value, queue);
|
||
|
}
|
||
|
|
||
|
iterator upper_bound(const key_type &value)
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
iterator iter = upper_bound(value, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
const_iterator upper_bound(const key_type &value, command_queue &queue) const
|
||
|
{
|
||
|
return ::boost::compute::upper_bound(begin(), end(), value, queue);
|
||
|
}
|
||
|
|
||
|
const_iterator upper_bound(const key_type &value) const
|
||
|
{
|
||
|
command_queue queue = m_vector.default_queue();
|
||
|
const_iterator iter = upper_bound(value, queue);
|
||
|
queue.finish();
|
||
|
return iter;
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
vector<T> m_vector;
|
||
|
};
|
||
|
|
||
|
} // end compute namespace
|
||
|
} // end boost namespace
|
||
|
|
||
|
#endif // BOOST_COMPUTE_CONTAINER_FLAT_SET_HPP
|