165 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			165 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
//---------------------------------------------------------------------------//
 | 
						|
// Copyright (c) 2013-2014 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_UTILITY_EXTENTS_HPP
 | 
						|
#define BOOST_COMPUTE_UTILITY_EXTENTS_HPP
 | 
						|
 | 
						|
#include <functional>
 | 
						|
#include <numeric>
 | 
						|
 | 
						|
#include <boost/compute/config.hpp>
 | 
						|
 | 
						|
#ifndef BOOST_COMPUTE_NO_HDR_INITIALIZER_LIST
 | 
						|
#include <initializer_list>
 | 
						|
#endif
 | 
						|
 | 
						|
#include <boost/array.hpp>
 | 
						|
 | 
						|
namespace boost {
 | 
						|
namespace compute {
 | 
						|
 | 
						|
/// The extents class contains an array of n-dimensional extents.
 | 
						|
///
 | 
						|
/// \see dim()
 | 
						|
template<size_t N>
 | 
						|
class extents
 | 
						|
{
 | 
						|
public:
 | 
						|
    typedef size_t size_type;
 | 
						|
    static const size_type static_size = N;
 | 
						|
    typedef boost::array<size_t, N> array_type;
 | 
						|
    typedef typename array_type::iterator iterator;
 | 
						|
    typedef typename array_type::const_iterator const_iterator;
 | 
						|
 | 
						|
    /// Creates an extents object with each component set to zero.
 | 
						|
    ///
 | 
						|
    /// For example:
 | 
						|
    /// \code
 | 
						|
    /// extents<3> exts(); // (0, 0, 0)
 | 
						|
    /// \endcode
 | 
						|
    extents()
 | 
						|
    {
 | 
						|
        m_extents.fill(0);
 | 
						|
    }
 | 
						|
 | 
						|
    /// Creates an extents object with each component set to \p value.
 | 
						|
    ///
 | 
						|
    /// For example:
 | 
						|
    /// \code
 | 
						|
    /// extents<3> exts(1); // (1, 1, 1)
 | 
						|
    /// \endcode
 | 
						|
    explicit extents(size_t value)
 | 
						|
    {
 | 
						|
        m_extents.fill(value);
 | 
						|
    }
 | 
						|
 | 
						|
    #ifndef BOOST_COMPUTE_NO_HDR_INITIALIZER_LIST
 | 
						|
    /// Creates an extents object with \p values.
 | 
						|
    extents(std::initializer_list<size_t> values)
 | 
						|
    {
 | 
						|
        BOOST_ASSERT(values.size() == N);
 | 
						|
 | 
						|
        std::copy(values.begin(), values.end(), m_extents.begin());
 | 
						|
    }
 | 
						|
    #endif // BOOST_COMPUTE_NO_HDR_INITIALIZER_LIST
 | 
						|
 | 
						|
    /// Returns the size (i.e. dimensionality) of the extents array.
 | 
						|
    size_type size() const
 | 
						|
    {
 | 
						|
        return N;
 | 
						|
    }
 | 
						|
 | 
						|
    /// Returns the linear size of the extents. This is equivalent to the
 | 
						|
    /// product of each extent in each dimension.
 | 
						|
    size_type linear() const
 | 
						|
    {
 | 
						|
        return std::accumulate(
 | 
						|
            m_extents.begin(), m_extents.end(), 1, std::multiplies<size_type>()
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /// Returns a pointer to the extents data array.
 | 
						|
    ///
 | 
						|
    /// This is useful for passing the extents data to OpenCL APIs which
 | 
						|
    /// expect an array of \c size_t.
 | 
						|
    size_t* data()
 | 
						|
    {
 | 
						|
        return m_extents.data();
 | 
						|
    }
 | 
						|
 | 
						|
    /// \overload
 | 
						|
    const size_t* data() const
 | 
						|
    {
 | 
						|
        return m_extents.data();
 | 
						|
    }
 | 
						|
 | 
						|
    iterator begin()
 | 
						|
    {
 | 
						|
        return m_extents.begin();
 | 
						|
    }
 | 
						|
 | 
						|
    const_iterator begin() const
 | 
						|
    {
 | 
						|
        return m_extents.begin();
 | 
						|
    }
 | 
						|
 | 
						|
    const_iterator cbegin() const
 | 
						|
    {
 | 
						|
        return m_extents.cbegin();
 | 
						|
    }
 | 
						|
 | 
						|
    iterator end()
 | 
						|
    {
 | 
						|
        return m_extents.end();
 | 
						|
    }
 | 
						|
 | 
						|
    const_iterator end() const
 | 
						|
    {
 | 
						|
        return m_extents.end();
 | 
						|
    }
 | 
						|
 | 
						|
    const_iterator cend() const
 | 
						|
    {
 | 
						|
        return m_extents.cend();
 | 
						|
    }
 | 
						|
 | 
						|
    /// Returns a reference to the extent at \p index.
 | 
						|
    size_t& operator[](size_t index)
 | 
						|
    {
 | 
						|
        return m_extents[index];
 | 
						|
    }
 | 
						|
 | 
						|
    /// \overload
 | 
						|
    const size_t& operator[](size_t index) const
 | 
						|
    {
 | 
						|
        return m_extents[index];
 | 
						|
    }
 | 
						|
 | 
						|
    /// Returns \c true if the extents in \c *this are the same as \p other.
 | 
						|
    bool operator==(const extents &other) const
 | 
						|
    {
 | 
						|
        return m_extents == other.m_extents;
 | 
						|
    }
 | 
						|
 | 
						|
    /// Returns \c true if the extents in \c *this are not the same as \p other.
 | 
						|
    bool operator!=(const extents &other) const
 | 
						|
    {
 | 
						|
        return m_extents != other.m_extents;
 | 
						|
    }
 | 
						|
 | 
						|
private:
 | 
						|
    array_type m_extents;
 | 
						|
};
 | 
						|
 | 
						|
} // end compute namespace
 | 
						|
} // end boost namespace
 | 
						|
 | 
						|
#endif // BOOST_COMPUTE_UTILITY_EXTENTS_HPP
 |