3 #include <funcy/concepts.h>     4 #include <funcy/constant.h>     5 #include <funcy/util/compute_conditional.h>     6 #include <funcy/util/derivative_wrappers.h>     7 #include <funcy/util/evaluate_if_present.h>     8 #include <funcy/util/type_traits.h>    10 #include <type_traits>    26         template < Function F, Function G >
    30             explicit Min( 
const F& f, 
const G& g ) : f_( f ), g_( g )
    36             template < 
class Arg >
    39                 update_if_present( f_, x );
    40                 update_if_present( g_, x );
    45             template < 
int index, 
class Arg >
    48                 update_if_present< index >( f_, x );
    49                 update_if_present< index >( g_, x );
    53             template < 
class... IndexedArgs >
    54             void bulk_update( IndexedArgs&&... args )
    56                 bulk_update_if_present( f_, args... );
    57                 bulk_update_if_present( g_, std::forward< IndexedArgs >( args )... );
    68             template < 
int id, 
class Arg,
    70             auto d1( Arg&& dx ) 
const    71                 requires( ComputeConditional< D1< F, IndexedArg >, D1< G, IndexedArg > >::present )
    73                 using D1F = D1< F, IndexedArg >;
    74                 using D1G = D1< G, IndexedArg >;
    75                 return ComputeConditional< D1F, D1G >( D1F( f_, dx ), D1G( g_, dx ),
    76                                                        f_smaller_than_g_ )();
    80             template < 
int idx, 
int idy, 
class ArgX, 
class ArgY,
    83             auto d2( ArgX&& dx, ArgY&& dy ) 
const    84                 requires( ComputeConditional< D2< F, IndexedArgX, IndexedArgY >,
    85                                               D2< G, IndexedArgX, IndexedArgY > >::present )
    87                 using D2F = D2< F, IndexedArgX, IndexedArgY >;
    88                 using D2G = D2< G, IndexedArgX, IndexedArgY >;
    89                 return ComputeConditional< D2F, D2G >( D2F( f_, dx, dy ), D2G( g_, dx, dy ),
    90                                                        f_smaller_than_g_ )();
    94             template < 
int idx, 
int idy, 
int idz, 
class ArgX, 
class ArgY, 
class ArgZ,
    98             auto d3( ArgX&& dx, ArgY&& dy, ArgZ&& dz ) 
const requires(
    99                 ComputeConditional< D3< F, IndexedArgX, IndexedArgY, IndexedArgZ >,
   100                                     D3< G, IndexedArgX, IndexedArgY, IndexedArgZ > >::present )
   102                 using D3F = D3< F, IndexedArgX, IndexedArgY, IndexedArgZ >;
   103                 using D3G = D3< G, IndexedArgX, IndexedArgY, IndexedArgZ >;
   104                 return ComputeConditional< D3F, D3G >( D3F( f_, dx, dy, dz ), D3G( g_, dx, dy, dz ),
   105                                                        f_smaller_than_g_ )();
   113                 f_smaller_than_g_ = x < y;
   114                 value_ = f_smaller_than_g_ ? x : y;
   119             bool f_smaller_than_g_;
   123     template < Function F, Function G >
   124     decltype( 
auto ) min( F&& f, G&& g )
   127                                                                     std::forward< G >( g ) );
   130     template < Function F, 
class G >
   131     decltype( 
auto ) min( F&& f, G&& g ) requires( !Function< G > )
   134             std::forward< F >( f ), 
constant( std::forward< G >( g ) ) );
   137     template < 
class F, Function G >
   138     decltype( 
auto ) min( F&& f, G&& g ) requires( !Function< F > )
   141             constant( std::forward< F >( f ) ), std::forward< G >( g ) );
 min function . 
Definition: min.h:27
auto d3(ArgX &&dx, ArgY &&dy, ArgZ &&dz) const requires(ComputeConditional< D3< F
Third directional derivative. 
Min(const F &f, const G &g)
Constructor. 
Definition: min.h:30
void update(Arg &&x)
Update point of evaluation. 
Definition: min.h:37
Main namespace of the funcy library. 
constexpr auto constant(Arg &&x) noexcept((std::is_rvalue_reference_v< Arg > &&std::is_nothrow_move_constructible_v< Arg >)||(std::is_lvalue_reference_v< Arg > &&std::is_nothrow_copy_constructible_v< Arg >))
Wrap a constant. 
Definition: constant.h:51
void update(Arg &&x)
Update variable corresponding to index. 
Definition: min.h:46
auto d1(Arg &&dx) const requires(ComputeConditional< D1< F
First directional derivative. 
typename Decay< std::decay_t< F > >::type decay_t
Access underlying type (if it is hidden by expression templates). 
Definition: type_traits.h:47
Definition: type_traits.h:54
Wrap a constant. 
Definition: constant.h:10
auto d2(ArgX &&dx, ArgY &&dy) const requires(ComputeConditional< D2< F
Second directional derivative. 
double operator()() const noexcept
Function value. 
Definition: min.h:62