public
Created

algorisme with operator composition *

  • Download Gist
algorisme_composicio.d
D
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
//D 2.0
//gdmd-4.6 <fitxer>
//Algorisme: implementació dels algorismes genèrics i els seves estructures de dades
 
//ordenar alfabèticament:
import std.conv, std.stdio, std.stream, std.string;
import std.socket, std.socketstream;
import std.datetime, std.functional, std.math;
 
class Algorisme(U,V) {
string nom;
uint versio;
alias V function (U) Funcio;
Funcio funcio;
 
this(string nom, uint versio, Funcio funcio) {
try {
this.nom = nom;
this.versio = versio;
this.funcio = funcio;
}
catch {
writeln("Error");
}
}
 
string toString() {
return format("%s (versió %s): %s -> %s", nom, versio, typeid(U), typeid(V));
}
 
//f: T -> U, g: U -> V; g·f = g(f): T -> V. this és g perquè està a l'esquerra
Algorisme!(T,V) opBinary(string op, T)(Algorisme!(T,U) alg) {
if (op=="*") {
//fer la funció composicio
return new Algorisme!(T,V)(this.nom ~ " · " ~ alg.nom, 1, function(T t) { return this.funcio(alg.funcio(t)); } );
}
}
 
}
 
 
alias Algorisme!(int, int) AlgorismeEnters;
 
 
void main(string [] args)
{
enum codi = "function(int a) { return 2 * a; }";
auto alg = new AlgorismeEnters("Doblar", 1, mixin(codi));
auto alg2 = new AlgorismeEnters("Triplicar", 1, function (int a) {return 3 * a;});
writeln(alg);
writeln(alg2);
writeln(alg * alg2);
}

Please sign in to comment on this gist.

Something went wrong with that request. Please try again.