Mailing list for all users of the OCaml language and system.
 help / color / mirror / Atom feed
From: Jacques Carette <carette@mcmaster.ca>
To: "Michaël Grünewald" <michaelgrunewald@yahoo.fr>
Cc: caml-list@inria.fr
Subject: Re: [Caml-list] Defining a family of functors
Date: Mon, 26 Jan 2009 10:15:36 -0500	[thread overview]
Message-ID: <497DD398.5030501@mcmaster.ca> (raw)
In-Reply-To: <497DD1F5.7050702@yahoo.fr>

Without the projections, you can do it via a higher-order Functor which 
does a fold, ie lifting to the Functor level what one usually does to 
get an n-ary product out of a binary product.

With the projections, as this involves name-generation, I don't see how 
to do it without using camlp4.  Even my favourite sledgehammer, 
metocaml, can't help here.

Jacques

Michaël Grünewald wrote:
> I am facing a situation that could be solved by ``defining a family of 
> functors'', I describe the problem and would be very glad to get your 
> views about it.
>
> To illustrate the situation, I will suppose A1, ..., An are modules 
> implementing the same signature S, let's say S contains the usual 
> opertations on groups (mathematical groups, you can replace this by 
> vector spaces, or whatever). It is easy to write a Product2 functor
>
> Product2: A1:S -> A2:S -> S2
>
> producing an implementation for the direct product (with signature S) 
> of the groups A1 and A2, plus injections j1 : A1.t -> S2.t and j2: 
> A2.t -> S2.t and corresponding projections (the type t denotes the 
> module thingie, as usual). This extension of S is here written S2.
>
> My problem is ``how do I remove the 2'' ? Would it be possible to 
> define a functor scheme [:)]
>
> Productn: A1:S -> .. -> An:S -> Sn
>
> able to instantiate concrete functors for any value of n ?
>
> It is possible to generate automatically appropriate code for small 
> values of n, but I am looking for a better approach. It is simple to 
> get close of the solution in the object paradigm, since I can simply 
> put objects in an array and iterate over this array (IIRC this is the 
> aggregate design pattern), but I do not see an easy way to define 
> injections and projections.


  reply	other threads:[~2009-01-26 15:16 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-01-26 15:08 Michaël Grünewald
2009-01-26 15:15 ` Jacques Carette [this message]
2009-01-27 14:30   ` [Caml-list] " Andrej Bauer
2009-01-27 14:47     ` Jacques Carette
2009-01-27 21:12       ` David Teller
2009-01-28  0:32         ` Nicolas Pouillard
2009-01-28 11:25           ` David Teller
2009-01-29  9:37             ` nicolas.pouillard
2009-01-29 10:40               ` David Allsopp
2009-01-29 21:14                 ` Mauricio Fernandez
2009-01-30  8:25                   ` Michaël Grünewald

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=497DD398.5030501@mcmaster.ca \
    --to=carette@mcmaster.ca \
    --cc=caml-list@inria.fr \
    --cc=michaelgrunewald@yahoo.fr \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox