2008-08-24 23:15:32 +08:00
// This file is part of Eigen, a lightweight C++ template library
2009-05-23 02:25:33 +08:00
// for linear algebra.
2008-08-24 23:15:32 +08:00
//
2010-06-25 05:21:58 +08:00
// Copyright (C) 2008 Gael Guennebaud <gael.guennebaud@inria.fr>
2008-08-24 23:15:32 +08:00
//
2012-07-14 02:42:47 +08:00
// This Source Code Form is subject to the terms of the Mozilla
// Public License v. 2.0. If a copy of the MPL was not distributed
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
2008-08-24 23:15:32 +08:00
# include "main.h"
2014-07-16 19:17:06 +08:00
template < typename From , typename To >
bool check_is_convertible ( const From & , const To & )
{
return internal : : is_convertible < From , To > : : value ;
}
2017-08-17 17:55:00 +08:00
struct FooReturnType {
typedef int ReturnType ;
} ;
2018-07-12 15:57:19 +08:00
struct MyInterface {
virtual void func ( ) = 0 ;
virtual ~ MyInterface ( ) { }
} ;
struct MyImpl : public MyInterface {
void func ( ) { }
} ;
2008-08-24 23:15:32 +08:00
void test_meta ( )
{
2010-10-26 04:13:49 +08:00
VERIFY ( ( internal : : conditional < ( 3 < 4 ) , internal : : true_type , internal : : false_type > : : type : : value ) ) ;
VERIFY ( ( internal : : is_same < float , float > : : value ) ) ;
VERIFY ( ( ! internal : : is_same < float , double > : : value ) ) ;
VERIFY ( ( ! internal : : is_same < float , float & > : : value ) ) ;
VERIFY ( ( ! internal : : is_same < float , const float & > : : value ) ) ;
2008-08-24 23:15:32 +08:00
2010-10-26 22:47:01 +08:00
VERIFY ( ( internal : : is_same < float , internal : : remove_all < const float & > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_all < const float * > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_all < const float * & > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_all < float * * > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_all < float * * & > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_all < float * const * & > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_all < float * const > : : type > : : value ) ) ;
2008-08-25 00:00:17 +08:00
2010-11-27 01:06:08 +08:00
// test add_const
VERIFY ( ( internal : : is_same < internal : : add_const < float > : : type , const float > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const < float * > : : type , float * const > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const < float const * > : : type , float const * const > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const < float & > : : type , float & > : : value ) ) ;
// test remove_const
VERIFY ( ( internal : : is_same < internal : : remove_const < float const * const > : : type , float const * > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : remove_const < float const * > : : type , float const * > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : remove_const < float * const > : : type , float * > : : value ) ) ;
// test add_const_on_value_type
VERIFY ( ( internal : : is_same < internal : : add_const_on_value_type < float & > : : type , float const & > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const_on_value_type < float * > : : type , float const * > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const_on_value_type < float > : : type , const float > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const_on_value_type < const float > : : type , const float > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const_on_value_type < const float * const > : : type , const float * const > : : value ) ) ;
VERIFY ( ( internal : : is_same < internal : : add_const_on_value_type < float * const > : : type , const float * const > : : value ) ) ;
2008-08-25 00:00:17 +08:00
2010-10-26 04:13:49 +08:00
VERIFY ( ( internal : : is_same < float , internal : : remove_reference < float & > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < const float , internal : : remove_reference < const float & > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_pointer < float * > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < const float , internal : : remove_pointer < const float * > : : type > : : value ) ) ;
VERIFY ( ( internal : : is_same < float , internal : : remove_pointer < float * const > : : type > : : value ) ) ;
2008-08-24 23:15:32 +08:00
2018-07-12 15:57:19 +08:00
// is_convertible
STATIC_CHECK ( ( internal : : is_convertible < float , double > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < int , double > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < int , short > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < short , int > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < double , int > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < double , std : : complex < double > > : : value ) ) ;
STATIC_CHECK ( ( ! internal : : is_convertible < std : : complex < double > , double > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < Array33f , Matrix3f > : : value ) ) ;
2018-07-13 23:47:28 +08:00
STATIC_CHECK ( ( internal : : is_convertible < Matrix3f & , Matrix3f > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < Matrix3f & , Matrix3f & > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < Matrix3f & , const Matrix3f & > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < const Matrix3f & , Matrix3f > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < const Matrix3f & , const Matrix3f & > : : value ) ) ;
STATIC_CHECK ( ( ! internal : : is_convertible < const Matrix3f & , Matrix3f & > : : value ) ) ;
STATIC_CHECK ( ( ! internal : : is_convertible < const Matrix3f , Matrix3f & > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < Matrix3f , Matrix3f & > : : value ) ) ; // std::is_convertible returns false here though Matrix3f from; Matrix3f& to = from; is valid.
//STATIC_CHECK((!internal::is_convertible<Matrix3f,Matrix3d>::value )); //does not work because the conversion is prevented by a static assertion
2018-07-12 15:57:19 +08:00
STATIC_CHECK ( ( ! internal : : is_convertible < Array33f , int > : : value ) ) ;
STATIC_CHECK ( ( ! internal : : is_convertible < MatrixXf , float > : : value ) ) ;
2014-07-16 19:17:06 +08:00
{
float f ;
MatrixXf A , B ;
VectorXf a , b ;
VERIFY ( ( check_is_convertible ( a . dot ( b ) , f ) ) ) ;
VERIFY ( ( check_is_convertible ( a . transpose ( ) * b , f ) ) ) ;
VERIFY ( ( ! check_is_convertible ( A * B , f ) ) ) ;
VERIFY ( ( check_is_convertible ( A * B , A ) ) ) ;
}
2017-08-17 17:55:00 +08:00
2018-07-12 15:57:19 +08:00
STATIC_CHECK ( ( ! internal : : is_convertible < MyInterface , MyImpl > : : value ) ) ;
STATIC_CHECK ( ( ! internal : : is_convertible < MyImpl , MyInterface > : : value ) ) ;
STATIC_CHECK ( ( internal : : is_convertible < MyImpl , const MyInterface & > : : value ) ) ;
{
int i ;
VERIFY ( ( check_is_convertible ( fix < 3 > ( ) , i ) ) ) ;
VERIFY ( ( ! check_is_convertible ( i , fix < DynamicIndex > ( ) ) ) ) ;
}
2017-08-17 17:55:00 +08:00
VERIFY ( ( internal : : has_ReturnType < FooReturnType > : : value ) ) ;
VERIFY ( ( internal : : has_ReturnType < ScalarBinaryOpTraits < int , int > > : : value ) ) ;
VERIFY ( ( ! internal : : has_ReturnType < MatrixXf > : : value ) ) ;
VERIFY ( ( ! internal : : has_ReturnType < int > : : value ) ) ;
2014-07-16 19:17:06 +08:00
2010-10-25 22:15:22 +08:00
VERIFY ( internal : : meta_sqrt < 1 > : : ret = = 1 ) ;
2012-11-06 22:25:50 +08:00
# define VERIFY_META_SQRT(X) VERIFY(internal::meta_sqrt<X>::ret == int(std::sqrt(double(X))))
2008-08-24 23:15:32 +08:00
VERIFY_META_SQRT ( 2 ) ;
VERIFY_META_SQRT ( 3 ) ;
VERIFY_META_SQRT ( 4 ) ;
VERIFY_META_SQRT ( 5 ) ;
VERIFY_META_SQRT ( 6 ) ;
VERIFY_META_SQRT ( 8 ) ;
VERIFY_META_SQRT ( 9 ) ;
VERIFY_META_SQRT ( 15 ) ;
VERIFY_META_SQRT ( 16 ) ;
VERIFY_META_SQRT ( 17 ) ;
VERIFY_META_SQRT ( 255 ) ;
VERIFY_META_SQRT ( 256 ) ;
VERIFY_META_SQRT ( 257 ) ;
VERIFY_META_SQRT ( 1023 ) ;
VERIFY_META_SQRT ( 1024 ) ;
VERIFY_META_SQRT ( 1025 ) ;
}