5dffee
diff -up boost_1_54_0/boost/numeric/ublas/detail/matrix_assign.hpp~ boost_1_54_0/boost/numeric/ublas/detail/matrix_assign.hpp
5dffee
--- boost_1_54_0/boost/numeric/ublas/detail/matrix_assign.hpp~	2010-10-19 00:01:35.000000000 -0700
5dffee
+++ boost_1_54_0/boost/numeric/ublas/detail/matrix_assign.hpp	2013-07-22 04:33:26.399038120 -0700
5dffee
@@ -1303,7 +1303,6 @@ namespace detail {
5dffee
     void matrix_swap (M &m, matrix_expression<E> &e, packed_proxy_tag, row_major_tag) {
5dffee
         typedef F<typename M::iterator2::reference, typename E::reference> functor_type;
5dffee
         // R unnecessary, make_conformant not required
5dffee
-        typedef typename M::size_type size_type;
5dffee
         typedef typename M::difference_type difference_type;
5dffee
         typename M::iterator1 it1 (m.begin1 ());
5dffee
         typename E::iterator1 it1e (e ().begin1 ());
5dffee
@@ -1329,7 +1328,6 @@ namespace detail {
5dffee
     void matrix_swap (M &m, matrix_expression<E> &e, packed_proxy_tag, column_major_tag) {
5dffee
         typedef F<typename M::iterator1::reference, typename E::reference> functor_type;
5dffee
         // R unnecessary, make_conformant not required
5dffee
-        typedef typename M::size_type size_type;
5dffee
         typedef typename M::difference_type difference_type;
5dffee
         typename M::iterator2 it2 (m.begin2 ());
5dffee
         typename E::iterator2 it2e (e ().begin2 ());
5dffee
@@ -1357,7 +1355,6 @@ namespace detail {
5dffee
         typedef R conformant_restrict_type;
5dffee
         typedef typename M::size_type size_type;
5dffee
         typedef typename M::difference_type difference_type;
5dffee
-        typedef typename M::value_type value_type;
5dffee
         BOOST_UBLAS_CHECK (m.size1 () == e ().size1 (), bad_size ());
5dffee
         BOOST_UBLAS_CHECK (m.size2 () == e ().size2 (), bad_size ());
5dffee
 
5dffee
@@ -1482,7 +1479,6 @@ namespace detail {
5dffee
         typedef R conformant_restrict_type;
5dffee
         typedef typename M::size_type size_type;
5dffee
         typedef typename M::difference_type difference_type;
5dffee
-        typedef typename M::value_type value_type;
5dffee
         BOOST_UBLAS_CHECK (m.size1 () == e ().size1 (), bad_size ());
5dffee
         BOOST_UBLAS_CHECK (m.size2 () == e ().size2 (), bad_size ());
5dffee
 
5dffee
diff -up boost_1_54_0/boost/numeric/ublas/detail/vector_assign.hpp~ boost_1_54_0/boost/numeric/ublas/detail/vector_assign.hpp
5dffee
--- boost_1_54_0/boost/numeric/ublas/detail/vector_assign.hpp~	2007-11-25 10:07:19.000000000 -0800
5dffee
+++ boost_1_54_0/boost/numeric/ublas/detail/vector_assign.hpp	2013-07-22 04:32:21.774650296 -0700
5dffee
@@ -379,7 +379,6 @@ namespace detail {
5dffee
         typedef typename V::size_type size_type;
5dffee
         typedef typename V::difference_type difference_type;
5dffee
         typedef typename V::value_type value_type;
5dffee
-        typedef typename V::reference reference;
5dffee
 #if BOOST_UBLAS_TYPE_CHECK
5dffee
         vector<value_type> cv (v.size ());
5dffee
         indexing_vector_assign<scalar_assign> (cv, v);
5dffee
@@ -513,7 +512,6 @@ namespace detail {
5dffee
         typedef F<typename V::iterator::reference, typename E::iterator::reference> functor_type;
5dffee
         typedef typename V::size_type size_type;
5dffee
         typedef typename V::difference_type difference_type;
5dffee
-        typedef typename V::value_type value_type;
5dffee
 
5dffee
         detail::make_conformant (v, e);
5dffee
         // FIXME should be a seperate restriction for E
5dffee
diff -up boost_1_54_0/boost/numeric/ublas/lu.hpp~ boost_1_54_0/boost/numeric/ublas/lu.hpp
5dffee
--- boost_1_54_0/boost/numeric/ublas/lu.hpp~	2010-07-04 23:06:24.000000000 -0700
5dffee
+++ boost_1_54_0/boost/numeric/ublas/lu.hpp	2013-07-22 04:40:06.634440205 -0700
5dffee
@@ -63,7 +63,6 @@ namespace boost { namespace numeric { na
5dffee
     BOOST_UBLAS_INLINE
5dffee
     void swap_rows (const PM &pm, MV &mv, vector_tag) {
5dffee
         typedef typename PM::size_type size_type;
5dffee
-        typedef typename MV::value_type value_type;
5dffee
 
5dffee
         size_type size = pm.size ();
5dffee
         for (size_type i = 0; i < size; ++ i) {
5dffee
@@ -75,7 +74,6 @@ namespace boost { namespace numeric { na
5dffee
     BOOST_UBLAS_INLINE
5dffee
     void swap_rows (const PM &pm, MV &mv, matrix_tag) {
5dffee
         typedef typename PM::size_type size_type;
5dffee
-        typedef typename MV::value_type value_type;
5dffee
 
5dffee
         size_type size = pm.size ();
5dffee
         for (size_type i = 0; i < size; ++ i) {
5dffee
diff -up boost_1_54_0/boost/numeric/ublas/operation.hpp~ boost_1_54_0/boost/numeric/ublas/operation.hpp
5dffee
--- boost_1_54_0/boost/numeric/ublas/operation.hpp~	2007-11-25 10:07:19.000000000 -0800
5dffee
+++ boost_1_54_0/boost/numeric/ublas/operation.hpp	2013-07-22 04:42:19.436046788 -0700
5dffee
@@ -129,7 +129,6 @@ namespace boost { namespace numeric { na
5dffee
                const vector_expression<E2> &e2,
5dffee
                V &v, packed_random_access_iterator_tag, row_major_tag) {
5dffee
         typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
         typedef typename V::size_type size_type;
5dffee
 
5dffee
         typename expression1_type::const_iterator1 it1 (e1 ().begin1 ());
5dffee
@@ -159,7 +158,6 @@ namespace boost { namespace numeric { na
5dffee
                const vector_expression<E2> &e2,
5dffee
                V &v, packed_random_access_iterator_tag, column_major_tag) {
5dffee
         typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
         typedef typename V::size_type size_type;
5dffee
 
5dffee
         typename expression1_type::const_iterator2 it2 (e1 ().begin2 ());
5dffee
@@ -188,9 +186,7 @@ namespace boost { namespace numeric { na
5dffee
     axpy_prod (const matrix_expression<E1> &e1,
5dffee
                const vector_expression<E2> &e2,
5dffee
                V &v, sparse_bidirectional_iterator_tag) {
5dffee
-        typedef const E1 expression1_type;
5dffee
         typedef const E2 expression2_type;
5dffee
-        typedef typename V::size_type size_type;
5dffee
 
5dffee
         typename expression2_type::const_iterator it (e2 ().begin ());
5dffee
         typename expression2_type::const_iterator it_end (e2 ().end ());
5dffee
@@ -350,7 +346,6 @@ namespace boost { namespace numeric { na
5dffee
     axpy_prod (const vector_expression<E1> &e1,
5dffee
                const matrix_expression<E2> &e2,
5dffee
                V &v, packed_random_access_iterator_tag, column_major_tag) {
5dffee
-        typedef const E1 expression1_type;
5dffee
         typedef const E2 expression2_type;
5dffee
         typedef typename V::size_type size_type;
5dffee
 
5dffee
@@ -380,7 +375,6 @@ namespace boost { namespace numeric { na
5dffee
     axpy_prod (const vector_expression<E1> &e1,
5dffee
                const matrix_expression<E2> &e2,
5dffee
                V &v, packed_random_access_iterator_tag, row_major_tag) {
5dffee
-        typedef const E1 expression1_type;
5dffee
         typedef const E2 expression2_type;
5dffee
         typedef typename V::size_type size_type;
5dffee
 
5dffee
@@ -411,8 +405,6 @@ namespace boost { namespace numeric { na
5dffee
                const matrix_expression<E2> &e2,
5dffee
                V &v, sparse_bidirectional_iterator_tag) {
5dffee
         typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
-        typedef typename V::size_type size_type;
5dffee
 
5dffee
         typename expression1_type::const_iterator it (e1 ().begin ());
5dffee
         typename expression1_type::const_iterator it_end (e1 ().end ());
5dffee
@@ -501,9 +493,6 @@ namespace boost { namespace numeric { na
5dffee
                const matrix_expression<E2> &e2,
5dffee
                M &m, TRI,
5dffee
                dense_proxy_tag, row_major_tag) {
5dffee
-        typedef M matrix_type;
5dffee
-        typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
         typedef typename M::size_type size_type;
5dffee
         typedef typename M::value_type value_type;
5dffee
 
5dffee
@@ -530,11 +519,9 @@ namespace boost { namespace numeric { na
5dffee
                const matrix_expression<E2> &e2,
5dffee
                M &m, TRI,
5dffee
                sparse_proxy_tag, row_major_tag) {
5dffee
-        typedef M matrix_type;
5dffee
         typedef TRI triangular_restriction;
5dffee
         typedef const E1 expression1_type;
5dffee
         typedef const E2 expression2_type;
5dffee
-        typedef typename M::size_type size_type;
5dffee
         typedef typename M::value_type value_type;
5dffee
 
5dffee
 #if BOOST_UBLAS_TYPE_CHECK
5dffee
@@ -580,9 +567,6 @@ namespace boost { namespace numeric { na
5dffee
                const matrix_expression<E2> &e2,
5dffee
                M &m, TRI,
5dffee
                dense_proxy_tag, column_major_tag) {
5dffee
-        typedef M matrix_type;
5dffee
-        typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
         typedef typename M::size_type size_type;
5dffee
         typedef typename M::value_type value_type;
5dffee
 
5dffee
@@ -609,11 +593,9 @@ namespace boost { namespace numeric { na
5dffee
                const matrix_expression<E2> &e2,
5dffee
                M &m, TRI,
5dffee
                sparse_proxy_tag, column_major_tag) {
5dffee
-        typedef M matrix_type;
5dffee
         typedef TRI triangular_restriction;
5dffee
         typedef const E1 expression1_type;
5dffee
         typedef const E2 expression2_type;
5dffee
-        typedef typename M::size_type size_type;
5dffee
         typedef typename M::value_type value_type;
5dffee
 
5dffee
 #if BOOST_UBLAS_TYPE_CHECK
5dffee
@@ -738,9 +720,6 @@ namespace boost { namespace numeric { na
5dffee
               const matrix_expression<E2> &e2,
5dffee
               M &m,
5dffee
               dense_proxy_tag, row_major_tag) {
5dffee
-        typedef M matrix_type;
5dffee
-        typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
         typedef typename M::size_type size_type;
5dffee
         typedef typename M::value_type value_type;
5dffee
 
5dffee
@@ -769,9 +748,6 @@ namespace boost { namespace numeric { na
5dffee
               const matrix_expression<E2> &e2,
5dffee
               M &m,
5dffee
               dense_proxy_tag, column_major_tag) {
5dffee
-        typedef M matrix_type;
5dffee
-        typedef const E1 expression1_type;
5dffee
-        typedef const E2 expression2_type;
5dffee
         typedef typename M::size_type size_type;
5dffee
         typedef typename M::value_type value_type;
5dffee
 
5dffee
diff -up boost_1_54_0/boost/numeric/ublas/triangular.hpp~ boost_1_54_0/boost/numeric/ublas/triangular.hpp
5dffee
--- boost_1_54_0/boost/numeric/ublas/triangular.hpp~	2012-09-18 14:07:07.000000000 -0700
5dffee
+++ boost_1_54_0/boost/numeric/ublas/triangular.hpp	2013-07-22 04:39:31.667230329 -0700
5dffee
@@ -1859,7 +1859,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, vector_expression<E2> &e2,
5dffee
                         lower_tag, column_major_tag, dense_proxy_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());
5dffee
@@ -1914,7 +1913,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, vector_expression<E2> &e2,
5dffee
                         lower_tag, column_major_tag, unknown_storage_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());
5dffee
@@ -1943,7 +1941,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, vector_expression<E2> &e2,
5dffee
                         lower_tag, row_major_tag, dense_proxy_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());
5dffee
@@ -1969,7 +1966,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, vector_expression<E2> &e2,
5dffee
                         lower_tag, row_major_tag, packed_proxy_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());
5dffee
@@ -1998,7 +1994,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, vector_expression<E2> &e2,
5dffee
                         lower_tag, row_major_tag, unknown_storage_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());
5dffee
@@ -2374,7 +2369,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, matrix_expression<E2> &e2,
5dffee
                         lower_tag, dense_proxy_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());
5dffee
@@ -2435,7 +2429,6 @@ namespace boost { namespace numeric { na
5dffee
     void inplace_solve (const matrix_expression<E1> &e1, matrix_expression<E2> &e2,
5dffee
                         lower_tag, unknown_storage_tag) {
5dffee
         typedef typename E2::size_type size_type;
5dffee
-        typedef typename E2::difference_type difference_type;
5dffee
         typedef typename E2::value_type value_type;
5dffee
 
5dffee
         BOOST_UBLAS_CHECK (e1 ().size1 () == e1 ().size2 (), bad_size ());