
Thanks for the rapid response on the previous question. Now for my real question: I am using an autodifferentiation library and want to use lambda's bind, but still return a generic type. Is this possible? Here is the function I wrote : struct test_function_impl { //result_of supprt template<typename Sig> struct result; template<typename This, typename Arg1, typename Arg2> struct result<This(Arg1, Arg2)> { typedef typename boost::remove_reference<Arg1>::type::value_type type; }; template<typename Vector, typename IntT> typename Vector::value_type //The type in the vector... can be a double or AD type operator()(const Vector& x, IntT y) const{ return x[0] * x[0] + y; } }; The function works on its own, and now std::tr1::result_of seems to work as well. However, I cannot bind to this: using namespace boost::lambda; ublas::bounded_vector<double, 1> x; x[0] = 1.0; int int_value = 1; //THIS FAILS! Not sure if lambda's bind is using result_of? Obviously, can't use the ret<> approach here. auto f = bind(test_function_impl(), _1, int_value); Does lambda support this usage, or should I turn to Phoenix (if so, I am recognizing a trend here). -Jesse