[function] generalization of std::plus and std::multiplies with more than one argument type
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
Does Boost have a generalization of std::plus and std::multiplies
(std_function.hpp)?
The standard defines this with only one template parameter
template <class _Tp>
struct multiplies : public binary_function<_Tp, _Tp, _Tp>
{
_Tp
operator()(const _Tp& __x, const _Tp& __y) const
{ return __x * __y; }
};
but I need something more general, where the types are different
multiplies
data:image/s3,"s3://crabby-images/7da80/7da80df736c61c9502b8b18cdf519a6e9eba8a2a" alt=""
alfC wrote:
Does Boost have a generalization of std::plus and std::multiplies (std_function.hpp)?
How about the boost::lambda arithmetic operators, possibly in
combination with ll_static_cast<Tp>, and -if necessary- put the result
in the functor wrapper boost::function
data:image/s3,"s3://crabby-images/cd5df/cd5dfc465235a484b7de5b253cf5e1f8321db5d8" alt=""
On 08.10.2009, at 17:27, er wrote:
alfC wrote:
Does Boost have a generalization of std::plus and std::multiplies (std_function.hpp)?
How about the boost::lambda arithmetic operators, possibly in combination with ll_static_cast<Tp>, and -if necessary- put the result in the functor wrapper boost::function
?
You probably already know this but in my (non authoritative) opinion, this is as close a generalization as can be.
I had such a class in our libraries, but threw it out and replaced it with lambda expressions Matthias
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
thank you er and Mathias for your answers,
alfC wrote:
Does Boost have a generalization of std::plus and std::multiplies (std_function.hpp)?
How about the boost::lambda arithmetic operators, possibly in combination with ll_static_cast<Tp>, and -if necessary- put the result in the functor wrapper boost::function
?
what is "ll_static_cast<Tp>"? after that part I got lost.
I had such a class in our libraries, but threw it out and replaced it with lambda expressions
but I need this generalization of multiplies as one of the default parameter of a template, how would you pass a lambda expression as template parameter? The reason I returned to my post is that today I found boost/mpl/ plus.hpp and boost/mpl/multiplies.hpp which seem to answer the first part of my question (although not the syntactic sugar part). Thank you, Alfredo
data:image/s3,"s3://crabby-images/89590/89590d82cbe9918869d50d06c72e3afad4a31b25" alt=""
alfa wrote:
but I need this generalization of multiplies as one of the default parameter of a template, how would you pass a lambda expression as template parameter?
As a part of my workj on Boost.SIMD, i have a generlized fucntor with
result_of protocol support and tag-dispatching.
Basically :
functor<plus>()(x,y)
return the sum of x and y for the correct semantic of + for the type of
x and y.
result_of
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
As a part of my workj on Boost.SIMD, i have a generlized fucntor with result_of protocol support and tag-dispatching.
thank you, where I can find Boost.SIMD, is functor defined there?
Basically :
functor<plus>()(x,y)
return the sum of x and y for the correct semantic of + for the type of x and y.
is this "plus" the same as "std::plus"? If so how can x, y be of different type?
result_of
::type returns it result type. Is that smthg like that you need ?
seems very similar to what I am looking for. I will know after knowning more details. Thank you, Alfredo
data:image/s3,"s3://crabby-images/89590/89590d82cbe9918869d50d06c72e3afad4a31b25" alt=""
alfC wrote:
thank you, where I can find Boost.SIMD, is functor defined there? Boost.SIMD is currently under work and will be released to the vault "soon"
is this "plus" the same as "std::plus"? If so how can x, y be of different type?
no, this plus is a tag defined by the library. x and y are from different type and i use a tag dispatching method to discriminate the actual semantic of plus to use. Basically, I scan the argument list and try to find non trivial types, if i do i ask for a specific properties called tag_of on those types and select the implementation to use to perform the operation. Currently we support arithmetic types and SIMD types but we provide an extension mecanism so you can define your own type set and give them proper implementation (for ex., complex number, matrix etc). All those variation are called by the same functor call anyway, making it a pure generic tag-dispatched computation facility.
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG alfC wrote:
The reason I returned to my post is that today I found boost/mpl/ plus.hpp and boost/mpl/multiplies.hpp which seem to answer the first part of my question (although not the syntactic sugar part).
mpl::plus and mpl::multiplies are not function objects. You
can't use them with int, for example. They are metafunctions
that mainly work with MPL Integral Constant Wrappers:
BOOST_MPL_ASSERT((boost::mpl::equal_to<
boost::mpl::plus
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
On Oct 16, 8:52 am, Steven Watanabe
mpl::plus and mpl::multiplies are not function objects. You can't use them with int, for example. They are metafunctions that mainly work with MPL Integral Constant Wrappers:
I see, I got confused because in the source (which is very difficult to read with all the defines, there is a point where you "#define AUX778076_OP_TOKEN +" so I though that it really implemented a functor. But it seems that the "token" is used only for the compile- time constants in the code after all. Thank you, Alfredo
data:image/s3,"s3://crabby-images/7da80/7da80df736c61c9502b8b18cdf519a6e9eba8a2a" alt=""
alfC wrote:
thank you er and Mathias for your answers,
alfC wrote:
Does Boost have a generalization of std::plus and std::multiplies (std_function.hpp)? How about the boost::lambda arithmetic operators, possibly in combination with ll_static_cast<Tp>, and -if necessary- put the result in the functor wrapper boost::function
what is "ll_static_cast<Tp>"? after that part I got lost.
the cast was in mind to allow for an argument that is convertible to but not necessarily equal to Tp.
but I need this generalization of multiplies as one of the default parameter of a template, how would you pass a lambda expression as template parameter?
Since you insist on a template parameter,
template
The reason I returned to my post is that today I found boost/mpl/ plus.hpp and boost/mpl/multiplies.hpp which seem to answer the first part of my question (although not the syntactic sugar part).
Thank you, Alfredo
participants (5)
-
alfC
-
er
-
Joel Falcou
-
Matthias Troyer
-
Steven Watanabe