200 lines
6.0 KiB
Plaintext
200 lines
6.0 KiB
Plaintext
|
|
||
|
/*
|
||
|
[auto_generated]
|
||
|
boost/numeric/odeint/iterator/detail/ode_iterator_base.hpp
|
||
|
|
||
|
[begin_description]
|
||
|
Base class for const_step_iterator and adaptive_iterator.
|
||
|
[end_description]
|
||
|
|
||
|
Copyright 2012-2013 Karsten Ahnert
|
||
|
Copyright 2012-2013 Mario Mulansky
|
||
|
|
||
|
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)
|
||
|
*/
|
||
|
|
||
|
|
||
|
#ifndef BOOST_NUMERIC_ODEINT_ITERATOR_DETAIL_ODE_ITERATOR_BASE_HPP_INCLUDED
|
||
|
#define BOOST_NUMERIC_ODEINT_ITERATOR_DETAIL_ODE_ITERATOR_BASE_HPP_INCLUDED
|
||
|
|
||
|
#include <boost/iterator/iterator_facade.hpp>
|
||
|
|
||
|
#include <boost/numeric/odeint/util/unwrap_reference.hpp>
|
||
|
#include <boost/numeric/odeint/util/detail/less_with_sign.hpp>
|
||
|
|
||
|
namespace boost {
|
||
|
namespace numeric {
|
||
|
namespace odeint {
|
||
|
namespace detail {
|
||
|
|
||
|
struct ode_state_iterator_tag {};
|
||
|
struct ode_state_time_iterator_tag {};
|
||
|
|
||
|
template< class Iterator , class Stepper , class System , class State , typename Tag >
|
||
|
class ode_iterator_base;
|
||
|
|
||
|
|
||
|
/* Specialization for the state iterator that has only state_type as its value_type */
|
||
|
template< class Iterator , class Stepper , class System , class State >
|
||
|
class ode_iterator_base< Iterator , Stepper , System , State , ode_state_iterator_tag >
|
||
|
: public boost::iterator_facade
|
||
|
<
|
||
|
Iterator ,
|
||
|
typename traits::state_type< Stepper >::type const ,
|
||
|
boost::single_pass_traversal_tag
|
||
|
>
|
||
|
{
|
||
|
private:
|
||
|
|
||
|
typedef Stepper stepper_type;
|
||
|
typedef System system_type;
|
||
|
typedef typename boost::numeric::odeint::unwrap_reference< stepper_type >::type unwrapped_stepper_type;
|
||
|
typedef State state_type;
|
||
|
typedef typename unwrapped_stepper_type::time_type time_type;
|
||
|
typedef typename unwrapped_stepper_type::value_type ode_value_type;
|
||
|
|
||
|
public:
|
||
|
|
||
|
ode_iterator_base( stepper_type stepper , system_type sys , time_type t , time_type dt )
|
||
|
: m_stepper( stepper ) , m_system( sys ) ,
|
||
|
m_t( t ) , m_dt( dt ) , m_at_end( false )
|
||
|
{ }
|
||
|
|
||
|
ode_iterator_base( stepper_type stepper , system_type sys )
|
||
|
: m_stepper( stepper ) , m_system( sys ) ,
|
||
|
m_t() , m_dt() , m_at_end( true )
|
||
|
{ }
|
||
|
|
||
|
// this function is only for testing
|
||
|
bool same( const ode_iterator_base &iter ) const
|
||
|
{
|
||
|
return (
|
||
|
//( static_cast<Iterator>(*this).get_state() ==
|
||
|
// static_cast<Iterator>(iter).get_state ) &&
|
||
|
( m_t == iter.m_t ) &&
|
||
|
( m_dt == iter.m_dt ) &&
|
||
|
( m_at_end == iter.m_at_end )
|
||
|
);
|
||
|
}
|
||
|
|
||
|
|
||
|
protected:
|
||
|
|
||
|
friend class boost::iterator_core_access;
|
||
|
|
||
|
bool equal( ode_iterator_base const& other ) const
|
||
|
{
|
||
|
if( m_at_end == other.m_at_end )
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
const state_type& dereference() const
|
||
|
{
|
||
|
return static_cast<const Iterator*>(this)->get_state();
|
||
|
}
|
||
|
|
||
|
protected:
|
||
|
|
||
|
stepper_type m_stepper;
|
||
|
system_type m_system;
|
||
|
time_type m_t;
|
||
|
time_type m_dt;
|
||
|
bool m_at_end;
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
/* Specialization for the state-time iterator that has pair<state_type,time_type> as its value_type */
|
||
|
|
||
|
template< class Iterator , class Stepper , class System , class State >
|
||
|
class ode_iterator_base< Iterator , Stepper , System , State , ode_state_time_iterator_tag >
|
||
|
: public boost::iterator_facade
|
||
|
<
|
||
|
Iterator ,
|
||
|
std::pair< const State , const typename traits::time_type< Stepper >::type > ,
|
||
|
boost::single_pass_traversal_tag ,
|
||
|
std::pair< const State& , const typename traits::time_type< Stepper >::type& >
|
||
|
>
|
||
|
{
|
||
|
private:
|
||
|
|
||
|
typedef Stepper stepper_type;
|
||
|
typedef System system_type;
|
||
|
typedef typename boost::numeric::odeint::unwrap_reference< stepper_type >::type unwrapped_stepper_type;
|
||
|
typedef State state_type;
|
||
|
typedef typename unwrapped_stepper_type::time_type time_type;
|
||
|
typedef typename unwrapped_stepper_type::value_type ode_value_type;
|
||
|
|
||
|
public:
|
||
|
|
||
|
ode_iterator_base( stepper_type stepper , system_type sys ,
|
||
|
time_type t , time_type dt )
|
||
|
: m_stepper( stepper ) , m_system( sys ) ,
|
||
|
m_t( t ) , m_dt( dt ) , m_at_end( false )
|
||
|
{ }
|
||
|
|
||
|
ode_iterator_base( stepper_type stepper , system_type sys )
|
||
|
: m_stepper( stepper ) , m_system( sys ) , m_at_end( true )
|
||
|
{ }
|
||
|
|
||
|
bool same( ode_iterator_base const& iter )
|
||
|
{
|
||
|
return (
|
||
|
//( static_cast<Iterator>(*this).get_state() ==
|
||
|
// static_cast<Iterator>(iter).get_state ) &&
|
||
|
( m_t == iter.m_t ) &&
|
||
|
( m_dt == iter.m_dt ) &&
|
||
|
( m_at_end == iter.m_at_end )
|
||
|
);
|
||
|
}
|
||
|
|
||
|
|
||
|
protected:
|
||
|
|
||
|
friend class boost::iterator_core_access;
|
||
|
|
||
|
bool equal( ode_iterator_base const& other ) const
|
||
|
{
|
||
|
if( m_at_end == other.m_at_end )
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
std::pair< const state_type& , const time_type& > dereference() const
|
||
|
{
|
||
|
return std::pair< const state_type & , const time_type & >(
|
||
|
static_cast<const Iterator*>(this)->get_state() , m_t );
|
||
|
}
|
||
|
|
||
|
stepper_type m_stepper;
|
||
|
system_type m_system;
|
||
|
time_type m_t;
|
||
|
time_type m_dt;
|
||
|
bool m_at_end;
|
||
|
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
} // namespace detail
|
||
|
} // namespace odeint
|
||
|
} // namespace numeric
|
||
|
} // namespace boost
|
||
|
|
||
|
|
||
|
|
||
|
#endif // BOOST_NUMERIC_ODEINT_ITERATOR_DETAIL_ODE_ITERATOR_BASE_HPP_INCLUDED
|