summaryrefslogtreecommitdiff
path: root/boost/numeric/odeint/external/nt2/nt2_resize.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'boost/numeric/odeint/external/nt2/nt2_resize.hpp')
-rw-r--r--boost/numeric/odeint/external/nt2/nt2_resize.hpp52
1 files changed, 52 insertions, 0 deletions
diff --git a/boost/numeric/odeint/external/nt2/nt2_resize.hpp b/boost/numeric/odeint/external/nt2/nt2_resize.hpp
new file mode 100644
index 0000000000..d9c2359c3e
--- /dev/null
+++ b/boost/numeric/odeint/external/nt2/nt2_resize.hpp
@@ -0,0 +1,52 @@
+//==============================================================================
+// Copyright 2014 LRI UMR 8623 CNRS/Univ Paris Sud XI
+// Copyright 2014 NumScale SAS
+//
+// Distributed under the Boost Software License, Version 1.0.
+// See accompanying file LICENSE.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//==============================================================================
+#ifndef BOOST_NUMERIC_ODEINT_EXTERNAL_NT2_NT2_RESIZE_HPP_INCLUDED
+#define BOOST_NUMERIC_ODEINT_EXTERNAL_NT2_NT2_RESIZE_HPP_INCLUDED
+
+#include <nt2/core/container/table/table.hpp>
+
+#include <boost/numeric/odeint/util/same_size.hpp>
+
+namespace boost { namespace numeric { namespace odeint {
+
+template<typename T, typename S>
+struct is_resizeable< nt2::container::table<T,S> >
+{
+ typedef boost::true_type type;
+ static const bool value = type::value;
+};
+
+template<typename T, typename S>
+struct same_size_impl< nt2::container::table<T,S>
+ , nt2::container::table<T,S>
+ >
+{
+ static bool same_size ( const nt2::container::table<T,S> &v1
+ , const nt2::container::table<T,S> &v2
+ )
+ {
+ return v1.extent() == v2.extent();
+ }
+};
+
+template<typename T, typename S>
+struct resize_impl< nt2::container::table<T,S>
+ , nt2::container::table<T,S>
+ >
+{
+ static void resize ( nt2::container::table<T,S> &v1
+ , const nt2::container::table<T,S> &v2
+ )
+ {
+ v1.resize( v2.extent() );
+ }
+};
+} } }
+
+#endif