aboutsummaryrefslogtreecommitdiffhomepage
path: root/Eigen
diff options
context:
space:
mode:
authorGravatar Kenneth Frank Riddile <kfriddile@yahoo.com>2009-01-09 00:55:53 +0000
committerGravatar Kenneth Frank Riddile <kfriddile@yahoo.com>2009-01-09 00:55:53 +0000
commitf52a9e531540d3b7a0ef37be48665a92845ea515 (patch)
tree910020b05d516998c30bf4d66b39ccd8ff2b10f9 /Eigen
parent003d0ce03e617ff778d5db7b0846746401842a9e (diff)
* Added aligned_allocator for using 16-byte aligned types with STL containers. There is still a compile-time problem with STL containers that have a standard-conformant resize() method, but this should resolve the original user issue which was storing aligned objects in a std::map.
Diffstat (limited to 'Eigen')
-rw-r--r--Eigen/Core1
-rw-r--r--Eigen/src/Core/util/Memory.h134
2 files changed, 111 insertions, 24 deletions
diff --git a/Eigen/Core b/Eigen/Core
index ff22d40a8..d4626cfa3 100644
--- a/Eigen/Core
+++ b/Eigen/Core
@@ -57,6 +57,7 @@
#include <iostream>
#include <cstring>
#include <string>
+#include <limits>
#if defined(EIGEN_SSE2_ON_MSVC_2008_OR_LATER) && defined(EIGEN_VECTORIZE)
#include <malloc.h> // for _aligned_malloc
diff --git a/Eigen/src/Core/util/Memory.h b/Eigen/src/Core/util/Memory.h
index 6ad364a9a..562fbdc6c 100644
--- a/Eigen/src/Core/util/Memory.h
+++ b/Eigen/src/Core/util/Memory.h
@@ -3,6 +3,7 @@
//
// Copyright (C) 2008 Gael Guennebaud <g.gael@free.fr>
// Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
+// Copyright (C) 2009 Kenneth Riddile <kfriddile@yahoo.com>
//
// Eigen is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
@@ -271,33 +272,118 @@ struct WithAlignedOperatorNew
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
};
+/** \class aligned_allocator
+*
+* \brief stl compatible allocator to use with with 16 byte aligned types
+*
+* Example:
+* \code
+* // Vector4f requires 16 bytes alignment:
+* std::vector<Vector4f, aligned_allocator<Vector4f> > dataVec4;
+* // Vector3f does not require 16 bytes alignment, no need to use Eigen's allocator:
+* std::vector<Vector3f> dataVec3;
+* \endcode
+*
+*/
+template<class T>
+class aligned_allocator
+{
+public:
+ typedef size_t size_type;
+ typedef ptrdiff_t difference_type;
+ typedef T* pointer;
+ typedef const T* const_pointer;
+ typedef T& reference;
+ typedef const T& const_reference;
+ typedef T value_type;
+
+ template<class U>
+ struct rebind
+ {
+ typedef aligned_allocator<U> other;
+ };
+
+ pointer address( reference value ) const
+ {
+ return &value;
+ }
+
+ const_pointer address( const_reference value ) const
+ {
+ return &value;
+ }
+
+ aligned_allocator() throw()
+ {
+ }
+
+ aligned_allocator( const aligned_allocator& ) throw()
+ {
+ }
+
+ template<class U>
+ aligned_allocator( const aligned_allocator<U>& ) throw()
+ {
+ }
+
+ ~aligned_allocator() throw()
+ {
+ }
+
+ size_type max_size() const throw()
+ {
+ return std::numeric_limits<size_type>::max();
+ }
+
+ pointer allocate( size_type num, const_pointer* hint = 0 )
+ {
+ static_cast<void>( hint ); // suppress unused variable warning
+ return static_cast<pointer>( ei_aligned_malloc( num * sizeof(T) ) );
+ }
+
+ void construct( pointer p, const T& value )
+ {
+ ::new( p ) T( value );
+ }
+
+ void destroy( pointer p )
+ {
+ p->~T();
+ }
+
+ void deallocate( pointer p, size_type /*num*/ )
+ {
+ ei_aligned_free( p );
+ }
+};
+
/** \class ei_new_allocator
- *
- * \brief stl compatible allocator to use with with fixed-size vector and matrix types
- *
- * STL allocator simply wrapping operators new[] and delete[]. Unlike GCC's default new_allocator,
- * ei_new_allocator call operator new on the type \a T and not the general new operator ignoring
- * overloaded version of operator new.
- *
- * Example:
- * \code
- * // Vector4f requires 16 bytes alignment:
- * std::vector<Vector4f,ei_new_allocator<Vector4f> > dataVec4;
- * // Vector3f does not require 16 bytes alignment, no need to use Eigen's allocator:
- * std::vector<Vector3f> dataVec3;
- *
- * struct Foo : WithAlignedOperatorNew {
- * char dummy;
- * Vector4f some_vector;
- * };
- * std::vector<Foo,ei_new_allocator<Foo> > dataFoo;
- * \endcode
- *
- * \sa class WithAlignedOperatorNew
- */
+*
+* \brief stl compatible allocator to use with with fixed-size vector and matrix types
+*
+* STL allocator simply wrapping operators new[] and delete[]. Unlike GCC's default new_allocator,
+* ei_new_allocator call operator new on the type \a T and not the general new operator ignoring
+* overloaded version of operator new.
+*
+* Example:
+* \code
+* // Vector4f requires 16 bytes alignment:
+* std::vector<Vector4f,ei_new_allocator<Vector4f> > dataVec4;
+* // Vector3f does not require 16 bytes alignment, no need to use Eigen's allocator:
+* std::vector<Vector3f> dataVec3;
+*
+* struct Foo : WithAlignedOperatorNew {
+* char dummy;
+* Vector4f some_vector;
+* };
+* std::vector<Foo,ei_new_allocator<Foo> > dataFoo;
+* \endcode
+*
+* \sa class WithAlignedOperatorNew
+*/
template<typename T> class ei_new_allocator
{
- public:
+public:
typedef T value_type;
typedef T* pointer;
typedef const T* const_pointer;