Python list comprehension-like syntax in C++
data:image/s3,"s3://crabby-images/65f63/65f639d36089caf609ca6e97dad247f2147e3093" alt=""
In Pyhon: y = [foo(_1) for _1 in x] In C++: list<int> x; x.push_back(...); .. list<int> y; for (list<int>::iterator it = x.begin(); x.end() != it; ++ it) y.push_back( foo(y) ); With boost, can we write the Python-like statement: copy( x.begin(), x.end(), magic_back_inserter(foo(_1), y) ); // pseudo-code -- Tzu-Chien Chiu, 3D Graphics Hardware Architect URL:http://www.csie.nctu.edu.tw/~jwchiu
data:image/s3,"s3://crabby-images/459b0/459b05c510e36271c5487efcfc0bde5e3554adf1" alt=""
Tzu-Chien Chiu wrote:
In Pyhon:
y = [foo(_1) for _1 in x]
In C++:
list<int> x; x.push_back(...); ..
list<int> y; for (list<int>::iterator it = x.begin(); x.end() != it; ++ it) y.push_back( foo(y) );
With boost, can we write the Python-like statement:
copy( x.begin(), x.end(), magic_back_inserter(foo(_1), y) ); // pseudo-code
With the range_ex library in boost-sandbox, this would look like: boost::copy( x | boost::adaptor::transform(&foo) , std::back_inserter(y) ); range_ex.zip lives at: http://www.boost-consulting.com/vault/index.php?directory=Algorithms HTH -- Eric Niebler Boost Consulting www.boost-consulting.com
data:image/s3,"s3://crabby-images/087c6/087c646db7080d3b3f97df95b7e8fcf0edd68f7c" alt=""
In Pyhon:
y = [foo(_1) for _1 in x]
In C++:
list<int> x; x.push_back(...); ..
list<int> y; for (list<int>::iterator it = x.begin(); x.end() != it; ++ it) y.push_back( foo(y) );
With boost, can we write the Python-like statement:
copy( x.begin(), x.end(), magic_back_inserter(foo(_1), y) ); // pseudo- code
With the range_ex library in boost-sandbox, this would look like:
boost::copy( x | boost::adaptor::transform(&foo) , std::back_inserter(y) );
What about: std::transform( x.begin(), x.end(), std::back_inserter(y), boost::bind( &foo, _1 ) ); Sebastien Martel
data:image/s3,"s3://crabby-images/7e462/7e462d7dd00158b0a067f8a3b23a8e5edd2e9dce" alt=""
Seb Martel wrote:
std::transform( x.begin(), x.end(), std::back_inserter(y), boost::bind( &foo, _1 ) );
Or even
std::transform( x.begin(), x.end(), std::back_inserter(y), foo );
Could it be possible that bind detects identity usage like this and notify of the inefficiency?
bind( foo, _1 ) is not identity. It converts foo into a function object that is capable of taking N arguments, N >= 1, and ignoring all but the first. (Similarly, bind( foo, _2 ) ignores all arguments but the second.) In a template parameterized by the type of f, bind( f, _1 ) also works as an "universal adaptor" of sorts, turning member pointers and reference_wrappers into function objects (and defining a ::result_type as an extra bonus.)
data:image/s3,"s3://crabby-images/3a9c7/3a9c77ef382a579eb10c06b834c45b2b80bf1ad2" alt=""
Tzu-Chien Chiu wrote:
In Pyhon:
y = [foo(_1) for _1 in x]
In C++:
list<int> x; x.push_back(...); ..
list<int> y; for (list<int>::iterator it = x.begin(); x.end() != it; ++ it) y.push_back( foo(y) );
With boost, can we write the Python-like statement:
copy( x.begin(), x.end(), magic_back_inserter(foo(_1), y) ); // pseudo-code
-- Tzu-Chien Chiu, 3D Graphics Hardware Architect URL:http://www.csie.nctu.edu.tw/~jwchiu But what would an expression-template version look like? y = for_( _1 >> in >> x)[foo] That is what the composition operator would be for: operator _, say, so we could do : foo for_ _1 in x
participants (5)
-
Eric Niebler
-
Peter Dimov
-
Seb Martel
-
Simon Buchan
-
Tzu-Chien Chiu