Rocksolid Light

News from da outaworlds

mail  files  register  groups  login

Message-ID:  

BOFH excuse #55: Plumber mistook routing panel for decorative wall fixture


comp / comp.lang.scheme / Re: DEFUN list argument

SubjectAuthor
* Re: DEFUN list argumentB. Pym
`* Re: DEFUN list argumentKaz Kylheku
 `- Re: DEFUN list argumentAxel Reichert

1
Subject: Re: DEFUN list argument
From: B. Pym
Newsgroups: comp.lang.lisp, comp.lang.scheme
Organization: A noiseless patient Spider
Date: Sun, 29 Sep 2024 00:52 UTC
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: Nobody447095@here-nor-there.org (B. Pym)
Newsgroups: comp.lang.lisp,comp.lang.scheme
Subject: Re: DEFUN list argument
Date: Sun, 29 Sep 2024 00:52:08 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 20
Message-ID: <vda8bn$1f4vl$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=iso-8859-1
Injection-Date: Sun, 29 Sep 2024 02:52:09 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="51cc0e2371b0a3eb39fb31df15078e2b";
logging-data="1545205"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1806gi4HjuU8spJaBSrxZve"
User-Agent: XanaNews/1.18.1.6
Cancel-Lock: sha1:f0I/wL8834XY4IEB38m2w1OHpCo=
View all headers

> (defun list-of-length (n list)
> "Predicate which tests whether LIST is a list
> of length N."
> (loop for i from 0 below n
> when (null list) do (return nil)
> do (pop list)
> finally (return (null list))))

Instead of using a macro whose source measures 60 kilobytes,
we can make it shorter by simply using recursion. Of course,
that's not possible in CL since it's not a Lispy language and
doesn't offer tail-call optimization. (Lispy languages
encourage recursive solutions.)

Scheme:

(define (list-of-length? n lst)
(cond ((zero? n) (null? lst))
((null? lst) #f)
(#t (list-of-length? (- n 1) (cdr lst)))))

Subject: Re: DEFUN list argument
From: Kaz Kylheku
Newsgroups: comp.lang.lisp, comp.lang.scheme
Organization: A noiseless patient Spider
Date: Sun, 29 Sep 2024 02:21 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: 643-408-1753@kylheku.com (Kaz Kylheku)
Newsgroups: comp.lang.lisp,comp.lang.scheme
Subject: Re: DEFUN list argument
Date: Sun, 29 Sep 2024 02:21:46 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 60
Message-ID: <20240928190603.978@kylheku.com>
References: <vda8bn$1f4vl$1@dont-email.me>
Injection-Date: Sun, 29 Sep 2024 04:21:46 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="bc6fdb5b8799704bd2680cae9af28e0f";
logging-data="1685504"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/vsY2EK5yu+N8m1VtampokaKRcI7+9P3w="
User-Agent: slrn/pre1.0.4-9 (Linux)
Cancel-Lock: sha1:IXpb3mxzEsbIvRRhtI+sLuGMU0w=
View all headers

On 2024-09-29, B. Pym <Nobody447095@here-nor-there.org> wrote:
>> (defun list-of-length (n list)
>> "Predicate which tests whether LIST is a list
>> of length N."
>> (loop for i from 0 below n
>> when (null list) do (return nil)
>> do (pop list)
>> finally (return (null list))))
>
> Instead of using a macro whose source measures 60 kilobytes,

.... we can use a macro whose source is 20 lines and which is not
included in our languager implementation, and then claim that a 7 line
function that must be accompanied by that macro is shorter than a 5 line
function depending only on ANSI Common Lisp.

> we can make it shorter by simply using recursion. Of course,
> that's not possible in CL since it's not a Lispy language and
> doesn't offer tail-call optimization.

The Common Lisp specification doesn't require it, but implementations
offer it.

The ISO C specification deosn't require any optimization at all; yet C
users rely on optimizations (one of them being TCO, by the way).

In C, nobody in their right mind writes i >> 1 rather than i / 2 any
more, even though ISO C doesn't "offer" the assumption that i / 2 will
be reduced to a shift.

> Scheme:

Scheme offers very little; most serious work done with Scheme picks
an implementation and uses it.

Many of your own posts pick a particular Scheme like Gauche and
often use its extensions that are not in Scheme.

> (define (list-of-length? n lst)
> (cond ((zero? n) (null? lst))
> ((null? lst) #f)
> (#t (list-of-length? (- n 1) (cdr lst)))))

You would avoid this kind of function entirely (and linked lists
all together) in code that is to be maximally performant. Linked
lists have poor cache performance. Chasing down a linked list
involved dependent loads which the machine cannot prefetch, unlike
marching down an array that is contiguously laid out in memory.

The battle you are trying to pick here is outdated.

Whether list processing code is recursive or iterative, and how fast it
is, is largerly irrelevant. Most list processing is compile time code
wrangling (macros and whatnot). Performance of the compile time is
not highly relevant, or else nobody would be using C++.

--
TXR Programming Language: http://nongnu.org/txr
Cygnal: Cygwin Native Application Library: http://kylheku.com/cygnal
Mastodon: @Kazinator@mstdn.ca

Subject: Re: DEFUN list argument
From: Axel Reichert
Newsgroups: comp.lang.lisp, comp.lang.scheme
Followup: comp.lang.lisp
Organization: A noiseless patient Spider
Date: Sun, 29 Sep 2024 11:51 UTC
References: 1 2
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: mail@axel-reichert.de (Axel Reichert)
Newsgroups: comp.lang.lisp,comp.lang.scheme
Subject: Re: DEFUN list argument
Followup-To: comp.lang.lisp
Date: Sun, 29 Sep 2024 13:51:54 +0200
Organization: A noiseless patient Spider
Lines: 24
Message-ID: <87plom3cf9.fsf@axel-reichert.de>
References: <vda8bn$1f4vl$1@dont-email.me> <20240928190603.978@kylheku.com>
MIME-Version: 1.0
Content-Type: text/plain
Injection-Date: Sun, 29 Sep 2024 13:52:10 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="e6bda63b1c26550a1b943331b934869e";
logging-data="1838434"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19L3ZulVDswx3VVzoZ7d7o5dJqZdfOBj/k="
User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/28.2 (gnu/linux)
Cancel-Lock: sha1:Fpnsgj+R6f1gAcHGl+6ImM8u4Xg=
sha1:7WOc76BJOgKlon1gy7lCurqepSU=
View all headers

Kaz Kylheku <643-408-1753@kylheku.com> writes:

> Scheme offers very little; most serious work done with Scheme picks an
> implementation and uses it.
>
> Many of your own posts pick a particular Scheme like Gauche and often
> use its extensions that are not in Scheme.

Like in geography: "Where does London end?" (-:

> Linked lists have poor cache performance. Chasing down a linked list
> involved dependent loads which the machine cannot prefetch, unlike
> marching down an array that is contiguously laid out in memory.
>
> The battle you are trying to pick here is outdated.

I have read so a couple of times. Interesting. But what is a Lisper to
do in the source code? Convert it all to vectors/arrays? Use more
imperative idioms than recursion? Do not care, because it is all handled
by the implementation?

Honestly curious,

Axel

1

rocksolid light 0.9.8
clearnet tor