This commit is contained in:
2026-03-23 20:54:41 +08:00
commit e13b3650e9
4596 changed files with 1015768 additions and 0 deletions

View File

@@ -0,0 +1,25 @@
//==============================================================================
// 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_ALGEBRA_DISPATCHER_HPP_INCLUDED
#define BOOST_NUMERIC_ODEINT_EXTERNAL_NT2_NT2_ALGEBRA_DISPATCHER_HPP_INCLUDED
#include <nt2/core/container/table/table.hpp>
#include <boost/numeric/odeint/algebra/vector_space_algebra.hpp>
#include <boost/numeric/odeint/algebra/algebra_dispatcher.hpp>
namespace boost { namespace numeric { namespace odeint {
template<typename T, typename S>
struct algebra_dispatcher<nt2::container::table<T,S> >
{
typedef vector_space_algebra algebra_type;
};
} } }
#endif

View File

@@ -0,0 +1,33 @@
//==============================================================================
// Copyright 2014 LASMEA UMR 6602 CNRS/Univ. Clermont II
// Copyright 2014 LRI UMR 8623 CNRS/Univ Paris Sud XI
// Copyright 2014 MetaScale 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_COPY_HPP_INCLUDED
#define BOOST_NUMERIC_ODEINT_EXTERNAL_NT2_NT2_COPY_HPP_INCLUDED
#include <nt2/core/container/table/table.hpp>
#include <boost/numeric/odeint/util/copy.hpp>
namespace boost { namespace numeric { namespace odeint {
template<typename T, typename S>
struct copy_impl< nt2::container::table<T,S>
, nt2::container::table<T,S>
>
{
static void copy ( const nt2::container::table<T,S> &v1
, nt2::container::table<T,S> &v2
)
{
v2 = v1;
}
};
} } }
#endif

View File

@@ -0,0 +1,31 @@
//==============================================================================
// 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_NORM_INF_HPP_INCLUDED
#define BOOST_NUMERIC_ODEINT_EXTERNAL_NT2_NT2_NORM_INF_HPP_INCLUDED
#include <nt2/core/container/table/table.hpp>
#include <nt2/include/functions/globalmax.hpp>
#include <nt2/include/functions/abs.hpp>
#include <boost/numeric/odeint/algebra/vector_space_algebra.hpp>
namespace boost { namespace numeric { namespace odeint
{
template<typename T, typename S>
struct vector_space_norm_inf<nt2::container::table<T,S> >
{
typedef T result_type;
result_type operator()(const nt2::container::table<T,S> &v1) const
{
return nt2::globalmax(nt2::abs(v1));
}
};
} } }
#endif

View File

@@ -0,0 +1,54 @@
//==============================================================================
// 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>
#include <type_traits>
namespace boost { namespace numeric { namespace odeint {
template<typename T, typename S>
struct is_resizeable< nt2::container::table<T,S> >
{
typedef std::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