digitalmars.D.learn - Partial function application (Currying)
- atzensepp (26/26) Jan 20 2024 Hello,
- Christian =?UTF-8?B?S8O2c3RsaW4=?= (5/5) Jan 20 2024 Would
- atzensepp (9/14) Jan 20 2024 Hello Christian,
- Richard (Rikki) Andrew Cattermole (4/4) Jan 20 2024 Not really any other way to do it, create context (i.e. struct, or
- atzensepp (27/32) Jan 20 2024 Hi Rikki,
- Richard (Rikki) Andrew Cattermole (25/30) Jan 20 2024 This worked:
- atzensepp (12/44) Jan 20 2024 Hello Rikki,
Hello,
D-Language allows for anonymous functions.
Is there a way of elegant partial function application such as in 
other (functional) languages?
A function "doemar" accepts a function with one parameter,
Another function g defined within mail accepts two parameters and 
should be applied partially. I found a way but it requires a 
temporary lambda expression in the invocation.
Is there a better way to do this?
```d
     void doemar( int delegate(int y) f)
     {
        for(int i=0;i<3;i++) writeln( f(i));
     }
     void main()
     {
        int delegate(int x,int y) g;
        for (int i=0;i<3;i++)
        {
           g = (a,b) => i*10+ a*3+b;
           writeln("---------");
           doemar( (x) => g(x,i));
        }
     }
```
Thanks
 Jan 20 2024
Would https://dlang.org/library/std/functional/curry.html help you? kind regards, Christian
 Jan 20 2024
On Saturday, 20 January 2024 at 17:45:36 UTC, Christian Köstlin wrote:Would https://dlang.org/library/std/functional/curry.html help you? kind regards, ChristianHello Christian, thank for the link. I looks good however in my installation (gdc 8.4.0) it says: ```d curry.d:1:8: error: module std.functional import 'curry' not found ``` Do I need to switch do another compiler?
 Jan 20 2024
Not really any other way to do it, create context (i.e. struct, or stack) and have a delegate point to both it and a patch function. It'll be how partial is implemented. https://dlang.org/phobos/std_functional.html#.partial
 Jan 20 2024
On Saturday, 20 January 2024 at 17:47:29 UTC, Richard (Rikki) Andrew Cattermole wrote:Not really any other way to do it, create context (i.e. struct, or stack) and have a delegate point to both it and a patch function. It'll be how partial is implemented. https://dlang.org/phobos/std_functional.html#.partialHi Rikki, thanks for the link to partial. I tried this: ```d import std.stdio; // Overloads are resolved when the partially applied function is called // with the remaining arguments. struct S { static char fun(int i, string s) { return s[i]; } static int fun(int a, int b) { return a * b; } } void main() { alias fun3 = partial!(S.fun, 3); writeln(fun3("hello")); // 'l' writeln(fun3(10)); // 30 } ``` But getting: ``` partial.d:12:14: error: template instance partial!(S.fun, 3) partial is not a template declaration, it is a module alias fun3 = partial!(S.fun, 3); ```
 Jan 20 2024
On 21/01/2024 9:55 AM, atzensepp wrote:
 import std.stdio; // Overloads are resolved when the partially applied 
 function is called // with the remaining arguments. struct S { static 
 char fun(int i, string s) { return s[i]; } static int fun(int a, int b) 
 { return a * b; } } void main() { alias fun3 = partial!(S.fun, 3); 
 writeln(fun3("hello")); // 'l' writeln(fun3(10)); // 30 }
This worked:
```d
import std.functional;
import std.stdio;
// Overloads are resolved when the partially applied function is called
// with the remaining arguments.
struct S
{
     static char fun(int i, string s)
     {
         return s[i];
     }
     static int fun(int a, int b)
     {
         return a * b;
     }
}
void main()
{
     alias fun3 = partial!(S.fun, 3);
     writeln(fun3("hello")); // 'l'
     writeln(fun3(10)); // 30
}
```
 Jan 20 2024
On Saturday, 20 January 2024 at 20:58:49 UTC, Richard (Rikki) Andrew Cattermole wrote:On 21/01/2024 9:55 AM, atzensepp wrote:Hello Rikki, thank you, this helps a lot although the polymorphism does not work in my environment. ``` partial2.d:23:17: error: function std.functional.partial!(fun, 3).partial (string _param_0) is not callable using argument types (int) writeln(fun3(10)); // 30 ``` But when I rename the functions for each case currying works well.import std.stdio; // Overloads are resolved when the partially applied function is called // with the remaining arguments. struct S { static char fun(int i, string s) { return s[i]; } static int fun(int a, int b) { return a * b; } } void main() { alias fun3 = partial!(S.fun, 3); writeln(fun3("hello")); // 'l' writeln(fun3(10)); // 30 }This worked: ```d import std.functional; import std.stdio; // Overloads are resolved when the partially applied function is called // with the remaining arguments. struct S { static char fun(int i, string s) { return s[i]; } static int fun(int a, int b) { return a * b; } } void main() { alias fun3 = partial!(S.fun, 3); writeln(fun3("hello")); // 'l' writeln(fun3(10)); // 30 } ```
 Jan 20 2024








 
  
  
 
 atzensepp <webwicht web.de>
 atzensepp <webwicht web.de> 