340 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			340 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
								 | 
							
								//---------------------------------------------------------------------------//
							 | 
						||
| 
								 | 
							
								// 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
							 |