From: Jon Harrop <jon@jdh30.plus.com>
To: caml-list <caml-list@inria.fr>
Subject: Re: [Caml-list] C++ STL and template features compared with OCaml parametric polymorphism and OO features
Date: Mon, 27 Sep 2004 17:54:35 +0100 [thread overview]
Message-ID: <200409271754.36040.jon@jdh30.plus.com> (raw)
In-Reply-To: <7f8e92aa04092706317dae6556@mail.gmail.com>
On Monday 27 September 2004 14:31, Radu Grigore wrote:
> The
> difference is that after you write the iterators code for a new
> sequence-like data structure all the "generic" functions, not only
> fold but also map and others, will automagically work on them.
I think this is the core of what we disagree on. I believe you'll be
implementing a new data structure (e.g. splay trees) because you want to use
different algorithms under the hood so that you get different asymptotic
complexities for different operations. Therefore, the "automagically"
generated ones will be useless because they'll have terrible performance -
they'll need replacing.
The different functions (e.g. insert, find for a splay tree) require
completely different algorithms so iterators are useless. For example, "find"
on a "set" in the STL does not use iterators. Equivalently, the HOF fold is
useless, e.g. "find" in "Set" in OCaml does not use fold:
let rec fold f s accu = match s with
Empty -> accu
| Node(l, v, r, _) -> fold f l (f v (fold f r accu))
The similar functions (e.g. accumulate for a splay tree) do have commonality
which can be factored out. This commonality is factored out as functions
templated over iterators in the STL. In OCaml, this can be factored out by
writing these functions in terms of fold:
let sum fold c = fold ( +. ) 0. c
let list_sum = sum List.fold_left
The automagic effect will only be worthwhile if you are implementing a lot of
data structures (which is very unlikely) in which case you can use a tuple of
functions:
let common fold =
(fun fold c -> fold ( +. ) 0. c),
...
let list_sum, list_... = common List.fold_left
> You should really check out the article cited by Vasili. It seems that
> we understend different things by "functional equivalent of an
> iterator",
I read it yesterday and, indeed, we did not mean the same thing by that term.
I was referring to how I would go about rewriting a C++/iterators program in
OCaml. I wouldn't begin by implementing iterators. I think you were referring
to how iterators could be implemented in a functional language. Is that
right?
Cheers,
Jon.
-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
next prev parent reply other threads:[~2004-09-27 16:58 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-09-25 21:12 Vasili Galchin
2004-09-25 21:38 ` Nicolas Cannasse
2004-09-25 22:15 ` Vasili Galchin
2004-09-25 22:52 ` Vasili Galchin
2004-09-26 1:34 ` Jon Harrop
2004-09-26 5:31 ` Radu Grigore
2004-09-26 9:47 ` sejourne_kevin
2004-09-26 13:05 ` Jon Harrop
2004-09-26 14:36 ` skaller
2004-09-26 15:08 ` sejourne_kevin
2004-09-26 15:27 ` skaller
2004-09-26 18:51 ` Jon Harrop
2004-09-26 20:14 ` Radu Grigore
2004-09-27 1:59 ` Jon Harrop
2004-09-27 4:48 ` skaller
2004-09-27 9:40 ` Jacques GARRIGUE
2004-09-27 10:50 ` Radu Grigore
2004-09-27 12:14 ` skaller
2004-09-27 13:11 ` Jon Harrop
2004-09-27 13:31 ` Radu Grigore
2004-09-27 16:54 ` Jon Harrop [this message]
2004-09-29 18:59 ` Radu Grigore
2004-09-27 13:32 ` Radu Grigore
2004-09-27 14:04 ` Brian Hurt
2004-09-27 14:58 ` skaller
2004-09-27 15:30 ` Brian Hurt
2004-09-27 16:38 ` skaller
2004-09-27 17:01 ` Brian Hurt
2004-09-28 1:21 ` skaller
2004-09-27 16:41 ` brogoff
2004-09-28 0:26 ` skaller
2004-09-29 15:32 ` Florian Hars
2004-09-29 16:49 ` [Caml-list] Factoring HOFs [was Re: C++ STL...] Jon Harrop
2004-09-30 9:19 ` Radu Grigore
2004-09-30 10:13 ` Keith Wansbrough
2004-09-30 10:31 ` Keith Wansbrough
2004-09-30 13:21 ` skaller
2004-09-30 23:17 ` [Caml-list] Factoring HOFs Jacques Garrigue
2004-10-01 8:46 ` Keith Wansbrough
2004-10-01 17:35 ` brogoff
2004-09-26 20:43 ` [Caml-list] C++ STL and template features compared with OCaml parametric polymorphism and OO features skaller
2004-09-26 14:19 ` skaller
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=200409271754.36040.jon@jdh30.plus.com \
--to=jon@jdh30.plus.com \
--cc=caml-list@inria.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