* How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
@ 2011-01-01 7:04 girosenth
2011-01-01 11:39 ` Elena
` (9 more replies)
0 siblings, 10 replies; 84+ messages in thread
From: girosenth @ 2011-01-01 7:04 UTC (permalink / raw)
To: help-gnu-emacs; +Cc: girosenth, girosenth
How to improve the readability of (any) LISP or any highlevel
functional language to the level of FORTH ?
There are many people who have trivia complaints about parens in lisp,
but I dont.
LISP is a prefix notation.
sequence of operations would look like this on operands (ops) :
(f ops (g ops (h ops (j ops (k ops (l ops ))...))))
How do you make it readable ?
How do you home to the center or centers ?
(f (g (h (j (k (l ops)))...)))
is easy to read or
ops l k j h g f
???
Which is linear reading from L->R ? LISP or FORTH ?
AND, if I must break the nested function structure, will I not be
visiting the forbidden territory of imperative programming ?
(setq L (l ops))
(setq K (k L ))
....
....
(setq F (f G ))
If I use setq, I am using globals, atleast in elisp.
If I use let*, I have limited options as I am constrained inside the
rigid structure of let*
(let*
((L (l ops))
(K (k L ))
....
(F (f G )))
some more
)
Is there a postfix functional language that also gets rid of parens
and is not as primitive as FORTH or POSTSCRIPT ?
What are the syntax advantages of ERLANG, ML, CAML, OCAML, HASKELL,
PROLOG, RUBY over LISP ?
How does one improve readability so that the code is self-commenting ?
girosenth
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
@ 2011-01-01 11:39 ` Elena
2011-01-01 14:15 ` Pascal J. Bourguignon
` (8 subsequent siblings)
9 siblings, 0 replies; 84+ messages in thread
From: Elena @ 2011-01-01 11:39 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 8:04 am, girosenth <girose...@india.com> wrote:
> Is there a postfix functional language that also gets rid of parens
> and is not as primitive as FORTH or POSTSCRIPT ?
Factor? http://factorcode.org/
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
2011-01-01 11:39 ` Elena
@ 2011-01-01 14:15 ` Pascal J. Bourguignon
2011-01-01 16:08 ` Nathan
` (2 more replies)
2011-01-01 18:27 ` How to improve the readability of Steve Revilak
` (7 subsequent siblings)
9 siblings, 3 replies; 84+ messages in thread
From: Pascal J. Bourguignon @ 2011-01-01 14:15 UTC (permalink / raw)
To: help-gnu-emacs
girosenth <girosenth@india.com> writes:
> How to improve the readability of (any) LISP or any highlevel
> functional language to the level of FORTH ?
>
> There are many people who have trivia complaints about parens in lisp,
> but I dont.
>
> LISP is a prefix notation.
>
> sequence of operations would look like this on operands (ops) :
>
> (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> How do you make it readable ?
> How do you home to the center or centers ?
>
> (f (g (h (j (k (l ops)))...)))
>
> is easy to read or
>
> ops l k j h g f
>
> ???
I think we can call you a troll.
Is it not obvious how you home to the center?
http://www.informatimago.com/~pjb/bulleye.png
Is it not a flagrant proof that lisp is the most easy to read?
--
__Pascal Bourguignon__ http://www.informatimago.com/
A bad day in () is better than a good day in {}.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 14:15 ` Pascal J. Bourguignon
@ 2011-01-01 16:08 ` Nathan
2011-01-01 18:05 ` Jan Burse
` (2 more replies)
2011-01-01 22:50 ` girosenth
2011-01-02 23:45 ` Chip Eastham
2 siblings, 3 replies; 84+ messages in thread
From: Nathan @ 2011-01-01 16:08 UTC (permalink / raw)
To: help-gnu-emacs
If you want a easy to read self-documenting functional language, look
into Ruby. I know personally that Ruby syntax was a big turn off to me
for several weeks (kind of like Lisp) but once you learn it, it
becomes the easiest to read of any programming language I've ever
experimented with. No contest.
Matz himself admitted that “...Ruby is a bad rip-off of Lisp... But it
is nicer to ordinary people.”
Though every language I've worked in, I've never been half as
productive as when I'm coding in Ruby. There are so many built in
methods to help you with common day to day tasks, and the end result
of your code will be simpler and clearer to read than you can have it
in any other language.
The downside of course is that Ruby lends itself to the efficient
production of very inefficient code. You'll be plagued with strict
evaluative breath first traversals that glut on your memory. You'll
find yourself cursing a global interpreter lock that makes Ruby's
simple method for handling threads meaningless in most situations.
In my hands, Ruby's nature seems to lend itself to the design of
inefficient code, but that can be overcome with a little attention.
Overall, I left Ruby because the community support was somewhat less
than I wanted. In particular, cross platform GUI application
development seemed poor.
If you want to develop webpages, or bang out quick one time scripts,
Ruby is hard to beat. For use at home, console applications are
probably a tolerable price to pay for the incredible development speed
and fantastic ease of maintenance Ruby will give your code.
If you give it an hour a day for two months, I guarantee you will be
head over heals in love with the Ruby language. If you're not, please
send me an email and tell me what language you prefer because I want
to try it out.
Ruby is just a blast to code in. If it had stronger GUI support, no
global interpretor lock, and either lazy evaluation or preemptive
multi-threading (with a strong preference toward the latter), I'd be
content to settle down with that for the rest of my life. But then,
this is from a guy who's learning Lisp only for the sake of mastering
a superior abstraction model. You might want to take me with a grain
of salt.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 16:08 ` Nathan
@ 2011-01-01 18:05 ` Jan Burse
2011-01-01 23:56 ` The Quiet Center
2011-01-03 10:29 ` How to improve the readability of (any) LISP or any highlevel functional " Didier Verna
2 siblings, 0 replies; 84+ messages in thread
From: Jan Burse @ 2011-01-01 18:05 UTC (permalink / raw)
To: help-gnu-emacs
Hi
I am responding from comp.lang.prolog.
Nathan schrieb:
> Ruby is just a blast to code in. If it had stronger GUI support, no
> global interpretor lock,
I think a global interpreter lock can be avoided by combining
the following approaches in logic programming languages:
0) Actual parameter data structures (of a thread running in the
interpreter) should be immune to concurrency problems.
1) Conversions between actual parameter data structures, and
global data structures (of the interpreter).
2) No exposure of global data structures,
only access via the interpreter.
3) When exposure of global data structures, then access via
thread safe methods.
Interestingly 0) and 1) is automatically assured by Prolog
implementations. Actual parameters are not visible between
threads, and clause instantiation can be viewed as producing
actual parameter data structures from global data structures,
whereas asserting a clause can be viewed as producting global
data structures form actual parameter data structures.
Point 2) and 3) depend on the API design for a Prolog implementation.
For point 2) it is assumend that a multi-threaded interpreter will
not have any problems accessing its global data structures, for
example in the case of Prolog clauses, concurrently. For 3) it
is assumed that corresponding access can be encapsulated in
thread safe methods.
There are a couple of Prolog system implementations around
that support multi threading. For example SWI Prolog. Or
Jekejeke Prolog. In Jekejeke Prolog mostly the approach 2)
has been followed by the API on purpose.
> and either lazy evaluation or preemptive multi-threading (with a
> strong preference toward the latter),
The threads deployed by multi-threading Prologs are preemptive.
They typically don't follow the cooperative model, because
coopertaive threads have only limited applications. SWI
Prolog has preemptive threads (*), Jekejeke Prolog inherits
the property from the threads of the Java VM.
Best Regards
(*)
http://hcs.science.uva.nl/projects/SWI-Prolog/articles/iclp-03.pdf
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of ...
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
2011-01-01 11:39 ` Elena
2011-01-01 14:15 ` Pascal J. Bourguignon
@ 2011-01-01 18:27 ` Steve Revilak
2011-01-01 19:22 ` How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? prad
` (6 subsequent siblings)
9 siblings, 0 replies; 84+ messages in thread
From: Steve Revilak @ 2011-01-01 18:27 UTC (permalink / raw)
To: help-gnu-emacs
[-- Attachment #1: Type: text/plain, Size: 1119 bytes --]
>From: girosenth <girosenth@india.com>
>How to improve the readability of (any) LISP or any highlevel
>functional language to the level of FORTH ?
I am not familiar with forth, but I can respond to the general issue
of improving code readability.
>How does one improve readability so that the code is self-commenting ?
I believe that you need to think of the act of writing a program as an
act of *writing*.
Many writers start with an outline, then a first draft, then many
rounds of revision and editing. The goal of the first draft is to get
the basic ideas down. The goal of revision and editing is to polish
the ideas, and to make them easier for the reader to understand. It's
rare for a first draft to be the final version.
Writing a program is no different. The first draft is the first
version that runs without crashing :) The editing and revision process
is where you clean things up, improve structure, and so fourth.
You should also read lots of code, to get ideas from other writers.
In short, the writer influences readability much more than the
language that he or she is writing in.
Steve
[-- Attachment #2: Type: application/pgp-signature, Size: 198 bytes --]
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (2 preceding siblings ...)
2011-01-01 18:27 ` How to improve the readability of Steve Revilak
@ 2011-01-01 19:22 ` prad
2011-01-01 23:56 ` Pascal Costanza
` (5 subsequent siblings)
9 siblings, 0 replies; 84+ messages in thread
From: prad @ 2011-01-01 19:22 UTC (permalink / raw)
To: help-gnu-emacs
girosenth <girosenth@india.com> writes:
> How to improve the readability of (any) LISP or any highlevel
> functional language to the level of FORTH ?
>
having come to lisp from haskell which i thought was very elegant, i was
initially dismayed by the increased verbosity and those
parentheses. however, now haskell looks funny and lisp reads
beautifully, so part of it is no doubt a matter of usage.
i also found that working down rather than across helps a lot. so
instead of
(setq whatever (func1 (func2 x y) (func3 a b))
this sort of thing is often preferable
(setq whatever
(func1 (func2 x y)
(func3 a b)))
--
in friendship,
prad
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 14:15 ` Pascal J. Bourguignon
2011-01-01 16:08 ` Nathan
@ 2011-01-01 22:50 ` girosenth
2011-01-02 21:11 ` Thien-Thi Nguyen
` (2 more replies)
2011-01-02 23:45 ` Chip Eastham
2 siblings, 3 replies; 84+ messages in thread
From: girosenth @ 2011-01-01 22:50 UTC (permalink / raw)
To: help-gnu-emacs; +Cc: girosenth, girosenth
On Jan 1, 6:15 am, "Pascal J. Bourguignon" <p...@informatimago.com>
wrote:
> girosenth <girose...@india.com> writes:
> > How to improve the readability of (any) LISP or any highlevel
> > functional language to the level of FORTH ?
>
> > There are many people who have trivia complaints about parens in lisp,
> > but I dont.
>
> > LISP is a prefix notation.
>
> > sequence of operations would look like this on operands (ops) :
>
> > (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> > How do you make it readable ?
> > How do you home to the center or centers ?
>
> > (f (g (h (j (k (l ops)))...)))
>
> > is easy to read or
>
> > ops l k j h g f
>
> > ???
>
> I think we can call you a troll.
Factually, such a level of prejudice is not good for health, intellect
or discussion.
> Is it not obvious how you home to the center?http://www.informatimago.com/~pjb/bulleye.png
> Is it not a flagrant proof that lisp is the most easy to read?
There are things that I was hoping experienced programmers would fill
in that I forgot to state.
In a one liner which is an accurately represented by the subsets your
image displays, it is infact true that the center(s) are immediately
obvious. But if each of the f,g,h,...k,l are huge functions (in the
definitions) then they may occupy parts of a screen and the whole may
occupy several screens, or several tens of screens. Note also that I
have ops only before , but they can be everywhere. Function
(definition) enclosures have a 1-1 correspondence with trees as any
hierarchical objects and may look like a herringbone tree.
Sphagetti code which was promoted by a goto was brought under control
by "structured" programming which had only 3 forms (thus removing the
need for a flow chart) ie sequence, selection and iteration.
Functional language adds another useful form which is recursion and
(as a side comment) recursion is not representable by a flowchart.
The sequence, which is the simplest of the construct is essentially
imperative in nature. Sequence of state changes.
A purely functional program would have a single huge nested function.
One could say that a huge function can be broken into simpler
functions. Logic could always be chased LINE BY LINE by a determined
reader with unlimited time, but for most of us, programming efficiency
is an issue. However, to break a several screen or even a smaller set
of computation, I am faced with how to break it into parts due to
coupling in its parts. I was doing it inside let* to avoid setq
(fair ?) but I have a function that must return a number or a string
depending on if a regex was found and its index or a message that it
was not found.
(string-match REGEXP STRING &optional START)
inside a (cond) I return a string or the number
I am constrained to write like this because I wrote a quick and dirty
working and structurally (in the sense of structured) readable code
but WITHOUT taking care of failures or errors. Now I am trying to
modify it to take care of errors.
I must test it as soon as string match what type of regexp was not
found.
As I started modifying it, I lost track of its structure. I could
understand it at the write time but I know that after forgetting, at
the read time I will not understand it in the linear sense of the size
increase.
Even as I explained to a friend, I realized that I need to home in to
the center and reading was not linear as FORTH promises and any
postfix language with action words (functions) reads. The reading is
not linear.
I realized that you can read infix notation or standard function
notation f(x) of (f x) only because they are simpler functions, not
the recursive type functions of McCarthy. Those functions have if then
else logic embedded that is not apparent as you start reading it.
Our math functions are very simple, and most often single letters.
That is why algebraic notation is easy for them.
In comparison to prefix, postfix seems in the order of the action.
Certainly, it starts with the center object moved to the left most.
One gentleman has advocated ruby. The thread will be enriched by
perspectives from other functional languages. Suppose, I want to stick
to elisp and then move to CL (since almost everyone who has not taken
a course in lisp or scheme and who starts with linux comes to emacs
and elisp first) instead of ruby, then it appears to me that macros
which are being discussed without any examples in elisp or even CL
might be an answer to take care of sphagetti code or highly coupled
code. I was considering making a huge MIMO function that takes in many
bits and makes an output to be used by others. Atleast, the main
program would be readable. Such a function would have no analogy to
the real world object or operation and thus built on fictional lines
and unstable in construction and likely to be challenged by then next
exception that I would encounter in my build-fix method and thus beg
for recoding and re-reading again. Readability then is an issue.
I read your post somewhere with your example of flatten. I was
honestly not impressed with readability. All that you did was to
compress cond and also to use push/pop which would be indicated by a
text comment as clearly. Admitted that the code took smaller part of
the screen.
In modern IDE's there is a feature which allows code to be collapsed.
I am using older version of emacs I dont know if RMS and his team has
copied such features from eclipse and other IDEs into emacs and
debugged them or a bold adventurer would be on their mercy.
In the hygenic macro thread currently in progress, I want to ask them
to show me how macros can be written to prove their claims assuming
that I have good grasp of basics like quote, backquote, unquote and
splice.
I know some of these might sound unpleasant to commercial entities
with so much invested in it but for us, honest discussion and support
of claims by demonstration example is what really counts.
girosenth
> --
> __Pascal Bourguignon__ http://www.informatimago.com/
> A bad day in () is better than a good day in {}.- Hide quoted text -
>
> - Show quoted text -
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 16:08 ` Nathan
2011-01-01 18:05 ` Jan Burse
@ 2011-01-01 23:56 ` The Quiet Center
2011-01-02 1:10 ` Jan Burse
` (4 more replies)
2011-01-03 10:29 ` How to improve the readability of (any) LISP or any highlevel functional " Didier Verna
2 siblings, 5 replies; 84+ messages in thread
From: The Quiet Center @ 2011-01-01 23:56 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 11:08 am, Nathan <nbeen...@gmail.com> wrote:
> If you want a easy to read self-documenting functional language, look
> into Ruby. I know personally that Ruby syntax was a big turn off to me
> for several weeks (kind of like Lisp) but once you learn it, it
> becomes the easiest to read of any programming language I've ever
> experimented with. No contest.
>
Well, Python was chosen over Ruby for MIT's rework of their intro to
cs course because Python is multi-paradigm, whereas Ruby claims
everything is an object.
How would you code this simple list compression problem in Ruby:
1.08 (**) Eliminate consecutive duplicates of list elements.
If a list contains repeated elements they should be replaced with
a single copy of the element. The order of the elements should not be
changed.
Example:
?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
X = [a,b,c,a,d,e]
> Matz himself admitted that “...Ruby is a bad rip-off of Lisp... But it
> is nicer to ordinary people.”
yeah I guess the LOOP macro is where I got stuck in doing Lisp.
>
> Though every language I've worked in, I've never been half as
> productive as when I'm coding in Ruby.
I've done Perl at corporate level for 10 years and I've heard seasoned
Perl developers say the same thing.
>
> In particular, cross platform GUI application
> development seemed poor.
yeah, wxPython is the only thing for any scripting languages that
seemed to make very professional desktop UI programs.
>
> If you want to develop webpages, or bang out quick one time scripts,
> Ruby is hard to beat. For use at home, console applications are
> probably a tolerable price to pay for the incredible development speed
> and fantastic ease of maintenance Ruby will give your code.
yeah sinatra.rb looks nice for web dev and ruby on rails was a runaway
hit for awhile.
By the way, here's the Prolog solution to the compression problem I
posted earlier:
% http://sites.google.com/site/prologsite/prolog-problems/1
% Problem 1.08 - compress consecutive duplicates into a single
% list element
compress([], []).
compress([X,Y], [X,Y]) :- X \= Y.
compress([X,Y], [X]) :- X = Y.
% problems writing other clauses (thanks RLa)
compress([X,Y|Z], [X|Z1]) :- X \= Y, compress([Y|Z], Z1).
compress([X,Y|Z], Z1) :- X = Y, compress([Y|Z], Z1).
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (3 preceding siblings ...)
2011-01-01 19:22 ` How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? prad
@ 2011-01-01 23:56 ` Pascal Costanza
2011-01-02 5:39 ` D Herring
2011-01-03 18:07 ` jacko
2011-01-02 12:59 ` Doug Hoffman
` (4 subsequent siblings)
9 siblings, 2 replies; 84+ messages in thread
From: Pascal Costanza @ 2011-01-01 23:56 UTC (permalink / raw)
To: help-gnu-emacs
On 01/01/2011 08:04, girosenth wrote:
> How to improve the readability of (any) LISP or any highlevel
> functional language to the level of FORTH ?
I'm rather wondering how we can improve the readability of (any) English
to the level of German.
Pascal
--
My website: http://p-cos.net
Common Lisp Document Repository: http://cdr.eurolisp.org
Closer to MOP & ContextL: http://common-lisp.net/project/closer/
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` The Quiet Center
@ 2011-01-02 1:10 ` Jan Burse
2011-01-02 3:45 ` LanX
` (3 subsequent siblings)
4 siblings, 0 replies; 84+ messages in thread
From: Jan Burse @ 2011-01-02 1:10 UTC (permalink / raw)
To: help-gnu-emacs
The Quiet Center schrieb:
> %http://sites.google.com/site/prologsite/prolog-problems/1
>
> % Problem 1.08 - compress consecutive duplicates into a single
> % list element
>
> compress([], []).
> compress([X,Y], [X,Y]) :- X \= Y.
> compress([X,Y], [X]) :- X = Y.
>
> % problems writing other clauses (thanks RLa)
>
> compress([X,Y|Z], [X|Z1]) :- X \= Y, compress([Y|Z], Z1).
> compress([X,Y|Z], Z1) :- X = Y, compress([Y|Z], Z1).
>
The above code does not work fully correct. Here is a
counter example (try yourself):
?- compress([a],X).
No
In a Prolog introductory course I would anyway use:
% compress(+List,-List)
compress([X,X|L],R) :- !, compress([X|L],R).
compress([X|L],[X|R]) :- compress(L,R).
compress([],[]).
No reason to use (\=)/2, which is anyway not declarative,
and no reason to avoid the cut !/0.
Bye
P.S.: On sites.google.com I find the following solution,
correct, but also avoids the cut !/0:
% 1.08 (**): Eliminate consecutive duplicates of list elements.
% compress(L1,L2) :- the list L2 is obtained from the list L1 by
% compressing repeated occurrences of elements into a single copy
% of the element.
% (list,list) (+,?)
compress([],[]).
compress([X],[X]).
compress([X,X|Xs],Zs) :- compress([X|Xs],Zs).
compress([X,Y|Ys],[X|Zs]) :- X \= Y, compress([Y|Ys],Zs).
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` The Quiet Center
2011-01-02 1:10 ` Jan Burse
@ 2011-01-02 3:45 ` LanX
2011-01-02 4:04 ` LanX
2011-01-02 6:59 ` w_a_x_man
` (2 subsequent siblings)
4 siblings, 1 reply; 84+ messages in thread
From: LanX @ 2011-01-02 3:45 UTC (permalink / raw)
To: help-gnu-emacs
> On Jan 1, 11:08 am, Nathan <nbeen...@gmail.com> wrote:
> > Matz himself admitted that “...Ruby is a bad rip-off of Lisp... But it
> > is nicer to ordinary people.”
Matz himself admitted in the earliest sources that Ruby is basically
Perl's semantics melted with Smalltalk's OOP syntax. All influences
from LISP come via Perl and many things criticized in Perl derive from
Larry's dedication to stay close to LISP in contrast to Guido who
breaks a lot in Python, e.g limiting lambdas to single expressions.
For sure Perl's scoping rules are much closer to eLISP's.
So in order to emulate eLISP I would rather chose a Perl or JavaScript
1.7 (with the additional "let"-command) but with the need of extra
macro functionality.
The problem are rather the datatypes which are far more static in
eLISP,
i.e.
1. no autocasting eLisp
2. hashes and arrays have only fixed length in eLisp
3. OTOH linked linked lists are not a native type in most mainstream
languages.
> How would you code this simple list compression problem in Ruby:
>
> 1.08 (**) Eliminate consecutive duplicates of list elements.
> If a list contains repeated elements they should be replaced with
> a single copy of the element. The order of the elements should not be
> changed.
>
> Example:
> ?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
> X = [a,b,c,a,d,e]
>
in Perl:
DB<1> my $l; print grep { $l = $_ if $_ ne $l }
(a,a,a,a,b,c,c,a,a,d,e,e,e,e);
abcade
from 5.10 one can use feature "state" to avoid an extra scope to make
$l lexical.
or define an explicit compress function:
DB<2> sub compress { my $l; grep { $l = $_ if $_ ne $l } @_ }
DB<3> print compress(a,a,a,a,b,c,c,a,a,d,e,e,e,e);
abcade
(Nota bene, no explicit return needed like in LISP)
I suppose one can translate those approaches directly to Ruby, Python
or PHP. Newer JS versions call "grep" rather "filter" like in Python.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 3:45 ` LanX
@ 2011-01-02 4:04 ` LanX
2011-01-02 5:36 ` Nathan
0 siblings, 1 reply; 84+ messages in thread
From: LanX @ 2011-01-02 4:04 UTC (permalink / raw)
To: help-gnu-emacs
> in Perl:
> DB<1> my $l; print grep { $l = $_ if $_ ne $l } (a,a,a,a,b,c,c,a,a,d,e,e,e,e);
> abcade
The same more explicit and less buggy
grep { if ($_ ne $l) { $l = $_ ; 1 } } LIST
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 4:04 ` LanX
@ 2011-01-02 5:36 ` Nathan
2011-01-02 6:46 ` Paul Rubin
2011-01-02 7:14 ` w_a_x_man
0 siblings, 2 replies; 84+ messages in thread
From: Nathan @ 2011-01-02 5:36 UTC (permalink / raw)
To: help-gnu-emacs
Well, to answer the question simply, this code will provide the
functionality you've been asking about in Ruby.
my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
print my_list.reduce([]){|x, y|
if x.empty? or x[x.length-1] != y then
x + [y]
else
x
end
}
As is typical of functional languages, this returns a value rather
than modifying the list in place. I recommended Ruby because you were
asking about a functional programming language that still reads in an
sequential manner like imperative languages, which Ruby does.
Ruby is a purely object oriented language, however there is no need
for new developers to write code in an object oriented manner. Your
code will be put into objects whether you specify those objects or not
simply for the sake of providing metadata.
I am familiar with Python, I use it more than Ruby these days. I've
found function/method names and locations to be less consistent than
in Ruby. I've found that far too many routines modify data in place -
rather than return the result- to make it a serious functional
language. That being the case, it's very usable.
It is my belief that every language possesses some piece of the light.
None are prefect; every one needs to learn from every other one.
Whether it's Ruby, Python, Java, C#, Lisp, or Perl; there are always
developers in the community that believe their language is beyond
improvement. I pity them.
Generally I consider the issue of readability to be a question of how
closely a new syntax matches what one is accustomed to reading. Many
people prefer sequential program flow over nested simply because
English, and every other spoken language I'm aware of, is sequential
in nature.
Thus, something can be considered "simple" and "intuitive" only when
it builds off what a person already knows; and since that knowledge
base changes dramatically between individuals... Simple and intuitive
are also in the eye of the beholder. In the end, what's important is
that your solution work for you.
There are many languages because there are many types of people and
there are many ways of thinking and recording thought. I believe that
greatness in thought is not about "having the prefect way of doing
things" or "finding some ultimate", to me it's about having many ways
of doing something and recognizing when to use each one.
Just like any other tool, programming languages have their strengths
and weaknesses. If one wanted, one could probably build an entire
house using nothing but a hammer. I will prefer to use a hammer only
for the nails, but that's me.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` Pascal Costanza
@ 2011-01-02 5:39 ` D Herring
2011-01-02 14:17 ` Frank GOENNINGER
2011-01-02 17:55 ` Bernd Paysan
2011-01-03 18:07 ` jacko
1 sibling, 2 replies; 84+ messages in thread
From: D Herring @ 2011-01-02 5:39 UTC (permalink / raw)
To: help-gnu-emacs
On 01/01/2011 06:56 PM, Pascal Costanza wrote:
> On 01/01/2011 08:04, girosenth wrote:
>> How to improve the readability of (any) LISP or any highlevel
>> functional language to the level of FORTH ?
>
> I'm rather wondering how we can improve the readability of (any)
> English to the level of German.
The classic response:
http://www.users.globalnet.co.uk/~choh/german.htm
I haven't a clue where this originated.
- Daniel
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 5:36 ` Nathan
@ 2011-01-02 6:46 ` Paul Rubin
2011-01-02 15:01 ` LanX
2011-01-02 7:14 ` w_a_x_man
1 sibling, 1 reply; 84+ messages in thread
From: Paul Rubin @ 2011-01-02 6:46 UTC (permalink / raw)
To: help-gnu-emacs
Nathan <nbeenken@gmail.com> writes:
> functionality you've been asking about in Ruby.
>
> my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
> print my_list.reduce([]){|x, y|
> if x.empty? or x[x.length-1] != y then
> x + [y]
> else
> x
> end
> }
That is pretty ugly; in Haskell you could write
my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
main = print [head xs | xs <- group my_list]
That uses a Python-like list comprehension since you mentioned Python,
but more idiomatic would be
my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
main = print . map head . group $ my_list
There is probably a function like "group" available in Ruby. Python has
itertools.groupby but it's a little bit brittle.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` The Quiet Center
2011-01-02 1:10 ` Jan Burse
2011-01-02 3:45 ` LanX
@ 2011-01-02 6:59 ` w_a_x_man
2011-01-03 15:22 ` LanX
2011-01-02 14:07 ` Frank GOENNINGER
2011-01-07 9:41 ` w_a_x_man
4 siblings, 1 reply; 84+ messages in thread
From: w_a_x_man @ 2011-01-02 6:59 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 5:56 pm, The Quiet Center <thequietcen...@gmail.com> wrote:
> On Jan 1, 11:08 am, Nathan <nbeen...@gmail.com> wrote:
>
> > If you want a easy to read self-documenting functional language, look
> > into Ruby. I know personally that Ruby syntax was a big turn off to me
> > for several weeks (kind of like Lisp) but once you learn it, it
> > becomes the easiest to read of any programming language I've ever
> > experimented with. No contest.
>
> Well, Python was chosen over Ruby for MIT's rework of their intro to
> cs course because Python is multi-paradigm, whereas Ruby claims
> everything is an object.
>
> How would you code this simple list compression problem in Ruby:
>
> 1.08 (**) Eliminate consecutive duplicates of list elements.
> If a list contains repeated elements they should be replaced with
> a single copy of the element. The order of the elements should not be
> changed.
>
> Example:
> ?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
> X = [a,b,c,a,d,e]
>
"aaaabccaadeeee".squeeze
==>"abcade"
p=nil; %w(a a a b c c a a d e e e).select{|x| x!=p && p=x}
==>["a", "b", "c", "a", "d", "e"]
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 5:36 ` Nathan
2011-01-02 6:46 ` Paul Rubin
@ 2011-01-02 7:14 ` w_a_x_man
1 sibling, 0 replies; 84+ messages in thread
From: w_a_x_man @ 2011-01-02 7:14 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 11:36 pm, Nathan <nbeen...@gmail.com> wrote:
> Well, to answer the question simply, this code will provide the
> functionality you've been asking about in Ruby.
>
> my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
> print my_list.reduce([]){|x, y|
> if x.empty? or x[x.length-1] != y then
Instead of x[x.size-1], use x[-1] or x.last.
> x + [y]
> else
> x
> end
>
> }
Another way using reduce:
%w(a a a b c c a a d e e e).reduce([]){|a,x| a[-1]==x ? a : a<<x}
==>["a", "b", "c", "a", "d", "e"]
This assumes nils aren't allowed in the source array.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (4 preceding siblings ...)
2011-01-01 23:56 ` Pascal Costanza
@ 2011-01-02 12:59 ` Doug Hoffman
2011-01-02 19:14 ` w_a_x_man
2011-01-03 10:18 ` Didier Verna
` (3 subsequent siblings)
9 siblings, 1 reply; 84+ messages in thread
From: Doug Hoffman @ 2011-01-02 12:59 UTC (permalink / raw)
To: help-gnu-emacs
On 1/1/11 2:04 AM, girosenth wrote:
> How to improve the readability of (any) LISP or any highlevel
> functional language to the level of FORTH ?
>
> There are many people who have trivia complaints about parens in lisp,
> but I dont.
>
> LISP is a prefix notation.
>
> sequence of operations would look like this on operands (ops) :
>
> (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> How do you make it readable ?
> How do you home to the center or centers ?
>
> (f (g (h (j (k (l ops)))...)))
>
> is easy to read or
>
> ops l k j h g f
[snip]
> Is there a postfix functional language that also gets rid of parens
> and is not as primitive as FORTH or POSTSCRIPT ?
Forth remains only as primitive as you want it to be.
Consider the list compression example later in this thread:
Example:
?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
X = [a,b,c,a,d,e]
To solve this using Forth I took an existing dynamic string library
class and added one method as follows:
\ Create a subclass of string with a compress method
:class string++ <super string+
\ compress: will return a new string object
:m compress: ( -- newStr )
self heap: ( newStr) 0 self at: { newStr lastChar }
0 0 newStr new:
lastChar newStr +:
self size: 1
?DO i self at: dup lastChar <>
IF dup newStr +: THEN
to lastChar
LOOP newStr ;m
;class
string++ s \ declare a string object named s
\ 1st copy&paste the input list from the Example
\ and place it into s
s" a,a,a,a,b,c,c,a,a,d,e,e,e,e" s new:
\ 2nd, remove all commas
s" ," 0 0 s replall:
\ 3rd, do the compression and save the output object in x
s compress: value x
\ We are done:
x p:
abcade \ Q.E.D
\ Or, if one insists on pretty printing
: e ( idx -- ) x at: emit ;
: print ( obj -- )
[char] [ emit 0 e
size: 1 DO [char] , emit i e LOOP
[char] ] emit ;
x print
[a,b,c,a,d,e] \ Q.E.D
\ return heap memory
s free:
x free:
If I find the compress method to be repeatedly useful in various
problems I would keep it as part of my class library. I may code a
compress method that is more general and perhaps also for ordered
collections. I am confident that there are (many) other solutions to
the above using more "primitive" Forth techniques.
We also have some extensive postfix arithmetic routines that prove
useful when translating, for example, Fortran equations. But I won't
get into that here.
-Doug
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` The Quiet Center
` (2 preceding siblings ...)
2011-01-02 6:59 ` w_a_x_man
@ 2011-01-02 14:07 ` Frank GOENNINGER
2011-01-07 9:41 ` w_a_x_man
4 siblings, 0 replies; 84+ messages in thread
From: Frank GOENNINGER @ 2011-01-02 14:07 UTC (permalink / raw)
To: help-gnu-emacs
The Quiet Center <thequietcenter@gmail.com> writes:
> On Jan 1, 11:08 am, Nathan <nbeen...@gmail.com> wrote:
>> If you want a easy to read self-documenting functional language, look
>> into Ruby. I know personally that Ruby syntax was a big turn off to me
>> for several weeks (kind of like Lisp) but once you learn it, it
>> becomes the easiest to read of any programming language I've ever
>> experimented with. No contest.
>>
>
> Well, Python was chosen over Ruby for MIT's rework of their intro to
> cs course because Python is multi-paradigm, whereas Ruby claims
> everything is an object.
>
> How would you code this simple list compression problem in Ruby:
>
> 1.08 (**) Eliminate consecutive duplicates of list elements.
> If a list contains repeated elements they should be replaced with
> a single copy of the element. The order of the elements should not be
> changed.
>
> Example:
> ?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
> X = [a,b,c,a,d,e]
>
>> Matz himself admitted that “...Ruby is a bad rip-off of Lisp... But it
>> is nicer to ordinary people.”
>
> yeah I guess the LOOP macro is where I got stuck in doing Lisp.
Simple:
? (defun compress (list)
(let ((last-element)
(result))
(loop for element in list
when (not (equal last-element element))
do
(progn
(setq last-element element)
(push element result)))
(reverse result)))
COMPRESS
? (setq list (list 'a 'a 'a 'a 'b 'c 'c 'a 'a 'd 'e 'e 'e 'e))
(A A A A B C C A A D E E E E)
? (compress list)
(A B C A D E)
'compress can be done in much more terse way in Lisp but this is just an
example using the Loop macro.
Frank
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 5:39 ` D Herring
@ 2011-01-02 14:17 ` Frank GOENNINGER
2011-01-02 14:53 ` Jerome Baum
2011-01-02 17:55 ` Bernd Paysan
1 sibling, 1 reply; 84+ messages in thread
From: Frank GOENNINGER @ 2011-01-02 14:17 UTC (permalink / raw)
To: help-gnu-emacs
D Herring <dherring@at.tentpost.dot.com> writes:
> On 01/01/2011 06:56 PM, Pascal Costanza wrote:
>> On 01/01/2011 08:04, girosenth wrote:
>>> How to improve the readability of (any) LISP or any highlevel
>>> functional language to the level of FORTH ?
>>
>> I'm rather wondering how we can improve the readability of (any)
>> English to the level of German.
>
> The classic response:
> http://www.users.globalnet.co.uk/~choh/german.htm
>
> I haven't a clue where this originated.
Must be the proposal of Mr Oettinger, the German politican now being EU
Commisioner for Energy. Hearing him speaking English very closely
assemble the "Modern English" as outlined on that page ...
http://www.youtube.com/watch?v=icOO7Ut1P4Y
No, I'm not proud of that ...
Frank
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 14:17 ` Frank GOENNINGER
@ 2011-01-02 14:53 ` Jerome Baum
2011-01-02 14:58 ` LanX
0 siblings, 1 reply; 84+ messages in thread
From: Jerome Baum @ 2011-01-02 14:53 UTC (permalink / raw)
To: help-gnu-emacs
In article <m2pqsf9yqg.fsf@ccde007.de.goenninger.net>,
dg1sbg@googlemail.com says...
> Must be the proposal of Mr Oettinger, the German politican now being
EU
> Commisioner for Energy. Hearing him speaking English very closely
> assemble the "Modern English" as outlined on that page ...
>
> http://www.youtube.com/watch?v=icOO7Ut1P4Y
>
> No, I'm not proud of that ...
>
> Frank
You just have to love the comment:
"I understand only train station"
(To put it into context, that's the text on an ad run by some English
training business over here in Germany.)
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 14:53 ` Jerome Baum
@ 2011-01-02 14:58 ` LanX
0 siblings, 0 replies; 84+ messages in thread
From: LanX @ 2011-01-02 14:58 UTC (permalink / raw)
To: help-gnu-emacs
> > No, I'm not proud of that ...
>
> > Frank
>
> You just have to love the comment:
>
> "I understand only train station"
come on guys, he speaks better English than more than 90% of all Anglo-
Saxon politicians speak any other foreign language...
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 6:46 ` Paul Rubin
@ 2011-01-02 15:01 ` LanX
2011-01-02 15:14 ` Jerome Baum
2011-01-02 21:21 ` Paul Rubin
0 siblings, 2 replies; 84+ messages in thread
From: LanX @ 2011-01-02 15:01 UTC (permalink / raw)
To: help-gnu-emacs
Paul Rubin schrieb:
> That is pretty ugly; in Haskell you could write
>
> my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
> main = print [head xs | xs <- group my_list]
does this really produce the desired output?
Will the second 1 really be printed?
And why do you guys switch to operate on digits instead of strings?
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 15:01 ` LanX
@ 2011-01-02 15:14 ` Jerome Baum
2011-01-02 21:21 ` Paul Rubin
1 sibling, 0 replies; 84+ messages in thread
From: Jerome Baum @ 2011-01-02 15:14 UTC (permalink / raw)
To: help-gnu-emacs
In article <ce0f5c3b-bc71-4868-8d2b-5495583ccfa8
@w18g2000vbe.googlegroups.com>, lanx.perl@googlemail.com says...
>
> Paul Rubin schrieb:
>
> > That is pretty ugly; in Haskell you could write
> >
> > my_list = [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
> > main = print [head xs | xs <- group my_list]
>
> does this really produce the desired output?
> Will the second 1 really be printed?
>
> And why do you guys switch to operate on digits instead of strings?
http://codepad.org/eGFuJrHZ
import List
my_list = ["one", "one", "one", "one", "two", "three", "three", "one",
"one", "four", "five", "five", "five", "five"]
main = print [head xs | xs <- group my_list]
Output:
["one","two","three","one","four","five"]
Works fine for me...
^ permalink raw reply [flat|nested] 84+ messages in thread
* RE: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
@ 2011-01-02 16:50 Drew Adams
0 siblings, 0 replies; 84+ messages in thread
From: Drew Adams @ 2011-01-02 16:50 UTC (permalink / raw)
To: help-gnu-emacs
> yeah I guess the LOOP macro is where I got stuck in doing Lisp.
The `loop' macro is scarcely Lisp ;-). Its syntax is certainly is not very
representative of Lisp's syntax, which is apparently the bugaboo of this thread.
`loop' is to Lisp as `find' is to a UNIX/GNU/Linux shell. `loop' and `find' are
each practically a language unto itself. Each can be useful ... and daunting to
the uninitiated.
If you learn the language of `loop' you might (or might not) like it, but not
liking the language of `loop' has little relation to not liking the language of
Lisp. ;-)
Some might appreciate this:
http://common-lisp.net/project/iterate/doc/index.html#Top
or the short version:
http://common-lisp.net/project/iterate/doc/Don_0027t-Loop-Iterate.html#Don_0027t
-Loop-Iterate
No flames from the Loopite Liberation Legion, if you please. ;-)
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 5:39 ` D Herring
2011-01-02 14:17 ` Frank GOENNINGER
@ 2011-01-02 17:55 ` Bernd Paysan
1 sibling, 0 replies; 84+ messages in thread
From: Bernd Paysan @ 2011-01-02 17:55 UTC (permalink / raw)
To: help-gnu-emacs
D Herring wrote:
> On 01/01/2011 06:56 PM, Pascal Costanza wrote:
>> On 01/01/2011 08:04, girosenth wrote:
>>> How to improve the readability of (any) LISP or any highlevel
>>> functional language to the level of FORTH ?
>>
>> I'm rather wondering how we can improve the readability of (any)
>> English to the level of German.
>
> The classic response:
> http://www.users.globalnet.co.uk/~choh/german.htm
>
> I haven't a clue where this originated.
The version I know stated at the end that the Germans zot zis vas a
viktory, and zey achived zeir original goal.
--
Bernd Paysan
"If you want it done right, you have to do it yourself"
http://www.jwdt.com/~paysan/
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 12:59 ` Doug Hoffman
@ 2011-01-02 19:14 ` w_a_x_man
2011-01-03 5:20 ` Elizabeth D Rather
` (3 more replies)
0 siblings, 4 replies; 84+ messages in thread
From: w_a_x_man @ 2011-01-02 19:14 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 2, 6:59 am, Doug Hoffman <glide...@gmail.com> wrote:
> On 1/1/11 2:04 AM, girosenth wrote:
>
> > How to improve the readability of (any) LISP or any highlevel
> > functional language to the level of FORTH ?
>
> > There are many people who have trivia complaints about parens in lisp,
> > but I dont.
>
> > LISP is a prefix notation.
>
> > sequence of operations would look like this on operands (ops) :
>
> > (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> > How do you make it readable ?
> > How do you home to the center or centers ?
>
> > (f (g (h (j (k (l ops)))...)))
>
> > is easy to read or
>
> > ops l k j h g f
>
> [snip]
>
> > Is there a postfix functional language that also gets rid of parens
> > and is not as primitive as FORTH or POSTSCRIPT ?
>
> Forth remains only as primitive as you want it to be.
>
That is equally true of assembly language.
Forth is a low-level language used primarily for programming embedded
applications such as controlling the flushing of a toilet.
"Forth, the toilet-flusher!"
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 22:50 ` girosenth
@ 2011-01-02 21:11 ` Thien-Thi Nguyen
2011-01-03 16:21 ` José A. Romero L.
2011-01-03 18:03 ` jacko
2 siblings, 0 replies; 84+ messages in thread
From: Thien-Thi Nguyen @ 2011-01-02 21:11 UTC (permalink / raw)
To: help-gnu-emacs, girosenth
() girosenth <girosenth@india.com>
() Sat, 1 Jan 2011 14:50:52 -0800 (PST)
In comparison to prefix, postfix seems in the order of the action.
Certainly, it starts with the center object moved to the left most.
In another response, someone suggested reading/writing down.
Introducing another dimension is a good start. It's only a
start, however, because it is visible to the programmer and
not to the computer; inserting error-checking or state-stashing
into the mix, while travelling "in to out" (now "down to up")
is still problematical. Imagine an art gallery constructed
only of staircases -- easy to trip, hard to enjoy the paintings
on the walls. (But very straightforward for Hurrying Up.)
So the way forward is to add landings:
you climb, you gawk, you climb some more.
In Emacs Lisp, the landings are made using ‘flet’.
In Scheme, the landings are made from internal procedures.
Build your programs with enough landings and you may find
yourself keeping company with fewer firefighters and more
art snobs. That's the risk you take being an architect.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 15:01 ` LanX
2011-01-02 15:14 ` Jerome Baum
@ 2011-01-02 21:21 ` Paul Rubin
1 sibling, 0 replies; 84+ messages in thread
From: Paul Rubin @ 2011-01-02 21:21 UTC (permalink / raw)
To: help-gnu-emacs
LanX <lanx.perl@googlemail.com> writes:
>> main = print [head xs | xs <- group my_list]
>
> does this really produce the desired output?
> Will the second 1 really be printed?
Yes. "group" is a very useful function, that transforms a list into a
list-of-lists which collapses identical elements:
group [1, 1, 1, 1, 2, 3, 3, 1, 1, 4, 5, 5, 5, 5]
is
[[1,1,1,1], [2], [3,3], [1,1], [4], [5,5,5,5]]
The list comprehension
[head xs | xs <- group my_list]
simply collects the first element of each of those sub-lists.
There is also groupBy, which lets you supply your own equality
predicate. If there's not already a Lisp library similar to Python's
itertools module and Haskell's List module, it's probably worth writing
one.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 14:15 ` Pascal J. Bourguignon
2011-01-01 16:08 ` Nathan
2011-01-01 22:50 ` girosenth
@ 2011-01-02 23:45 ` Chip Eastham
2 siblings, 0 replies; 84+ messages in thread
From: Chip Eastham @ 2011-01-02 23:45 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 9:15 am, "Pascal J. Bourguignon" <p...@informatimago.com>
wrote:
[snip]
> A bad day in () is better than a good day in {}.
Ah, at last the meaning of your .sig dawns on me!
regards, chip
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 19:14 ` w_a_x_man
@ 2011-01-03 5:20 ` Elizabeth D Rather
2011-01-03 10:48 ` MarkWills
` (2 subsequent siblings)
3 siblings, 0 replies; 84+ messages in thread
From: Elizabeth D Rather @ 2011-01-03 5:20 UTC (permalink / raw)
To: help-gnu-emacs
On 1/2/11 9:14 AM, w_a_x_man wrote:
> On Jan 2, 6:59 am, Doug Hoffman<glide...@gmail.com> wrote:
...
>> Forth remains only as primitive as you want it to be.
>>
>
> That is equally true of assembly language.
>
> Forth is a low-level language used primarily for programming embedded
> applications such as controlling the flushing of a toilet.
>
> "Forth, the toilet-flusher!"
I actually know of no toilet-control applications of Forth. But I do
know some applications controlling satellite tracking antennas,
large-scale electric power-distribution systems, satellite
instrumentation, scientific instruments, and quite a few other pretty
non-trivial applications.
Cheers,
Elizabeth
--
==================================================
Elizabeth D. Rather (US & Canada) 800-55-FORTH
FORTH Inc. +1 310.999.6784
5959 West Century Blvd. Suite 700
Los Angeles, CA 90045
http://www.forth.com
"Forth-based products and Services for real-time
applications since 1973."
==================================================
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (5 preceding siblings ...)
2011-01-02 12:59 ` Doug Hoffman
@ 2011-01-03 10:18 ` Didier Verna
2011-01-04 6:47 ` pineapple
` (2 subsequent siblings)
9 siblings, 0 replies; 84+ messages in thread
From: Didier Verna @ 2011-01-03 10:18 UTC (permalink / raw)
To: help-gnu-emacs
girosenth <girosenth@india.com> wrote:
> AND, if I must break the nested function structure, will I not be
> visiting the forbidden territory of imperative programming ?
Why do you think imperative programming is forbidden in Lisp ?
--
Resistance is futile. You will be jazzimilated.
Scientific site: http://www.lrde.epita.fr/~didier
Music (Jazz) site: http://www.didierverna.com
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 16:08 ` Nathan
2011-01-01 18:05 ` Jan Burse
2011-01-01 23:56 ` The Quiet Center
@ 2011-01-03 10:29 ` Didier Verna
2011-01-03 13:05 ` Tim Harig
2 siblings, 1 reply; 84+ messages in thread
From: Didier Verna @ 2011-01-03 10:29 UTC (permalink / raw)
To: help-gnu-emacs
Nathan <nbeenken@gmail.com> wrote:
> Matz himself admitted that “...Ruby is a bad rip-off of Lisp... But it
> is nicer to ordinary people.”
Which of course is a very sorry thing to say. Ruby is not nicer to
ordinary people. It's nicer to people having already been brainwashed by
languages full of syntax noise. At most, he could have said "to the
majority of people".
There is litterature and evidence out there that Lisp is just good
enough for ordinary people as well, when it's their first programming
experience.
This misconception that you must be exceptionally clever to learn and
use Lisp really hurts the language and the community.
--
Resistance is futile. You will be jazzimilated.
Scientific site: http://www.lrde.epita.fr/~didier
Music (Jazz) site: http://www.didierverna.com
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 19:14 ` w_a_x_man
2011-01-03 5:20 ` Elizabeth D Rather
@ 2011-01-03 10:48 ` MarkWills
2011-01-03 15:13 ` LanX
2011-01-03 18:20 ` jacko
2011-01-03 18:22 ` jacko
3 siblings, 1 reply; 84+ messages in thread
From: MarkWills @ 2011-01-03 10:48 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 2, 7:14 pm, w_a_x_man <w_a_x_...@yahoo.com> wrote:
> On Jan 2, 6:59 am, Doug Hoffman <glide...@gmail.com> wrote:
>
>
>
> > On 1/1/11 2:04 AM, girosenth wrote:
>
> > > How to improve the readability of (any) LISP or any highlevel
> > > functional language to the level of FORTH ?
>
> > > There are many people who have trivia complaints about parens in lisp,
> > > but I dont.
>
> > > LISP is a prefix notation.
>
> > > sequence of operations would look like this on operands (ops) :
>
> > > (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> > > How do you make it readable ?
> > > How do you home to the center or centers ?
>
> > > (f (g (h (j (k (l ops)))...)))
>
> > > is easy to read or
>
> > > ops l k j h g f
>
> > [snip]
>
> > > Is there a postfix functional language that also gets rid of parens
> > > and is not as primitive as FORTH or POSTSCRIPT ?
>
> > Forth remains only as primitive as you want it to be.
>
> That is equally true of assembly language.
>
> Forth is a low-level language used primarily for programming embedded
> applications such as controlling the flushing of a toilet.
>
> "Forth, the toilet-flusher!"
Er, no.
Forth has been/is used for:
* Controlling radio telescopes
* Performing the data acquisition on radio telescopes
* Cargo bay loading system on space shuttle
* Controlling CNC machines in metal finishing
* Controlling DC rectifiers in metal finishing
* Dosing controllers in metal finishing
* Anodising controllers in metal finishing
* Distributed control system in factories
* Airport management
* Rain gauge data acquisition in environmental applications
* Flow meter monitoring (data acquisition) and reporting in water/
sewage applications
* Subsea data acquisition and control (in progress)
* Real-time telemetry in Formula 1 cars (still ongoing)
* Initialising PC mother boards all over the world
* OLPC laptop
Note that, contrary to your bizarre assertion, I personally know of no
instance where a Forth system has been used to flush a toilet. It
would be a bit over the top, since a 555 timer and a relay would do
the job quite nicely, as we used to do in the 80's with that exact
application, and similarly with industrial washer detergent dosing
systems.
I know you're a troll and I shouldn't 'feed you' but Forth is still
used, and is still a valuable programming language.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-03 10:29 ` How to improve the readability of (any) LISP or any highlevel functional " Didier Verna
@ 2011-01-03 13:05 ` Tim Harig
2011-01-04 4:49 ` rusi
2011-01-04 10:18 ` Didier Verna
0 siblings, 2 replies; 84+ messages in thread
From: Tim Harig @ 2011-01-03 13:05 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-03, Didier Verna <didier@lrde.epita.fr> wrote:
> Nathan <nbeenken@gmail.com> wrote:
>
>> Matz himself admitted that ???...Ruby is a bad rip-off of Lisp... But it
>> is nicer to ordinary people.???
>
> This misconception that you must be exceptionally clever to learn and
> use Lisp really hurts the language and the community.
What hurts the LISP community far more is the zealotry of its members,
their insistance that LISP is the *only* tool for *every* job, and their
agressiveness in trying to push it off on to everybody else -- whether
everybody else happens want it or not. Whether this is indicitive
of the entire community or simply the result of those most apparent,
I cannot say; but, it leads to the overall impression that the LISP
community is narrowminded and neophobic. Who would want to be part of
such a community?
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-03 10:48 ` MarkWills
@ 2011-01-03 15:13 ` LanX
0 siblings, 0 replies; 84+ messages in thread
From: LanX @ 2011-01-03 15:13 UTC (permalink / raw)
To: help-gnu-emacs
On 3 Jan., 11:48, MarkWills <markrobertwi...@yahoo.co.uk> wrote:
> On Jan 2, 7:14 pm, w_a_x_man <w_a_x_...@yahoo.com> wrote:
> > "Forth, the toilet-flusher!"
> I know you're a troll and I shouldn't 'feed you' but Forth is still
> used, and is still a valuable programming language.
indeed!
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 6:59 ` w_a_x_man
@ 2011-01-03 15:22 ` LanX
0 siblings, 0 replies; 84+ messages in thread
From: LanX @ 2011-01-03 15:22 UTC (permalink / raw)
To: help-gnu-emacs
On 2 Jan., 07:59, w_a_x_man <w_a_x_...@yahoo.com> wrote:
> p=nil; %w(a a a b c c a a d e e e).select{|x| x!=p && p=x}
> ==>["a", "b", "c", "a", "d", "e"]
and by translating my perl code you also inherited it's restrictions
p=nil; ["a","a","b",false,false,"e"].select{|x| x!=p && p=x}
=> ["a", "b", "e"]
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 22:50 ` girosenth
2011-01-02 21:11 ` Thien-Thi Nguyen
@ 2011-01-03 16:21 ` José A. Romero L.
2011-01-03 18:03 ` jacko
2 siblings, 0 replies; 84+ messages in thread
From: José A. Romero L. @ 2011-01-03 16:21 UTC (permalink / raw)
To: help-gnu-emacs
On 1 Jan, 23:50, girosenth <girose...@india.com> wrote:
(...)
> of computation, I am faced with how to break it into parts due to
> coupling in its parts. I was doing it inside let* to avoid setq
> (fair ?) but I have a function that must return a number or a string
(...)
Can't you simply use setq inside let?:
(setq blah 1)
(let ((blah))
(setq blah 2) ;; <-- This is not blah! ;)
(message "blah is %s" blah))
Cheers,
--
José A. Romero L.
escherdragon at gmail
"We who cut mere stones must always be envisioning cathedrals."
(Quarry worker's creed)
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 22:50 ` girosenth
2011-01-02 21:11 ` Thien-Thi Nguyen
2011-01-03 16:21 ` José A. Romero L.
@ 2011-01-03 18:03 ` jacko
2 siblings, 0 replies; 84+ messages in thread
From: jacko @ 2011-01-03 18:03 UTC (permalink / raw)
To: help-gnu-emacs
Not sure about present languages, I like Tcl for fast script hacks.
I'm developing a language called pHone which is just starting to be
formalized.
Try
http://sites.google.com/site/jackokring/phone-language/looking-in-2011
For a look at the core definition, before symbol processing and
numerics have been added.
Cheers Jacko
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` Pascal Costanza
2011-01-02 5:39 ` D Herring
@ 2011-01-03 18:07 ` jacko
1 sibling, 0 replies; 84+ messages in thread
From: jacko @ 2011-01-03 18:07 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 11:56 pm, Pascal Costanza <p...@p-cos.net> wrote:
> On 01/01/2011 08:04, girosenth wrote:
>
> > How to improve the readability of (any) LISP or any highlevel
> > functional language to the level of FORTH ?
>
> I'm rather wondering how we can improve the readability of (any) English
> to the level of German.
>
> Pascal
>
> --
> My website:http://p-cos.net
> Common Lisp Document Repository:http://cdr.eurolisp.org
> Closer to MOP & ContextL:http://common-lisp.net/project/closer/
That's a worthy endeavour, but how would you translate chauser?
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 19:14 ` w_a_x_man
2011-01-03 5:20 ` Elizabeth D Rather
2011-01-03 10:48 ` MarkWills
@ 2011-01-03 18:20 ` jacko
2011-01-03 18:22 ` jacko
3 siblings, 0 replies; 84+ messages in thread
From: jacko @ 2011-01-03 18:20 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 2, 7:14 pm, w_a_x_man <w_a_x_...@yahoo.com> wrote:
> On Jan 2, 6:59 am, Doug Hoffman <glide...@gmail.com> wrote:
>
>
>
>
>
>
>
>
>
> > On 1/1/11 2:04 AM, girosenth wrote:
>
> > > How to improve the readability of (any) LISP or any highlevel
> > > functional language to the level of FORTH ?
>
> > > There are many people who have trivia complaints about parens in lisp,
> > > but I dont.
>
> > > LISP is a prefix notation.
>
> > > sequence of operations would look like this on operands (ops) :
>
> > > (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> > > How do you make it readable ?
> > > How do you home to the center or centers ?
>
> > > (f (g (h (j (k (l ops)))...)))
>
> > > is easy to read or
>
> > > ops l k j h g f
>
> > [snip]
>
> > > Is there a postfix functional language that also gets rid of parens
> > > and is not as primitive as FORTH or POSTSCRIPT ?
>
> > Forth remains only as primitive as you want it to be.
>
> That is equally true of assembly language.
>
> Forth is a low-level language used primarily for programming embedded
> applications such as controlling the flushing of a toilet.
>
> "Forth, the toilet-flusher!"
C the toilet contents...
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-02 19:14 ` w_a_x_man
` (2 preceding siblings ...)
2011-01-03 18:20 ` jacko
@ 2011-01-03 18:22 ` jacko
3 siblings, 0 replies; 84+ messages in thread
From: jacko @ 2011-01-03 18:22 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 2, 7:14 pm, w_a_x_man <w_a_x_...@yahoo.com> wrote:
> On Jan 2, 6:59 am, Doug Hoffman <glide...@gmail.com> wrote:
>
>
>
>
>
>
>
>
>
> > On 1/1/11 2:04 AM, girosenth wrote:
>
> > > How to improve the readability of (any) LISP or any highlevel
> > > functional language to the level of FORTH ?
>
> > > There are many people who have trivia complaints about parens in lisp,
> > > but I dont.
>
> > > LISP is a prefix notation.
>
> > > sequence of operations would look like this on operands (ops) :
>
> > > (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> > > How do you make it readable ?
> > > How do you home to the center or centers ?
>
> > > (f (g (h (j (k (l ops)))...)))
>
> > > is easy to read or
>
> > > ops l k j h g f
>
> > [snip]
>
> > > Is there a postfix functional language that also gets rid of parens
> > > and is not as primitive as FORTH or POSTSCRIPT ?
>
> > Forth remains only as primitive as you want it to be.
>
> That is equally true of assembly language.
>
> Forth is a low-level language used primarily for programming embedded
> applications such as controlling the flushing of a toilet.
>
> "Forth, the toilet-flusher!"
C the toilet contents...
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-03 13:05 ` Tim Harig
@ 2011-01-04 4:49 ` rusi
2011-01-04 5:39 ` D Herring
2011-01-04 6:24 ` Pascal J. Bourguignon
2011-01-04 10:18 ` Didier Verna
1 sibling, 2 replies; 84+ messages in thread
From: rusi @ 2011-01-04 4:49 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 3, 6:05 pm, Tim Harig <user...@ilthio.net> wrote:
> On 2011-01-03, Didier Verna <did...@lrde.epita.fr> wrote:
>
> > Nathan <nbeen...@gmail.com> wrote:
>
> >> Matz himself admitted that ???...Ruby is a bad rip-off of Lisp... But it
> >> is nicer to ordinary people.???
>
> > This misconception that you must be exceptionally clever to learn and
> > use Lisp really hurts the language and the community.
>
> What hurts the LISP community far more is the zealotry of its members,
> their insistance that LISP is the *only* tool for *every* job, and their
> agressiveness in trying to push it off on to everybody else -- whether
> everybody else happens want it or not. Whether this is indicitive
> of the entire community or simply the result of those most apparent,
> I cannot say; but, it leads to the overall impression that the LISP
> community is narrowminded and neophobic. Who would want to be part of
> such a community?
There are more mundane reasons -- like unsuitability of lisp as a
distribution platform
[See http://www.newartisans.com/about-me.html where John Wiegley
explains why he switched from lisp to C++ for his program ledger ]
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 4:49 ` rusi
@ 2011-01-04 5:39 ` D Herring
2011-01-04 8:02 ` Tim Harig
2011-01-04 6:24 ` Pascal J. Bourguignon
1 sibling, 1 reply; 84+ messages in thread
From: D Herring @ 2011-01-04 5:39 UTC (permalink / raw)
To: help-gnu-emacs
On 01/03/2011 11:49 PM, rusi wrote:
> On Jan 3, 6:05 pm, Tim Harig<user...@ilthio.net> wrote:
>> What hurts the LISP community far more is the zealotry of its members,
>> their insistance that LISP is the *only* tool for *every* job, and their
>> agressiveness in trying to push it off on to everybody else -- whether
>> everybody else happens want it or not. Whether this is indicitive
>> of the entire community or simply the result of those most apparent,
>> I cannot say; but, it leads to the overall impression that the LISP
>> community is narrowminded and neophobic. Who would want to be part of
>> such a community?
Like the dark days of apple, bsd, and linux, there can be some bizarre
fanboyism in the lisp community. Geeks are always technical but often
not personable.
> There are more mundane reasons -- like unsuitability of lisp as a
> distribution platform
> [See http://www.newartisans.com/about-me.html where John Wiegley
> explains why he switched from lisp to C++ for his program ledger ]
First he says "It was originally written in C++, but lately I’ve been
porting it to Common Lisp, since I’ve realized how much simpler – and
more powerful – many of its aspects will become."
Then there's a cryptic "I found Common Lisp unsuitable as a
distribution platform."
Trying not to sound fanboyish, but there are numerous ways to
distribute lisp apps. There have been a couple notable improvements
in the last year; but several implementations have always offered to
spit out an ordinary, standalone executable.
I think many readers in the other cross posted newsgroups have seen
similar come-and-go users leave their favorite language.
- Daniel
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 4:49 ` rusi
2011-01-04 5:39 ` D Herring
@ 2011-01-04 6:24 ` Pascal J. Bourguignon
2011-01-04 15:43 ` Raffael Cavallaro
1 sibling, 1 reply; 84+ messages in thread
From: Pascal J. Bourguignon @ 2011-01-04 6:24 UTC (permalink / raw)
To: help-gnu-emacs
rusi <rustompmody@gmail.com> writes:
> On Jan 3, 6:05 pm, Tim Harig <user...@ilthio.net> wrote:
>> On 2011-01-03, Didier Verna <did...@lrde.epita.fr> wrote:
>>
>> > Nathan <nbeen...@gmail.com> wrote:
>>
>> >> Matz himself admitted that ???...Ruby is a bad rip-off of Lisp... But it
>> >> is nicer to ordinary people.???
>>
>> > This misconception that you must be exceptionally clever to learn and
>> > use Lisp really hurts the language and the community.
>>
>> What hurts the LISP community far more is the zealotry of its members,
>> their insistance that LISP is the *only* tool for *every* job, and their
>> agressiveness in trying to push it off on to everybody else -- whether
>> everybody else happens want it or not. Whether this is indicitive
>> of the entire community or simply the result of those most apparent,
>> I cannot say; but, it leads to the overall impression that the LISP
>> community is narrowminded and neophobic. Who would want to be part of
>> such a community?
>
> There are more mundane reasons -- like unsuitability of lisp as a
> distribution platform
> [See http://www.newartisans.com/about-me.html where John Wiegley
> explains why he switched from lisp to C++ for his program ledger ]
I saw no explanation, only the statements that he "found Common Lisp
unsuitable as a distribution platform."
Perhaps it was just him being unable to find an implementation of Common
Lisp suitable as distribution platform. I've got the impression a lot
of people are able to find such implementations of Common Lisp, to
distribute and deploy their applications, be it free software
implementations or commercial implementation.
In anycase, he gives no justification.
--
__Pascal Bourguignon__ http://www.informatimago.com/
A bad day in () is better than a good day in {}.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (6 preceding siblings ...)
2011-01-03 10:18 ` Didier Verna
@ 2011-01-04 6:47 ` pineapple
2011-01-04 14:14 ` P.M.Lawrence
2011-01-05 14:58 ` Xah Lee
2011-01-18 22:55 ` m_l_g3
9 siblings, 1 reply; 84+ messages in thread
From: pineapple @ 2011-01-04 6:47 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 2:04 pm, girosenth <girose...@india.com> wrote:
> Is there a postfix functional language that also gets rid of parens
> and is not as primitive as FORTH or POSTSCRIPT ?
Joy.
http://en.wikipedia.org/wiki/Joy_(programming_language)
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 5:39 ` D Herring
@ 2011-01-04 8:02 ` Tim Harig
2011-01-04 9:09 ` Nicolas Neuss
2011-01-04 10:00 ` Tim Bradshaw
0 siblings, 2 replies; 84+ messages in thread
From: Tim Harig @ 2011-01-04 8:02 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04, D Herring <dherring@at.tentpost.dot.com> wrote:
>> On Jan 3, 6:05 pm, Tim Harig<user...@ilthio.net> wrote:
>>> What hurts the LISP community far more is the zealotry of its members,
>>> their insistance that LISP is the *only* tool for *every* job, and their
>>> agressiveness in trying to push it off on to everybody else -- whether
>>> everybody else happens want it or not. Whether this is indicitive
>>> of the entire community or simply the result of those most apparent,
>>> I cannot say; but, it leads to the overall impression that the LISP
>>> community is narrowminded and neophobic. Who would want to be part of
>>> such a community?
>
> Like the dark days of apple, bsd, and linux, there can be some bizarre
> fanboyism in the lisp community. Geeks are always technical but often
> not personable.
1. You imply that the worst of the zealotry for Apple, BSD, and Linux is
over. When is it going to be over for LISP?
2. While I would agree that the listed groups have zealots among their
ranks; but, in my experience, most of them have resigned to the
fact that they often have to work with other systems. I would
suspect that most of their members are at least as knowledgable
about using Windows as most dedicated Windows users. Most of
them, when push comes to shove, will even admit that there
are things which they admire about other operating systems,
including Windows.
LISP users on the other hand, never seem to be able to let
go of LISP when the situation requires it. To be fair, most
newcomers to any given language will tend to let the idioms
from their previous language bleed into the new language.
This is an familiarity issue and most will gradually assimilate
into the mainstream as their knowledge and experience with the
language grows. Ultimately their knowledge and experience in
both langauges improves their overall abilities no matter what
language they may happen to be using. LISP users never seem
to do that. They seem to be unable, or unwilling, to learn
anything new.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 8:02 ` Tim Harig
@ 2011-01-04 9:09 ` Nicolas Neuss
2011-01-04 10:00 ` Tim Bradshaw
1 sibling, 0 replies; 84+ messages in thread
From: Nicolas Neuss @ 2011-01-04 9:09 UTC (permalink / raw)
To: help-gnu-emacs
Tim Harig <usernet@ilthio.net> writes:
> LISP users on the other hand, never seem to be able to let
> go of LISP when the situation requires it. To be fair, most
> newcomers to any given language will tend to let the idioms
> from their previous language bleed into the new language.
> This is an familiarity issue and most will gradually assimilate
> into the mainstream as their knowledge and experience with the
> language grows. Ultimately their knowledge and experience in
> both langauges improves their overall abilities no matter what
> language they may happen to be using. LISP users never seem
> to do that. They seem to be unable, or unwilling, to learn
> anything new.
Could you provide a reference? Of a respected Lisp user who is
unwilling to learn anything new if the situation requires it? In my
experience people who proselytize Lisp are very often semi-newbies who
do not stay long.
Nicolas
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 8:02 ` Tim Harig
2011-01-04 9:09 ` Nicolas Neuss
@ 2011-01-04 10:00 ` Tim Bradshaw
2011-01-04 12:21 ` Tim Harig
2011-01-04 23:32 ` Tim X
1 sibling, 2 replies; 84+ messages in thread
From: Tim Bradshaw @ 2011-01-04 10:00 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04 08:02:35 +0000, Tim Harig said:
> LISP users on the other hand, never seem to be able to let
> go of LISP when the situation requires it.
I think this probably is not the case. It may be the case that the
Lisp users *you hear from* often have this view, but I don't think
those people are necessarily very representative of Lisp users as a
whole. Of course I can't really infer much about the ones you don't
hear from other than in a sort of dark-energy way - implementors are
probably the only people who might have a chance of knowing about them
in any reliable way.
For instance, I've been berated by the users you hear from for saying I
write (and like writing) Perl and (but not like very much) Java. I
don't think that makes me an atypical Lisp user, I just think it makes
me one of the few who are in the subset of Lisp users that you hear
from and who will admit to using other langages.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-03 13:05 ` Tim Harig
2011-01-04 4:49 ` rusi
@ 2011-01-04 10:18 ` Didier Verna
1 sibling, 0 replies; 84+ messages in thread
From: Didier Verna @ 2011-01-04 10:18 UTC (permalink / raw)
To: help-gnu-emacs
Tim Harig <usernet@ilthio.net> wrote:
> What hurts the LISP community far more is the zealotry of its members,
> their insistance that LISP is the *only* tool for *every* job, and
> their agressiveness in trying to push it off on to everybody else --
> whether everybody else happens want it or not. Whether this is
> indicitive of the entire community or simply the result of those most
> apparent, I cannot say; but, it leads to the overall impression that
> the LISP community is narrowminded and neophobic. Who would want to be
> part of such a community?
Not sure which lispers you've been talking to. I don't see any more
zealotry in the Lisp community than in any other one. I see, however,
things like Racket in which Lispers put a lot of efforts learning about
the cool stuff that comes from other languages and incorporating them
into their Lisp dialect (static typing, contracts, to name a few). Is
that narrowminded? Is it wrong to try to improve your preferred language
instead of switching to another one? These are the Lispers you should
talk to.
About the "*only* tool for *every* job" thing, there is often a
confusion between Lisp -- The Idea, and Lisp -- The Language(s). Lispers
usually like Lisp for its extreme customizability, something that is
closely related to Lisp -- The Idea (code is data, structural
reflexivity, the Lisp macros etc.). However, no programming language is
perfect, not even Lisp -- The Language(s). Common Lisp is far from
perfect, it's not perfect to have a gazillion Scheme dialects, let alone
Emacs Lisp.
The other thing that puzzles me is why you would be annoyed by people
trying to "push it off" on you. Maybe (just maybe ;-) I would try to
push off Lisp -- The Idea on you, but I wouldn't dare to try to push off
*any* language on you, because I don't know your background, your needs,
your interests etc. If somebody does that on me, I just ignore them.
--
Resistance is futile. You will be jazzimilated.
Scientific site: http://www.lrde.epita.fr/~didier
Music (Jazz) site: http://www.didierverna.com
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 10:00 ` Tim Bradshaw
@ 2011-01-04 12:21 ` Tim Harig
2011-01-04 12:23 ` Tim Bradshaw
2011-01-04 12:41 ` Tamas K Papp
2011-01-04 23:32 ` Tim X
1 sibling, 2 replies; 84+ messages in thread
From: Tim Harig @ 2011-01-04 12:21 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04, Tim Bradshaw <tfb@tfeb.org> wrote:
> On 2011-01-04 08:02:35 +0000, Tim Harig said:
>
>> LISP users on the other hand, never seem to be able to let
>> go of LISP when the situation requires it.
>
> I think this probably is not the case. It may be the case that the
> Lisp users *you hear from* often have this view, but I don't think
> those people are necessarily very representative of Lisp users as a
> whole. Of course I can't really infer much about the ones you don't
> hear from other than in a sort of dark-energy way - implementors are
> probably the only people who might have a chance of knowing about them
> in any reliable way.
The loudest voices in the crowd tend to characterize the crowd.
Unfortunately, to my point, those vocal zealots in the LISP community
are not doing it any favors.
Perhaps I am alone in this, but I don't much appreciate being part of
communities that are too openly negative towards others. It really puts
a poor taste in my mouth. I am a right tool for the right job kind
of person and I prefer communities that are open enough to be able to
properly evaluate the role of their chosen tools compared to others.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 12:21 ` Tim Harig
@ 2011-01-04 12:23 ` Tim Bradshaw
2011-01-04 13:33 ` Tim Harig
2011-01-04 12:41 ` Tamas K Papp
1 sibling, 1 reply; 84+ messages in thread
From: Tim Bradshaw @ 2011-01-04 12:23 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04 12:21:44 +0000, Tim Harig said:
> The loudest voices in the crowd tend to characterize the crowd.
They characterize how it *appears*, but only that.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 12:21 ` Tim Harig
2011-01-04 12:23 ` Tim Bradshaw
@ 2011-01-04 12:41 ` Tamas K Papp
1 sibling, 0 replies; 84+ messages in thread
From: Tamas K Papp @ 2011-01-04 12:41 UTC (permalink / raw)
To: help-gnu-emacs
On Tue, 04 Jan 2011 12:21:44 +0000, Tim Harig wrote:
> On 2011-01-04, Tim Bradshaw <tfb@tfeb.org> wrote:
>> On 2011-01-04 08:02:35 +0000, Tim Harig said:
>>
>>> LISP users on the other hand, never seem to be able to let go of LISP
>>> when the situation requires it.
>>
>> I think this probably is not the case. It may be the case that the
>> Lisp users *you hear from* often have this view, but I don't think
>> those people are necessarily very representative of Lisp users as a
>> whole. Of course I can't really infer much about the ones you don't
>> hear from other than in a sort of dark-energy way - implementors are
>> probably the only people who might have a chance of knowing about them
>> in any reliable way.
>
> The loudest voices in the crowd tend to characterize the crowd.
> Unfortunately, to my point, those vocal zealots in the LISP community
> are not doing it any favors.
>
> Perhaps I am alone in this, but I don't much appreciate being part of
> communities that are too openly negative towards others. It really puts
> a poor taste in my mouth. I am a right tool for the right job kind of
> person and I prefer communities that are open enough to be able to
> properly evaluate the role of their chosen tools compared to others.
It would be great if you could substantiate your points with examples
(eg links to discussions on newsgroups or mailing lists). I have been
following c.l.l for years now, but I haven't seen the kind of zealotry
that you describe. Perhaps this is because Lisp zealots go to other
forums: this is of course possible, but I would be interested in
seeing examples of lispers being "openly negative towards others"
before entertaining the idea that this is some sort of general
tendency.
I don't believe that it is possible to have a meaningful discussion
about this question unless you are a lot more specific about your
claims.
Best,
Tamas
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 12:23 ` Tim Bradshaw
@ 2011-01-04 13:33 ` Tim Harig
0 siblings, 0 replies; 84+ messages in thread
From: Tim Harig @ 2011-01-04 13:33 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04, Tim Bradshaw <tfb@tfeb.org> wrote:
> On 2011-01-04 12:21:44 +0000, Tim Harig said:
>
>> The loudest voices in the crowd tend to characterize the crowd.
>
> They characterize how it *appears*, but only that.
No doubt; but, when somebody evaluates the language, their impressions
will be based far more on appearences then objective reality. My point
is, that simply offering assertions against the languages misconceptions
and/or touting the languages benefits may not be effective in generating
interest for the language -- even among those who might have strong use
cases for the LISP language.
In many instances, I think it would be more useful for the community
to appear be a little more open minded, inviting, and respectful of
other languages that a prospective LISP user might already have an
appreciation for. To do that, it needs to mitigate those negative voices
within the community that are carrying the furthest and providing the
negative contribution to the communities appearance.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 6:47 ` pineapple
@ 2011-01-04 14:14 ` P.M.Lawrence
0 siblings, 0 replies; 84+ messages in thread
From: P.M.Lawrence @ 2011-01-04 14:14 UTC (permalink / raw)
To: help-gnu-emacs
pineapple wrote:
> On Jan 1, 2:04 pm, girosenth <girose...@india.com> wrote:
>
> > Is there a postfix functional language that also gets rid of parens
> > and is not as primitive as FORTH or POSTSCRIPT ?
>
> Joy.
>
> http://en.wikipedia.org/wiki/Joy_(programming_language)
Not quite; that does use bracketing around chunks of code, as much as
anything for quoting purposes to allow lazy evaluation.
The problem with a completely postfix notation for a functional
language is that parameters are evaluated as they turn up, without
regard to the operation that needs them (as, without lookahead that
would destroy the gains from postfix notation, it isn't yet known what
will be needed). That appears to enforce strict evaluation, unless the
postfix notation is loosened with some quoting system.
However, I did some work on this myself for my Furphy project (see
http://users.beagle.com.au/peterl/furphy.html - but so far it's only a
prototype/testbed, and still quite "primitive"). I found an
indirection mechanism that gave lazy evaluation without a quoting
system, which I implemented with the complementary keywords FREEZE and
THAW. Even so, a quoting system is so convenient that I added one back
in - only, now it is a layer of syntactic sugar rather than an
alternative treatment of the source. I wanted to avoid that
alternative treatment so that inconsistencies wouldn't develop from
going in and out of postfix notation - I was even able to make keyword
naming postfix. P.M.Lawrence.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 6:24 ` Pascal J. Bourguignon
@ 2011-01-04 15:43 ` Raffael Cavallaro
0 siblings, 0 replies; 84+ messages in thread
From: Raffael Cavallaro @ 2011-01-04 15:43 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04 01:24:13 -0500, Pascal J. Bourguignon said:
> I saw no explanation, only the statements that he "found Common Lisp
> unsuitable as a distribution platform."
He also says he likes Mac OS X so maybe he was looking for a native Mac
OS X distribution option. Unless he was writing about a very recent
experience, the best free option, Clozure CL64/32, was not yet mature
enough that many would want to use it to distribute an application
(imho it is now).
The other option for native Mac apps has been available for years -
LispWorks - but it is not free. Never underestimate people's ability to
allow the desire for a no-cost solution to override better judgement.
Clearly, he thinks lisp is superior; he thinks Mac OS X is superior;
until recently, you had to pay to distribute this combination in a
native app using a mature implementation and IDE.
warmest regards,
Ralph
--
Raffael Cavallaro
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 10:00 ` Tim Bradshaw
2011-01-04 12:21 ` Tim Harig
@ 2011-01-04 23:32 ` Tim X
2011-01-05 1:35 ` [OT] LISP community advocacy [was Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?] Tim Harig
2011-01-05 9:52 ` How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? Tim Bradshaw
1 sibling, 2 replies; 84+ messages in thread
From: Tim X @ 2011-01-04 23:32 UTC (permalink / raw)
To: help-gnu-emacs
Tim Bradshaw <tfb@tfeb.org> writes:
> On 2011-01-04 08:02:35 +0000, Tim Harig said:
>
>> LISP users on the other hand, never seem to be able to let
>> go of LISP when the situation requires it.
>
> I think this probably is not the case. It may be the case that the Lisp users
> *you hear from* often have this view, but I don't think those people are
> necessarily very representative of Lisp users as a whole. Of course I can't
> really infer much about the ones you don't hear from other than in a sort of
> dark-energy way - implementors are probably the only people who might have a
> chance of knowing about them in any reliable way.
>
> For instance, I've been berated by the users you hear from for saying I write
> (and like writing) Perl and (but not like very much) Java. I don't think that
> makes me an atypical Lisp user, I just think it makes me one of the few who are
> in the subset of Lisp users that you hear from and who will admit to using
> other langages.
>
I would add that it is a mistake to judge a community of users based on
a single forum. For example, many have complained about comp.lang.lisp
and it is often viewed as being the lisp community. In reality, it is
only a very small representation of lisp users from a single forum.
There are many other lisp forums with varying levels of acceptance,
hostility, dogma, experience, cynicism etc.
Judging the lisp community by what goes on in c.l.l is like stopping at
some remote town in the hills where everyone has the same nose and
concluding it is a national trait.
Personally, I enjoy c.l.l as I can easily recognise the threads to kill
and those which are likely to have some interesting information. Sure,
we may throw a few fists and end up rolling around in the pig shit from
time to time and sometimes one of the cousins may drink a bit much
'shine and probably should'nt pull out the shotgun, but what can you do,
its family.
--
tcross (at) rapttech dot com dot au
^ permalink raw reply [flat|nested] 84+ messages in thread
* [OT] LISP community advocacy [was Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?]
2011-01-04 23:32 ` Tim X
@ 2011-01-05 1:35 ` Tim Harig
2011-01-05 9:52 ` How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? Tim Bradshaw
1 sibling, 0 replies; 84+ messages in thread
From: Tim Harig @ 2011-01-05 1:35 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04, Tim X <timx@nospam.dev.null> wrote:
>> On 2011-01-04 08:02:35 +0000, Tim Harig said:
>>
>>> LISP users on the other hand, never seem to be able to let
>>> go of LISP when the situation requires it.
>
> I would add that it is a mistake to judge a community of users based on
> a single forum. For example, many have complained about comp.lang.lisp
> and it is often viewed as being the lisp community. In reality, it is
I don't subscribe to c.l.l. I came across this post in c.l.f and my post
is a general statement not really directed to the topic or poster but
merely to the comment about what is detrimental to the LISP community.
Most of my experience with LISP advocates comes from bleedthrough to
other groups or aquaintences in meat-space. I would expect advocacy in a
group dedicated to the language. In groups that are language agnostic,
I would expect a more sympathetic attitude towards other languages.
I certainly wouldn't expect them to spam groups dedicated to other
languages with LISP propoganda.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-04 23:32 ` Tim X
2011-01-05 1:35 ` [OT] LISP community advocacy [was Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?] Tim Harig
@ 2011-01-05 9:52 ` Tim Bradshaw
1 sibling, 0 replies; 84+ messages in thread
From: Tim Bradshaw @ 2011-01-05 9:52 UTC (permalink / raw)
To: help-gnu-emacs
On 2011-01-04 23:32:23 +0000, Tim X said:
> I would add that it is a mistake to judge a community of users based on
> a single forum. For example, many have complained about comp.lang.lisp
> and it is often viewed as being the lisp community. In reality, it is
> only a very small representation of lisp users from a single forum.
> There are many other lisp forums with varying levels of acceptance,
> hostility, dogma, experience, cynicism etc.
I think it's almost universally a mistake to judge anything by usenet
news, not just CLL. Newsgroups have always been odd and fierce places,
and (without evidence) I think usenet must be close to dead as a
discussion forum (as opposed to a media distribution mechanism where
it seems to be thriving).
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (7 preceding siblings ...)
2011-01-04 6:47 ` pineapple
@ 2011-01-05 14:58 ` Xah Lee
2011-01-05 16:21 ` Andrew Haley
` (2 more replies)
2011-01-18 22:55 ` m_l_g3
9 siblings, 3 replies; 84+ messages in thread
From: Xah Lee @ 2011-01-05 14:58 UTC (permalink / raw)
To: help-gnu-emacs
On Dec 31 2010, 11:04 pm, girosenth <girose...@india.com> wrote:
> How to improve the readability of (any) LISP or any highlevel
> functional language to the level of FORTH ?
>
> There are many people who have trivia complaints about parens in lisp,
> but I dont.
>
> LISP is a prefix notation.
Note that calling lisp syntax as “prefix” is misleading.
When you say “prefix” or “postfix” notation, implied in the word is
use of operators and their general ordering characteristics.
lisp syntax does not use operators, or rather, it primarily relies on
one single match-fix operator the parenthesis. And as a match-fix
operator, the word “pre-fix” doesn't make much sense because that word
is primarly for operators used in a linear (none nested) way.
for detail, see:
〈The Concepts and Confusions of Prefix, Infix, Postfix and Fully
Nested Notations〉
http://xahlee.org/UnixResource_dir/writ/notations.html
> sequence of operations would look like this on operands (ops) :
>
> (f ops (g ops (h ops (j ops (k ops (l ops ))...))))
>
> How do you make it readable ?
> How do you home to the center or centers ?
>
> (f (g (h (j (k (l ops)))...)))
>
> is easy to read or
>
> ops l k j h g f
>
> ???
>
> Which is linear reading from L->R ? LISP or FORTH ?
>
> AND, if I must break the nested function structure, will I not be
> visiting the forbidden territory of imperative programming ?
>
> (setq L (l ops))
> (setq K (k L ))
> ....
> ....
> (setq F (f G ))
>
> If I use setq, I am using globals, atleast in elisp.
>
> If I use let*, I have limited options as I am constrained inside the
> rigid structure of let*
>
> (let*
> ((L (l ops))
> (K (k L ))
> ....
> (F (f G )))
>
> some more
> )
>
> Is there a postfix functional language that also gets rid of parens
> and is not as primitive as FORTH or POSTSCRIPT ?
you might get some tips about this from this article:
〈What's Point-free Programing? (point-free function syntax)〉
http://xahlee.org/comp/point-free_programing.html
i've thought about a syntax that does not use any match-fix operators
(nesting of symbols) whatsoever. But my current conclusion is that
• strictly no nesting whatsoever is not a desired property.
• when done to a large extend yet not 100% (e.g. APL and derivatives),
you sacrifice several advantages in syntax and also some semantic
possibilty in the lang.
also note, reduction or elimination of match-fix operators in so-
called stack
based lang such as Forth, does not really qualify as a syntactical
solution. It
rids of match-fix by a semantic solution. (i.e. there's implicit
hiding of
arguments, they went into a “stack”). Another way to view this is
that, when we
look at Forth (which am not familiar) or HP-28s calculator's language
(which i'm
familiar), or if we look at so-called “reverse polish notation” RPN,
the RPN is
not a complete syntx system on its own right, but relies on a language
system... (not sure if anyone see what i mean here... i need to do a
lot more
thinking to express this in some “formal” way, so as to clearly
indicate the
properties differences)
> What are the syntax advantages of ERLANG, ML, CAML, OCAML, HASKELL,
> PROLOG, RUBY over LISP ?
that's a loaded question of course.
but my own pet peeves is that there is to-date no major general
purpose comp lang that actually have a lexical grammar. The awareness
of the concept of a grammar for syntax is little known among
programers. Each lang basically create a bunch of ad hoc syntax, that
are not consistent nor well defined. In fact, no major general purpose
languages even have a lexical grammar per se. (what we have are just
tools that helps define and parse)
The only close exception is XML, but of course it is just a markup
lang.
for some detail, see:
• 〈Math Notations, Computer Languages, and the “Form” in Formalism〉
http://xahlee.org/cmaci/notation/lang_notation_formalism.html
• 〈Pattern Matching vs Lexical Grammar Specification〉
http://xahlee.org/cmaci/notation/pattern_matching_vs_pattern_spec.html
> How does one improve readability so that the code is self-commenting ?
it's a common myth among programers that certain lang's syntax is so
clear that it is “self-documenting”. For example, lisp coders said it
in 1970s or earlier when sexp and the idea of a lang that reflex math
directly is new. Mathematica literature said it in 1990s because
pattern matching is a good fit for symbolic manipulation. Haskeller
has said it because they think Haskell code is so much a direct mirror
of traditional math notation (and this is quite laughable when
compared to Mathematica). And Ruby coder said it because they feel how
the syntax mirror programing algorithms so clearly and concisely.
Perl mongers to various degree also thinks of that of their lang,
because how the perl idioms allow ommision of many syntactical details
and quite flexible and they think it reflect the way human uses
natural lang (e.g. english).
so, sometimes in discussion, someone show you a line of code without
any comment or explanation. To you, you are perplexed at what the code
does. When you ask, you find out that they are honestly surprised
because they think that the code's meaning is so plain and obvious
that any additional explanation actually complicate it.
part of all these feelings is due to the fact that when you are
familiar with a lang, it becomes part of your thinking, a written
language to express your thoughts. Especially so if you don't know
much of other langs. You are too familiar with the lang to realize the
fact that different languages have always been a barrior to
communication. The more expert you are with a lang, and the less the
number of other langs you actually work with in depth, the more likely
you forgot that different langs are just different. What's obvious to
you, even just a short line, is really just a string of gibberish
symbols mixed together in weird ways to another who are not familiar
with your lang.
So, your question «How does one improve readability so that the code
is self-commenting ?» has many answers depending what you really want.
Comp lang syntax readability is a subject in the context psychology
and linguistics. Among comp lang forums among programers, they knew
nothing of it, and what you read there usually is utter garbage. But
to take a general programer practioners's point of view, for example,
Python is considered very readable, and the primary reason for sayig
so is actually just code formatting (i.e. short lines, and all neatly
indented), and the reason python code are well formatted because the
formatting is worked into the language's syntax.
take a complete different perspective, there's Mathematica. For
example, what do you think if comp lang source code are like
traditional math notation that's so-call 2-dimentional notation? e.g.
you have 「x^3」 with the 3 raised, you have 1/2 with 1 on top of a bar
and 2 below the bar, etc. And when the expression gets complex, e.g.
-b + Sqrt[b^2-4 a c]/(2 a)
it becomes much easier to read when in traditional math notation. In
Mathematica, its syntax system is such that, it can display the source
code in 2-dimentional notation automatically, if you want. you can see
some example here, also in PDF format
〈Math Typesetting, Mathematica, MathML〉 http://xahlee.org/math/typesetting_Mathematica_mathML.html
The same expression in lisp style you get this
/(+(-(b) √(+(^(b 2) -(*(4 a c))))) *(2 a))
is it readable? Many lispers insist that its the most readable syntax.
See also:
• 〈What's Function, What's Operator?〉 http://xahlee.org/math/function_and_operators.html
Xah ∑ http://xahlee.org/ ☄
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 14:58 ` Xah Lee
@ 2011-01-05 16:21 ` Andrew Haley
2011-01-05 21:29 ` Pascal J. Bourguignon
2011-01-07 5:36 ` Xah Lee
2011-01-05 17:59 ` Elena
2011-01-06 22:59 ` Xah Lee
2 siblings, 2 replies; 84+ messages in thread
From: Andrew Haley @ 2011-01-05 16:21 UTC (permalink / raw)
To: help-gnu-emacs
In comp.lang.forth Xah Lee <xahlee@gmail.com> wrote:
>
> lisp syntax does not use operators, or rather, it primarily relies on
> one single match-fix operator the parenthesis. And as a match-fix
> operator, the word ?pre-fix? doesn't make much sense because that word
> is primarly for operators used in a linear (none nested) way.
>
> for detail, see:
>
> ?The Concepts and Confusions of Prefix, Infix, Postfix and Fully
> Nested Notations?
> http://xahlee.org/UnixResource_dir/writ/notations.html
Given that the article even manages to confuse Polish notation and
Reverse Polish notation, I strongly recommend that everyone avoid it.
Andrew.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 14:58 ` Xah Lee
2011-01-05 16:21 ` Andrew Haley
@ 2011-01-05 17:59 ` Elena
2011-01-05 20:13 ` Xah Lee
2011-01-05 21:42 ` Pascal J. Bourguignon
2011-01-06 22:59 ` Xah Lee
2 siblings, 2 replies; 84+ messages in thread
From: Elena @ 2011-01-05 17:59 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 5, 3:58 pm, Xah Lee <xah...@gmail.com> wrote:
> The same expression in lisp style you get this
>
> /(+(-(b) √(+(^(b 2) -(*(4 a c))))) *(2 a))
>
> is it readable? Many lispers insist that its the most readable syntax.
And here is why: http://blo.udoidio.info/2008/09/lisp-syntax-is-great.html
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 17:59 ` Elena
@ 2011-01-05 20:13 ` Xah Lee
2011-01-05 21:42 ` Pascal J. Bourguignon
1 sibling, 0 replies; 84+ messages in thread
From: Xah Lee @ 2011-01-05 20:13 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 5, 9:59 am, Elena <egarr...@gmail.com> wrote:
> On Jan 5, 3:58 pm, Xah Lee <xah...@gmail.com> wrote:
>
> > The same expression in lisp style you get this
>
> > /(+(-(b) √(+(^(b 2) -(*(4 a c))))) *(2 a))
>
> > is it readable? Many lispers insist that its the most readable syntax.
>
> And here is why: http://blo.udoidio.info/2008/09/lisp-syntax-is-great.html
oops, a typo. Copied the wrong line. The correct form is
(/ (+ (- b) (√ (+ (^ b 2) (- (* 4 a c))))) (* 2 a))
article on my blog now
http://xahlee.blogspot.com/2011/01/whats-most-readable-computer-language.html
Xah
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 16:21 ` Andrew Haley
@ 2011-01-05 21:29 ` Pascal J. Bourguignon
2011-01-06 8:57 ` Jonathan Groll
2011-01-07 5:36 ` Xah Lee
1 sibling, 1 reply; 84+ messages in thread
From: Pascal J. Bourguignon @ 2011-01-05 21:29 UTC (permalink / raw)
To: help-gnu-emacs
Andrew Haley <andrew29@littlepinkcloud.invalid> writes:
> In comp.lang.forth Xah Lee <xahlee@gmail.com> wrote:
>>
>> lisp syntax does not use operators, or rather, it primarily relies on
>> one single match-fix operator the parenthesis. And as a match-fix
>> operator, the word ?pre-fix? doesn't make much sense because that word
>> is primarly for operators used in a linear (none nested) way.
>>
>> for detail, see:
>>
>> ?The Concepts and Confusions of Prefix, Infix, Postfix and Fully
>> Nested Notations?
>> http://xahlee.org/UnixResource_dir/writ/notations.html
>
> Given that the article even manages to confuse Polish notation and
> Reverse Polish notation, I strongly recommend that everyone avoid it.
As most of what he writes...
--
__Pascal Bourguignon__ http://www.informatimago.com/
A bad day in () is better than a good day in {}.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 17:59 ` Elena
2011-01-05 20:13 ` Xah Lee
@ 2011-01-05 21:42 ` Pascal J. Bourguignon
2011-01-06 13:38 ` Doug Hoffman
1 sibling, 1 reply; 84+ messages in thread
From: Pascal J. Bourguignon @ 2011-01-05 21:42 UTC (permalink / raw)
To: help-gnu-emacs
Elena <egarrulo@gmail.com> writes:
> On Jan 5, 3:58 pm, Xah Lee <xah...@gmail.com> wrote:
>> The same expression in lisp style you get this
>>
>> /(+(-(b) √(+(^(b 2) -(*(4 a c))))) *(2 a))
>>
>> is it readable? Many lispers insist that its the most readable syntax.
>
> And here is why: http://blo.udoidio.info/2008/09/lisp-syntax-is-great.html
He's wrong, the most readable is:
(divide (minus (square-root (minus (square b) (* 4 a c)))
b)
2 a)
or, for wanbees:
(/ (- (sqrt (- (square b) (* 4 a c))) b)
2 a)
--
__Pascal Bourguignon__ http://www.informatimago.com/
A bad day in () is better than a good day in {}.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 21:29 ` Pascal J. Bourguignon
@ 2011-01-06 8:57 ` Jonathan Groll
0 siblings, 0 replies; 84+ messages in thread
From: Jonathan Groll @ 2011-01-06 8:57 UTC (permalink / raw)
To: help-gnu-emacs
On Wed, 05 Jan 2011 22:29:50 +0100, "Pascal J. Bourguignon" <pjb@informatimago.com> wrote:
> Andrew Haley <andrew29@littlepinkcloud.invalid> writes:
>
> > In comp.lang.forth Xah Lee <xahlee@gmail.com> wrote:
> >>
> >> lisp syntax does not use operators, or rather, it primarily relies on
> >> one single match-fix operator the parenthesis. And as a match-fix
> >> operator, the word ?pre-fix? doesn't make much sense because that word
> >> is primarly for operators used in a linear (none nested) way.
> >>
> >> for detail, see:
> >>
> >> ?The Concepts and Confusions of Prefix, Infix, Postfix and Fully
> >> Nested Notations?
> >> http://xahlee.org/UnixResource_dir/writ/notations.html
> >
> > Given that the article even manages to confuse Polish notation and
> > Reverse Polish notation, I strongly recommend that everyone avoid it.
>
> As most of what he writes...
Indeed. Most people think that because it is published on the internet
it must be right.
Cheers,
Jonathan
--
jjg: Jonathan J. Groll : groll co za
has_one { :blog => "http://bloggroll.com" }
Reine, reine gueux éveille
Gomme à gaine, en horreur, taie.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 21:42 ` Pascal J. Bourguignon
@ 2011-01-06 13:38 ` Doug Hoffman
2011-01-06 19:20 ` Pascal J. Bourguignon
0 siblings, 1 reply; 84+ messages in thread
From: Doug Hoffman @ 2011-01-06 13:38 UTC (permalink / raw)
To: help-gnu-emacs
On 1/5/11 4:42 PM, Pascal J. Bourguignon wrote:
> Elena<egarrulo@gmail.com> writes:
>
>> On Jan 5, 3:58 pm, Xah Lee<xah...@gmail.com> wrote:
>>> The same expression in lisp style you get this
>>>
>>> /(+(-(b) √(+(^(b 2) -(*(4 a c))))) *(2 a))
>>>
>>> is it readable? Many lispers insist that its the most readable syntax.
>>
>> And here is why: http://blo.udoidio.info/2008/09/lisp-syntax-is-great.html
>
> He's wrong, the most readable is:
>
> (divide (minus (square-root (minus (square b) (* 4 a c)))
> b)
> 2 a)
>
> or, for wanbees:
>
> (/ (- (sqrt (- (square b) (* 4 a c))) b)
> 2 a)
Without getting into the issues of the proper way to handle the
quadratic (this has been thoroughly hashed thru on comp.lang.forth) and
sticking with just the simple equation as presented (I'll ignore the
issue of taking the square root of negative numbers) I would make the
following observations:
1)
> (divide (minus (square-root (minus (square b) (* 4 a c))) b) 2 a)
This may be very readable for Lispers. For others not so much.
2) The following is one way (of many) to approach this in standard Forth:
: quad f{ a b c -- root }
b FNEGATE b FDUP F* 4e a c F* F* F- FSQRT F+ 2e a F* F/
;
-2e 7e 15e quad f.
-1.500000
Is it readable? Unless you're a Forther I would say no. But notice the
complete lack of parentheses and operator precedences to resolve. Any
competent Forther could quickly see exactly what is going on.
3) We have available in Forth a FORmula TRANslator utility (it is not
part of the official ANS Forth standard). It could be applied in this
situation as follows:
: quad2 f{ a b c -- root }
f' (-b + sqrt(b^2 - 4*a*c))/(2*a)'
;
-2e 7e 15e quad2 f.
-1.500000
Is it readable? I would say yes. Note that it compiles *exactly* the
same Forth code as quad in 2).
4) I am able to do a copy/paste of
=(-b + sqrt(b^2 - 4*a*c))/(2*a)
into an Excel spreadsheet and with the variables a, b, and c defined
the spreadsheet gives the expected results.
-Doug
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-06 13:38 ` Doug Hoffman
@ 2011-01-06 19:20 ` Pascal J. Bourguignon
2011-01-07 0:09 ` w_a_x_man
2011-01-07 12:04 ` Doug Hoffman
0 siblings, 2 replies; 84+ messages in thread
From: Pascal J. Bourguignon @ 2011-01-06 19:20 UTC (permalink / raw)
To: help-gnu-emacs
Doug Hoffman <glidedog@gmail.com> writes:
> 2) The following is one way (of many) to approach this in standard Forth:
>
> : quad f{ a b c -- root }
> b FNEGATE b FDUP F* 4e a c F* F* F- FSQRT F+ 2e a F* F/
> ;
>
> -2e 7e 15e quad f.
> -1.500000
>
> Is it readable? Unless you're a Forther I would say no. But notice
> the complete lack of parentheses and operator precedences to resolve.
> Any competent Forther could quickly see exactly what is going on.
Now, as a Forth programmer, ask yourself what you would have to do, to
call an operator with a variable arity?
In Postscript, there is a mark operator, to push a mark on the stack, so
that a next operator of variable arity may collect a variable number of
arguments, up to that mark.
Then, as a Forth programmer, ask yourself what you would need to be able
to parse a Forth expression containing unknown operators, ie. operators
of unknown (possibly fixed, but also variable) arity?]
If you consider a separate table giving the arity of the operators, then
it is not unknown anymore. The only solution I know, is to use mark
systematically:
MARK MARK MARK MARK MARK b FNEGATE FDUP F* MARK 4e a c F* F- FSQRT F+
MARK 2e a F* F/
Then, we may add some syntactic sugar, replacing call the MARK operator
'(', and adding gratuituous balanced ')' after each operator:
(((((((b -) FDUP) f*) (4e a c F*) F-) FSQRT) F+) (2e a F*) F/)
Finally, we may apply mechanically a recursive reverse:
(defun rrev (x)
(if (listp x)
(mapcar 'rrev (reverse x))
x))
(rrev
'(((((((b -) FDUP) f*) (4e a c F*) F-) FSQRT) F+) (2e a F*) F/))
(F/ (F* a 2e)
(F+ (FSQRT (F- (F* c a 4e)
(F* (FDUP (- b)))))))
so it becomes readable again and you can see there's a bug in the Forth
expression. Since the syntax become suddenly much simplier, we don't
need to prefix operators with 'F' anymore. So we can write merely:
(/ (* a 2)
(+ (sqrt (- (* c a 4)
(* (dup (- b)))))))
Anyways, the great thing now, is that we have homoiconicity
(notice how I used the parenthesised source expression as data passed
to rrev), and we can process expressions without knowing the arity of
the operators (the operators may even not be defined before we process
expressions using them!). For example, we could now write:
(derivate '(/ (* a 2)
(+ (sqrt (- (* c a 4)
(* (dup (- b)))))))
'a)
and get:
--> (- (/ 2 (sqrt (- (* 4 a c) (* b b))))
(/ (* 4 a c) (expt (sqrt (- (* 4 a c) (* b b))) 3/2)))
and since this is one of the first applications of Lisp, you can see now
the reasons and advantages why lisp has these parentheses. Of course,
that doesn't preclude writing in lisp symbolic mathematic programs like
maxima, providing the mathematical user with a more usual infix input
and 2D output:
http://www.informatimago.com/images/example-maxima.png
> 3) We have available in Forth a FORmula TRANslator utility (it is not
> part of the official ANS Forth standard). It could be applied in this
> situation as follows:
>
> : quad2 f{ a b c -- root }
> f' (-b + sqrt(b^2 - 4*a*c))/(2*a)'
> ;
There are also infix-to-lisp utilities to embed infix expressions in
lisp program. If you had to implement a program with a lot of
mathematical formula to copy from a book, I guess these utility would
come handy.
--
__Pascal Bourguignon__ http://www.informatimago.com/
A bad day in () is better than a good day in {}.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 14:58 ` Xah Lee
2011-01-05 16:21 ` Andrew Haley
2011-01-05 17:59 ` Elena
@ 2011-01-06 22:59 ` Xah Lee
2011-01-07 11:47 ` Jan Burse
2 siblings, 1 reply; 84+ messages in thread
From: Xah Lee @ 2011-01-06 22:59 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 5, 6:58 am, Xah Lee <xah...@gmail.com> wrote:
> On Dec 31 2010, 11:04 pm, girosenth <girose...@india.com> wrote:
>
> > How to improve the readability of (any) LISP or any highlevel
> > functional language to the level of FORTH ?
some basics that might be helpful.
〈What's Function, What's Operator?〉
http://xahlee.org/math/function_and_operators.html
--------------------------------------------------
What's Function, What's Operator?
Xah Lee, 2010-12-14, 2011-01-06
Typically, we understand what “function” and “operator” mean, but
programer may have a hard time explaining them, and mathematician may
never thought about it. Here, we clarify a bit on the meaning of the
word “function” and “operator”, their context, their relation.
--------------------------------
Function is a Mathematical Concept
Function you probably understand. A function takes a input, and output
a value for a given input. The inputs are called “parameters”. A
specific set of input is called “arguments”. The number of parameters
of a function is called the function's “arity”. So, for example, the
function “sin” has arity 1. A constant, such as 35, π, can be
considered as functions of no parameter, so they are functions of
arity 0. A function of 2 parameters, such as f(x,y) := x+y has arity
2.
Function is a mathematical concept. Viewed in another way, it's a map
from one space (aka set) to another.
--------------------------------
Operator is About Notation
A operator, is less of a mathematical concept, but more of a concept
of notation. Or, in computer language contexts, a element of syntax. A
“operator” is a symbol (or symbols) that are written to indicate
operations. For example, we write 1+2, the “+” is a operator, and the
“1” and “2” are its “operands”. Mathematically, operator is a function
that acts on its operands. The operands are the arguments of the
function.
--------------------------------
Binary Operators
Typically, operators takes 2 arguments, the left and right of the
symbol. e.g. 2×3, 3/4, 2^3, union {3,4}∪{2,4,1}, etc.
--------------------------------
Unary Operators
But there are also 1-argument operators. For example the minus sign
-3, and the logical not ¬ sign, the factorial 3!, square root √3.
--------------------------------
Multi-symbol Operators
Operators can also involve other forms with more symbols. For example,
the absolute sign |-3|, floor ⌊3.8⌋ uses a bracket, summation ∑ takes
4 arguments, a expression, a variable, and start and end values. The
anti-derivative (aka indefinite integral) ∫ takes 2 arguments, a
expression and a symbol. In traditional notation, the integration
operator involves 2 symbols, ∫ and ⅆ. For example, we write ∫ sin(x)
ⅆx .
--------------------------------
Implicit Operators
Operator can be a bit complicated. For example -3 can be interpreted
in several ways. We can think of the minus sign as unary operator
acting on the argument 3. So, mathematically, it is a function of 1
arity that returns the addictive inverse of the element 3. Or, we can
interprete it as one single entity, a element of Reals denoted -3.
When we write 3-2, the ways to interprete it gets a bit more complex.
One way to think of it as a notation shorthand for 3 + (-2). The -2
part can be thought of as before. Another way is to think of - as a
binary operator on 3 and 2, but this seemingly simple interpretation
is a bit complex. Because, what is math definition of the minus binary
function? I'm not sure how it can be defined in terms of algebra
without ultimately thinking of it as additon of 2 elements, one being
a addictive inverse. The other way is to think of it as a real line,
moving the first argument to the left by a distance of the second
argument. Of course ultimately these are equivalent, but i can't think
of a simple, direct, interpretation that can serve as a math
foundation. Also, this is directly related to how does one interprete
division, such as 3/2.
The multiplication operator also gets complicated. For example, when
we write 3 x, it usually means 3*x. The space acts as implicit
multiplication sign. But when we write 3 +2, the space there has no
significance. When we write 3x, even there is no space nor any
operator, but we mean 3*x. As a computer language syntax based on
traditional notation, the parsing rule is not trivial.
Operator Stickiness
There's also the concept of “operator stickiness” (aka “operator
precendence”) at work that makes expressions with operators more
concise. When we write3△4▲5, how do you know it's (3△4)▲5 or 3△(4▲5)?
The concept of operator stickiness is needed to resolve that.
Otherwise, you'll need to always write 3+(4*5) instead of the simpler
3+4*5. But this again, also introduced more complexity. When you have
a expression of tens of different operators, it becomes a problem of
remembering the stickiness grammar for each operator. (in practice,
when you are not sure about the procedence, you usually just use
explicit priority indicator by parens. This often happens in
programing with logic operators (e.g. and &&, or ||, not !.)
Forgetting Operator Precedence is a common error in programing. In
written math for human communication, it is prone to
miscommunication.)
--------------------------------
Operator is tied to Notation
Because the concept of “operator” more has to do with syntax and
notation, and when considering traditional math notation of writing in
“2-dimensions”, also the fact that traditional math notation has a lot
ambiguities, it gets a bit complicated and not as imprecise as we
like. (See: The Problems of Traditional Math Notation)
Mathematically, operator and function are the same thing.
Math function in traditional notation has the form e.g. sin(x),
f(x,y), where the things inside the paren are its parameter/arguments,
and function name is placed to the left.
Operators are useful because writing everything out in full function
notation gets very cumbersome and hard to read. For example, we write
3+4*5 instead of plus(3,times(4,5)) or +(3,*(4,5)).
Here's a example of traditional notation using operators:
-b+√(b^2-4 a c)/(2 a)
If you don't allow space as implicit multiplication sign, then you
have to write:
-b+√((b^2)-4*a*c)/(2*a)
If you don't allow the the concept of operator precedence, then you
have to write:
(-b)+(√((b^2)-((4*a)*c))/(2*a))
If you prefer the structural clarity of the traditional function
notation f(x), you have to write:
/(+(-(b),√(+(^(b,2),-(*(4,a,c))))),*(2,a))
If you prefer words than symbols, as traditionally practiced when
writing out functions, you have to write:
divide(add(minus(b),sqrt(add(power(b,
2),minus(times(4,a,c))))),times(2,a))
The notation using operators is much concise, readable, but at the
cost of relatively complex lexical grammar. The full functional
notation is precise, grammatically simple, but difficult to read.
In math context, it's best to think of functions instead of operator,
and sometimes also use a uniform function notation, where all
arguments are explicitly indicated in one uniform way.
Here's what Wikipedia has to say about operators: Operation
(mathematics). Quote:
An operation ω is a function of the form ω : X1 × … × Xk → Y. The
sets Xj are called the domains of the operation, the set Y is called
the codomain of the operation, and the fixed non-negative integer k
(the number of arguments) is called the type or arity of the
operation.
Note that it doesn't really speaks of “operators”, but speaks of
“operations”, and flatly defines operation as a function.
--------------------------------
Traditional Function Notation sin(x) Isn't Perfect
Note that, even the functional notation such as sin(x), isn't perfect.
Problem of Functions Returning Functions
Normally, with full function notation, you'd expect that execution
order of operations clearly corresponds to the nesting structure. For
example, in our example before:
divide(add(minus(b),sqrt(add(power(b,
2),minus(times(4,a,c))))),times(2,a))
The inner-most parts are evaluated first.
But there's a problem when a function returns a function. For example,
the derivative takes a function and returns a function. We might
write:
derivative(f)
Now, if we want to evaluate the result at 3, then we might write:
derivative(f)(3)
You can see that the notation no longer nests. The operator precedence
issue is back. Now, you need to have a slightly more complex notion of
precedence to work out the notation.
One solution to this is the lisp language's syntax. In lisp syntax,
everything is written inside a paren. The first element is the
function name, the rest is its arguments. So, sin(x) would be written
as (sin,x). (comma is used for separator) Our derivative example would
then be:
((derivative,f),3)
In this way, the syntax remains a pure nested form, and provides the
utmost precision.
Our formula example in fully nested syntax be:
(/,(+,(-,b),(√,(+,(^,b,2),(-,(*,4,a,c))))),(*,2,a))
We could change the comma separator to space. So, it would look like
this:
(/ (+ (- b) (√ (+ (^ b 2) (- (* 4 a c))))) (* 2 a))
(Note: actual lisp language's syntax is not 100% regular. Many of its
syntax does not have the form (a b c ...). See: Fundamental Problems
of Lisp.)
--------------------------------
Syntax Design for Computer Languages
Mixing Operator Syntax with Full Function Notation Syntax
In most computer language, they allow both the operator and full
function syntax. For example, you can write (sin(x))^2+3. (almost all
languages do this; e.g. C, C++, C#, Java, Pascal, Perl, Python, Ruby,
Bash, PowerShell, Haskell, OCaml. The only exception is lisps.)
(Though, almost all computer languages does not have a regular syntax,
in fact, non of any major computer lang has a syntax specification.
The closest one that has a somewhat regular and simple syntax grammar
is Mathematica. See: The Concepts and Confusions of Prefix, Infix,
Postfix and Fully Nested Notations ◇ Math Notations, Computer
Languages, and the “Form” in Formalism.)
Mixed form is normal, and most flexible. Because, not all functions
have a associated operator symbol. And, writing everything in nested
brackets is not readible and hard to write too. The question is, is it
possible to design a syntax, that is fully regular with a very simple
lexical grammar, and easy to read and write?
Xah ∑ http://xahlee.org/ ☄
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-06 19:20 ` Pascal J. Bourguignon
@ 2011-01-07 0:09 ` w_a_x_man
2011-01-07 12:04 ` Doug Hoffman
1 sibling, 0 replies; 84+ messages in thread
From: w_a_x_man @ 2011-01-07 0:09 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 6, 1:20 pm, "Pascal J. Bourguignon" <p...@informatimago.com>
wrote:
> so it becomes readable again and you can see there's a bug in the Forth
> expression. Since the syntax become suddenly much simplier, we don't
> need to prefix operators with 'F' anymore.
Since Forth is a low-level language, operators aren't overloaded.
"F+" adds two floats, "+" adds two integers.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-05 16:21 ` Andrew Haley
2011-01-05 21:29 ` Pascal J. Bourguignon
@ 2011-01-07 5:36 ` Xah Lee
2011-01-07 13:28 ` Andrew Haley
1 sibling, 1 reply; 84+ messages in thread
From: Xah Lee @ 2011-01-07 5:36 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 5, 8:21 am, Andrew Haley <andre...@littlepinkcloud.invalid>
wrote:
> Given that the article even manages to confuse Polish notation and
> Reverse Polish notation, I strongly recommend that everyone avoid it.
Hi man,
if you are not familiar with RPN, please see:
http://xahlee.org/prog/hp28s/hp28s.html
there are several free progs writting in RPN language. Among which, is
a music chord generating prog, could be fun to play with.
if you in college, you could show it to your friends and be
impressive.
Also, you might want to pickup emacs. In it, you can type 【Alt+x】,
Enter, then type “calc”, then you can play with RPN. My own pet peeve
about emacs calc is about its doc... due to that, i never actually
done much with it in the past decade of emacs-using other than simple
arithemitcs with Reals. Though, am aware of the fact that it can very
much do vector and matrix — even solving equations — arithemitcs, as
well as complex.
Xah
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 23:56 ` The Quiet Center
` (3 preceding siblings ...)
2011-01-02 14:07 ` Frank GOENNINGER
@ 2011-01-07 9:41 ` w_a_x_man
2011-01-09 10:41 ` How to improve the readability of (any) LISP or any highlevelfunctional " WJ
4 siblings, 1 reply; 84+ messages in thread
From: w_a_x_man @ 2011-01-07 9:41 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 5:56 pm, The Quiet Center <thequietcen...@gmail.com> wrote:
> How would you code this simple list compression problem in Ruby:
>
> 1.08 (**) Eliminate consecutive duplicates of list elements.
> If a list contains repeated elements they should be replaced with
> a single copy of the element. The order of the elements should not be
> changed.
>
> Example:
> ?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
> X = [a,b,c,a,d,e]
(defun compress (stuff)
(mapcon #'(lambda (x)
(if (and (> (length x) 1) (eql (car x) (cadr x)))
nil
(list (car x))))
stuff))
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-06 22:59 ` Xah Lee
@ 2011-01-07 11:47 ` Jan Burse
2011-01-21 10:03 ` rupertlssmith
0 siblings, 1 reply; 84+ messages in thread
From: Jan Burse @ 2011-01-07 11:47 UTC (permalink / raw)
To: help-gnu-emacs
Hi
This is quite funny to write a tractate about operator definitions
to comp.lang.prolog. Prolog has already for some time operator
definitions. But some other programming language do have also.
Best Regards
See also:
http://cs.union.edu/~striegnk/learn-prolog-now/html/node82.html#sec.l9.operators
from http://www.learnprolognow.org/
Xah Lee schrieb:
> On Jan 5, 6:58 am, Xah Lee<xah...@gmail.com> wrote:
>> On Dec 31 2010, 11:04 pm, girosenth<girose...@india.com> wrote:
>>
>>> How to improve the readability of (any) LISP or any highlevel
>>> functional language to the level of FORTH ?
>
> some basics that might be helpful.
>
> 〈What's Function, What's Operator?〉
> http://xahlee.org/math/function_and_operators.html
>
> --------------------------------------------------
> What's Function, What's Operator?
>
> Xah Lee, 2010-12-14, 2011-01-06
>
> Typically, we understand what “function” and “operator” mean, but
> programer may have a hard time explaining them, and mathematician may
> never thought about it. Here, we clarify a bit on the meaning of the
> word “function” and “operator”, their context, their relation.
>
> --------------------------------
> Function is a Mathematical Concept
>
> Function you probably understand. A function takes a input, and output
> a value for a given input. The inputs are called “parameters”. A
> specific set of input is called “arguments”. The number of parameters
> of a function is called the function's “arity”. So, for example, the
> function “sin” has arity 1. A constant, such as 35, π, can be
> considered as functions of no parameter, so they are functions of
> arity 0. A function of 2 parameters, such as f(x,y) := x+y has arity
> 2.
>
> Function is a mathematical concept. Viewed in another way, it's a map
> from one space (aka set) to another.
>
> --------------------------------
> Operator is About Notation
>
> A operator, is less of a mathematical concept, but more of a concept
> of notation. Or, in computer language contexts, a element of syntax. A
> “operator” is a symbol (or symbols) that are written to indicate
> operations. For example, we write 1+2, the “+” is a operator, and the
> “1” and “2” are its “operands”. Mathematically, operator is a function
> that acts on its operands. The operands are the arguments of the
> function.
>
> --------------------------------
> Binary Operators
>
> Typically, operators takes 2 arguments, the left and right of the
> symbol. e.g. 2×3, 3/4, 2^3, union {3,4}∪{2,4,1}, etc.
>
> --------------------------------
> Unary Operators
>
> But there are also 1-argument operators. For example the minus sign
> -3, and the logical not ¬ sign, the factorial 3!, square root √3.
>
> --------------------------------
> Multi-symbol Operators
>
> Operators can also involve other forms with more symbols. For example,
> the absolute sign |-3|, floor ⌊3.8⌋ uses a bracket, summation ∑ takes
> 4 arguments, a expression, a variable, and start and end values. The
> anti-derivative (aka indefinite integral) ∫ takes 2 arguments, a
> expression and a symbol. In traditional notation, the integration
> operator involves 2 symbols, ∫ and ⅆ. For example, we write ∫ sin(x)
> ⅆx .
>
> --------------------------------
> Implicit Operators
>
> Operator can be a bit complicated. For example -3 can be interpreted
> in several ways. We can think of the minus sign as unary operator
> acting on the argument 3. So, mathematically, it is a function of 1
> arity that returns the addictive inverse of the element 3. Or, we can
> interprete it as one single entity, a element of Reals denoted -3.
> When we write 3-2, the ways to interprete it gets a bit more complex.
> One way to think of it as a notation shorthand for 3 + (-2). The -2
> part can be thought of as before. Another way is to think of - as a
> binary operator on 3 and 2, but this seemingly simple interpretation
> is a bit complex. Because, what is math definition of the minus binary
> function? I'm not sure how it can be defined in terms of algebra
> without ultimately thinking of it as additon of 2 elements, one being
> a addictive inverse. The other way is to think of it as a real line,
> moving the first argument to the left by a distance of the second
> argument. Of course ultimately these are equivalent, but i can't think
> of a simple, direct, interpretation that can serve as a math
> foundation. Also, this is directly related to how does one interprete
> division, such as 3/2.
>
> The multiplication operator also gets complicated. For example, when
> we write 3 x, it usually means 3*x. The space acts as implicit
> multiplication sign. But when we write 3 +2, the space there has no
> significance. When we write 3x, even there is no space nor any
> operator, but we mean 3*x. As a computer language syntax based on
> traditional notation, the parsing rule is not trivial.
> Operator Stickiness
>
> There's also the concept of “operator stickiness” (aka “operator
> precendence”) at work that makes expressions with operators more
> concise. When we write3△4▲5, how do you know it's (3△4)▲5 or 3△(4▲5)?
> The concept of operator stickiness is needed to resolve that.
> Otherwise, you'll need to always write 3+(4*5) instead of the simpler
> 3+4*5. But this again, also introduced more complexity. When you have
> a expression of tens of different operators, it becomes a problem of
> remembering the stickiness grammar for each operator. (in practice,
> when you are not sure about the procedence, you usually just use
> explicit priority indicator by parens. This often happens in
> programing with logic operators (e.g. and&&, or ||, not !.)
> Forgetting Operator Precedence is a common error in programing. In
> written math for human communication, it is prone to
> miscommunication.)
>
> --------------------------------
> Operator is tied to Notation
>
> Because the concept of “operator” more has to do with syntax and
> notation, and when considering traditional math notation of writing in
> “2-dimensions”, also the fact that traditional math notation has a lot
> ambiguities, it gets a bit complicated and not as imprecise as we
> like. (See: The Problems of Traditional Math Notation)
>
> Mathematically, operator and function are the same thing.
>
> Math function in traditional notation has the form e.g. sin(x),
> f(x,y), where the things inside the paren are its parameter/arguments,
> and function name is placed to the left.
>
> Operators are useful because writing everything out in full function
> notation gets very cumbersome and hard to read. For example, we write
> 3+4*5 instead of plus(3,times(4,5)) or +(3,*(4,5)).
>
> Here's a example of traditional notation using operators:
>
> -b+√(b^2-4 a c)/(2 a)
>
> If you don't allow space as implicit multiplication sign, then you
> have to write:
>
> -b+√((b^2)-4*a*c)/(2*a)
>
> If you don't allow the the concept of operator precedence, then you
> have to write:
>
> (-b)+(√((b^2)-((4*a)*c))/(2*a))
>
> If you prefer the structural clarity of the traditional function
> notation f(x), you have to write:
>
> /(+(-(b),√(+(^(b,2),-(*(4,a,c))))),*(2,a))
>
> If you prefer words than symbols, as traditionally practiced when
> writing out functions, you have to write:
>
> divide(add(minus(b),sqrt(add(power(b,
> 2),minus(times(4,a,c))))),times(2,a))
>
> The notation using operators is much concise, readable, but at the
> cost of relatively complex lexical grammar. The full functional
> notation is precise, grammatically simple, but difficult to read.
>
> In math context, it's best to think of functions instead of operator,
> and sometimes also use a uniform function notation, where all
> arguments are explicitly indicated in one uniform way.
>
> Here's what Wikipedia has to say about operators: Operation
> (mathematics). Quote:
>
> An operation ω is a function of the form ω : X1 × … × Xk → Y. The
> sets Xj are called the domains of the operation, the set Y is called
> the codomain of the operation, and the fixed non-negative integer k
> (the number of arguments) is called the type or arity of the
> operation.
>
> Note that it doesn't really speaks of “operators”, but speaks of
> “operations”, and flatly defines operation as a function.
>
> --------------------------------
> Traditional Function Notation sin(x) Isn't Perfect
>
> Note that, even the functional notation such as sin(x), isn't perfect.
> Problem of Functions Returning Functions
>
> Normally, with full function notation, you'd expect that execution
> order of operations clearly corresponds to the nesting structure. For
> example, in our example before:
>
> divide(add(minus(b),sqrt(add(power(b,
> 2),minus(times(4,a,c))))),times(2,a))
>
> The inner-most parts are evaluated first.
>
> But there's a problem when a function returns a function. For example,
> the derivative takes a function and returns a function. We might
> write:
>
> derivative(f)
>
> Now, if we want to evaluate the result at 3, then we might write:
>
> derivative(f)(3)
>
> You can see that the notation no longer nests. The operator precedence
> issue is back. Now, you need to have a slightly more complex notion of
> precedence to work out the notation.
>
> One solution to this is the lisp language's syntax. In lisp syntax,
> everything is written inside a paren. The first element is the
> function name, the rest is its arguments. So, sin(x) would be written
> as (sin,x). (comma is used for separator) Our derivative example would
> then be:
>
> ((derivative,f),3)
>
> In this way, the syntax remains a pure nested form, and provides the
> utmost precision.
>
> Our formula example in fully nested syntax be:
>
> (/,(+,(-,b),(√,(+,(^,b,2),(-,(*,4,a,c))))),(*,2,a))
>
> We could change the comma separator to space. So, it would look like
> this:
>
> (/ (+ (- b) (√ (+ (^ b 2) (- (* 4 a c))))) (* 2 a))
>
> (Note: actual lisp language's syntax is not 100% regular. Many of its
> syntax does not have the form (a b c ...). See: Fundamental Problems
> of Lisp.)
>
> --------------------------------
> Syntax Design for Computer Languages
> Mixing Operator Syntax with Full Function Notation Syntax
>
> In most computer language, they allow both the operator and full
> function syntax. For example, you can write (sin(x))^2+3. (almost all
> languages do this; e.g. C, C++, C#, Java, Pascal, Perl, Python, Ruby,
> Bash, PowerShell, Haskell, OCaml. The only exception is lisps.)
>
> (Though, almost all computer languages does not have a regular syntax,
> in fact, non of any major computer lang has a syntax specification.
> The closest one that has a somewhat regular and simple syntax grammar
> is Mathematica. See: The Concepts and Confusions of Prefix, Infix,
> Postfix and Fully Nested Notations ◇ Math Notations, Computer
> Languages, and the “Form” in Formalism.)
>
> Mixed form is normal, and most flexible. Because, not all functions
> have a associated operator symbol. And, writing everything in nested
> brackets is not readible and hard to write too. The question is, is it
> possible to design a syntax, that is fully regular with a very simple
> lexical grammar, and easy to read and write?
>
> Xah ∑ http://xahlee.org/ ☄
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-06 19:20 ` Pascal J. Bourguignon
2011-01-07 0:09 ` w_a_x_man
@ 2011-01-07 12:04 ` Doug Hoffman
1 sibling, 0 replies; 84+ messages in thread
From: Doug Hoffman @ 2011-01-07 12:04 UTC (permalink / raw)
To: help-gnu-emacs
On 1/6/11 2:20 PM, Pascal J. Bourguignon wrote:
> Doug Hoffman<glidedog@gmail.com> writes:
>
>> 2) The following is one way (of many) to approach this in standard Forth:
>>
>> : quad f{ a b c -- root }
>> b FNEGATE b FDUP F* 4e a c F* F* F- FSQRT F+ 2e a F* F/
>> ;
>>
>> -2e 7e 15e quad f.
>> -1.500000
>>
>> Is it readable? Unless you're a Forther I would say no. But notice
>> the complete lack of parentheses and operator precedences to resolve.
>> Any competent Forther could quickly see exactly what is going on.
>
> Now, as a Forth programmer, ask yourself what you would have to do, to
> call an operator with a variable arity?
One way to handle a variable number of input parameters is to precede
them with a count. There is at least one ANS Forth word that does this.
I've seen the technique used a lot elsewhere in Forth code. Supplying
a "mark" is also something I've seen.
If I am going to apply a single operator to a list of many items, in
Forth I would likely put the items in a list, perhaps a list of objects
depending on the nature of the items, and then iterate over the list.
Just to be clear, so we don't get sidetracked on a Lisp vs Forth
tangent: I commented that I believed the Lisp example is somewhat
readable to someone unfamiliar with Lisp, Forth is not readable to
someone unfamiliar with Forth. The standard "Fortran/spreadsheet"
syntax version is the most readable for this example regardless of
language familiarity, again in my opinion.
[snip]
> (F/ (F* a 2e)
> (F+ (FSQRT (F- (F* c a 4e)
> (F* (FDUP (- b)))))))
>
> so it becomes readable again and you can see there's a bug in the Forth
> expression.
No, I can't see any bug in the Forth example. Could you point it out
more clearly?
-Doug
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-07 5:36 ` Xah Lee
@ 2011-01-07 13:28 ` Andrew Haley
2011-01-07 16:19 ` Xah Lee
0 siblings, 1 reply; 84+ messages in thread
From: Andrew Haley @ 2011-01-07 13:28 UTC (permalink / raw)
To: help-gnu-emacs
In comp.lang.forth Xah Lee <xahlee@gmail.com> wrote:
>
> On Jan 5, 8:21?am, Andrew Haley <andre...@littlepinkcloud.invalid>
> wrote:
>> Given that the article even manages to confuse Polish notation and
>> Reverse Polish notation, I strongly recommend that everyone avoid it.
>
> Hi man,
>
> if you are not familiar with RPN, please see:
>
> http://xahlee.org/prog/hp28s/hp28s.html
Thank you, Xah. If I ever forget about RPN, I'll be sure to come
straight to you for a refresher. In the meantime, I suggest you fix
that article.
Andrew.
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-07 13:28 ` Andrew Haley
@ 2011-01-07 16:19 ` Xah Lee
0 siblings, 0 replies; 84+ messages in thread
From: Xah Lee @ 2011-01-07 16:19 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 7, 5:28 am, Andrew Haley <andre...@littlepinkcloud.invalid>
wrote:
> In comp.lang.forth Xah Lee <xah...@gmail.com> wrote:
>
>
>
> > On Jan 5, 8:21?am, Andrew Haley <andre...@littlepinkcloud.invalid>
> > wrote:
> >> Given that the article even manages to confuse Polish notation and
> >> Reverse Polish notation, I strongly recommend that everyone avoid it.
>
> > Hi man,
>
> > if you are not familiar with RPN, please see:
>
> > http://xahlee.org/prog/hp28s/hp28s.html
>
> Thank you, Xah. If I ever forget about RPN, I'll be sure to come
> straight to you for a refresher. In the meantime, I suggest you fix
> that article.
thanks. corrected, with credit.
Xah
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevelfunctional language to the level of FORTH ?
2011-01-07 9:41 ` w_a_x_man
@ 2011-01-09 10:41 ` WJ
0 siblings, 0 replies; 84+ messages in thread
From: WJ @ 2011-01-09 10:41 UTC (permalink / raw)
To: help-gnu-emacs
w_a_x_man wrote:
> On Jan 1, 5:56 pm, The Quiet Center <thequietcen...@gmail.com> wrote:
>
> > How would you code this simple list compression problem in Ruby:
> >
> > 1.08 (**) Eliminate consecutive duplicates of list elements.
> > If a list contains repeated elements they should be replaced
> > with a single copy of the element. The order of the elements should
> > not be changed.
> >
> > Example:
> > ?- compress([a,a,a,a,b,c,c,a,a,d,e,e,e,e],X).
> > X = [a,b,c,a,d,e]
>
>
>
> (defun compress (stuff)
> (mapcon #'(lambda (x)
> (if (and (> (length x) 1) (eql (car x) (cadr x)))
> nil
> (list (car x))))
> stuff))
MAPCON works quite well for this.
Tweeked:
(defun compress (stuff)
(mapcon #'(lambda (x)
(if (and (rest x) (eql (first x) (second x)))
nil
(list (first x))))
stuff))
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
` (8 preceding siblings ...)
2011-01-05 14:58 ` Xah Lee
@ 2011-01-18 22:55 ` m_l_g3
2011-01-19 13:45 ` Doug Hoffman
2011-01-21 16:15 ` Jan Burse
9 siblings, 2 replies; 84+ messages in thread
From: m_l_g3 @ 2011-01-18 22:55 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 1, 10:04 am, girosenth <girose...@india.com> wrote:
> How to improve the readability of (any) LISP or any highlevel
> functional language to the level of FORTH ?
...
>
> How do you make it readable ?
...
>
> (f (g (h (j (k (l ops)))...)))
(e
(f
(g (h i)
(j k l)
)
(m (n o (p q))
(r (s t) u)
) ) )
The rule: if you don't see the closing paren moving the eyes down,
it's on the right.
But it either to the right or down, no other option.
Since closing parens are visually identical, there's no need to one
line per paren;
this is shown at the last line (yes, their visual and logical
orderings are different,
but they are identical parens otherwise worth only counting!).
> Is there a postfix functional language that also gets rid of parens
> and is not as primitive as FORTH or POSTSCRIPT ?
There is a prefix/infix one: Haskell with its ($) and (.) operators
and... well... monads.
As to Forth, you may try to layout control structures on the right,
as if RPN is not enough:
: MAX 2dup > if
drop else
nip then
;
: foo
10 0 do
i 3 mod 0= if
i . then loop
;
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-18 22:55 ` m_l_g3
@ 2011-01-19 13:45 ` Doug Hoffman
2011-01-21 16:15 ` Jan Burse
1 sibling, 0 replies; 84+ messages in thread
From: Doug Hoffman @ 2011-01-19 13:45 UTC (permalink / raw)
To: help-gnu-emacs
On 1/18/11 5:55 PM, m_l_g3 wrote:
> On Jan 1, 10:04 am, girosenth<girose...@india.com> wrote:
>> How to improve the readability of (any) LISP or any highlevel
>> functional language to the level of FORTH ?
>
> ...
>>
>> How do you make it readable ?
> ...
>>
>> (f (g (h (j (k (l ops)))...)))
>
> (e
> (f
> (g (h i)
> (j k l)
> )
> (m (n o (p q))
> (r (s t) u)
> ) ) )
>
> The rule: if you don't see the closing paren moving the eyes down,
> it's on the right.
> But it either to the right or down, no other option.
I would assume that Lispers would use a source editor that automatically
hilights corresponding parens (e.g., selct a left paren and the right
paren becomes bold or whatever) and checks for missing parens
automatically before compilation is attempted.
> As to Forth, you may try to layout control structures on the right,
> as if RPN is not enough:
>
> : MAX 2dup> if
> drop else
> nip then
> ;
I agree with vusual "aligning" for control words. But I would do it
differently (stack comment please!). The above suggests to me that ELSE
is consuming the result of the DROP and THEN is consuming the result of
the NIP.
Better, IMHO:
: MAX ( n1 n2 -- max )
2dup > IF drop
ELSE nip
THEN ;
Read in English as " <condition> iftrue DROP, otherwise NIP, then continue".
-Doug
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-07 11:47 ` Jan Burse
@ 2011-01-21 10:03 ` rupertlssmith
2011-01-21 16:08 ` Jan Burse
0 siblings, 1 reply; 84+ messages in thread
From: rupertlssmith @ 2011-01-21 10:03 UTC (permalink / raw)
To: help-gnu-emacs
On Jan 7, 11:47 am, Jan Burse <janbu...@fastmail.fm> wrote:
> This is quite funny to write a tractate about operator definitions
> to comp.lang.prolog. Prolog has already for some time operator
> definitions.
Yes, and you can define infix operators with it too! Making your code
nice and easy to read, and avoiding all this Neanderthal RPN stuff. I
guess some people just like to do things the hard way?
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-21 10:03 ` rupertlssmith
@ 2011-01-21 16:08 ` Jan Burse
2011-01-21 21:43 ` D. J. Penton
0 siblings, 1 reply; 84+ messages in thread
From: Jan Burse @ 2011-01-21 16:08 UTC (permalink / raw)
To: help-gnu-emacs
rupertlssmith@googlemail.com schrieb:
> On Jan 7, 11:47 am, Jan Burse<janbu...@fastmail.fm> wrote:
>> This is quite funny to write a tractate about operator definitions
>> to comp.lang.prolog. Prolog has already for some time operator
>> definitions.
>
> Yes, and you can define infix operators with it too! Making your code
> nice and easy to read, and avoiding all this Neanderthal RPN stuff. I
> guess some people just like to do things the hard way?
Reminds me of the HP-41C
http://en.wikipedia.org/wiki/HP-41C
But still the Haskell people have for example even put more
into operators, than Prolog did. You can write things like:
(+ 4)
Or
x $ y z
Right? I guess the current lack of a concept of lambda
expressions in Prolog is the cause.
Bye
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-18 22:55 ` m_l_g3
2011-01-19 13:45 ` Doug Hoffman
@ 2011-01-21 16:15 ` Jan Burse
1 sibling, 0 replies; 84+ messages in thread
From: Jan Burse @ 2011-01-21 16:15 UTC (permalink / raw)
To: help-gnu-emacs
I am voting for RPL:
http://en.wikipedia.org/wiki/RPL_(programming_language)
m_l_g3 schrieb:
> On Jan 1, 10:04 am, girosenth<girose...@india.com> wrote:
>> How to improve the readability of (any) LISP or any highlevel
>> functional language to the level of FORTH ?
>
> ...
>>
>> How do you make it readable ?
> ...
>>
>> (f (g (h (j (k (l ops)))...)))
>
> (e
> (f
> (g (h i)
> (j k l)
> )
> (m (n o (p q))
> (r (s t) u)
> ) ) )
>
> The rule: if you don't see the closing paren moving the eyes down,
> it's on the right.
> But it either to the right or down, no other option.
>
> Since closing parens are visually identical, there's no need to one
> line per paren;
> this is shown at the last line (yes, their visual and logical
> orderings are different,
> but they are identical parens otherwise worth only counting!).
>
>
>
>> Is there a postfix functional language that also gets rid of parens
>> and is not as primitive as FORTH or POSTSCRIPT ?
>
> There is a prefix/infix one: Haskell with its ($) and (.) operators
> and... well... monads.
>
> As to Forth, you may try to layout control structures on the right,
> as if RPN is not enough:
>
> : MAX 2dup> if
> drop else
> nip then
> ;
>
> : foo
> 10 0 do
> i 3 mod 0= if
> i . then loop
> ;
>
>
^ permalink raw reply [flat|nested] 84+ messages in thread
* Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?
2011-01-21 16:08 ` Jan Burse
@ 2011-01-21 21:43 ` D. J. Penton
0 siblings, 0 replies; 84+ messages in thread
From: D. J. Penton @ 2011-01-21 21:43 UTC (permalink / raw)
To: GNU Emacs List
Ahhhh...the world of programming languages is beautiful!
I LOVE Lisp, Scheme, Haskell, OCaml, C, Objective-C, Perl, and java. Really! I love them all. If I were to learn Ruby or Python I would probably love them too. I have a hard time loving C++ , but I'll bet I could learn to love it. Soon I shall try my hand at Prolog and Forth.
My choice of languages depends on what I am trying to program. I am not equally expert in all of the languages I use, but they all have their uses. My deepest love is for Common Lisp. But the others are very, very good too.
In past times I used VIM. Now I use emacs. I love them both. I also adore Xcode, Visual Studio, Netbeans, and Eclipse. Flowers in a garden!
When I encounter a flame war or debate about programming languages, I mentally gather my dear bouquet of languages around me and bask in the delight of choice.
Best wishes to all,
- Dave -
^ permalink raw reply [flat|nested] 84+ messages in thread
end of thread, other threads:[~2011-01-21 21:43 UTC | newest]
Thread overview: 84+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-01-01 7:04 How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? girosenth
2011-01-01 11:39 ` Elena
2011-01-01 14:15 ` Pascal J. Bourguignon
2011-01-01 16:08 ` Nathan
2011-01-01 18:05 ` Jan Burse
2011-01-01 23:56 ` The Quiet Center
2011-01-02 1:10 ` Jan Burse
2011-01-02 3:45 ` LanX
2011-01-02 4:04 ` LanX
2011-01-02 5:36 ` Nathan
2011-01-02 6:46 ` Paul Rubin
2011-01-02 15:01 ` LanX
2011-01-02 15:14 ` Jerome Baum
2011-01-02 21:21 ` Paul Rubin
2011-01-02 7:14 ` w_a_x_man
2011-01-02 6:59 ` w_a_x_man
2011-01-03 15:22 ` LanX
2011-01-02 14:07 ` Frank GOENNINGER
2011-01-07 9:41 ` w_a_x_man
2011-01-09 10:41 ` How to improve the readability of (any) LISP or any highlevelfunctional " WJ
2011-01-03 10:29 ` How to improve the readability of (any) LISP or any highlevel functional " Didier Verna
2011-01-03 13:05 ` Tim Harig
2011-01-04 4:49 ` rusi
2011-01-04 5:39 ` D Herring
2011-01-04 8:02 ` Tim Harig
2011-01-04 9:09 ` Nicolas Neuss
2011-01-04 10:00 ` Tim Bradshaw
2011-01-04 12:21 ` Tim Harig
2011-01-04 12:23 ` Tim Bradshaw
2011-01-04 13:33 ` Tim Harig
2011-01-04 12:41 ` Tamas K Papp
2011-01-04 23:32 ` Tim X
2011-01-05 1:35 ` [OT] LISP community advocacy [was Re: How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ?] Tim Harig
2011-01-05 9:52 ` How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? Tim Bradshaw
2011-01-04 6:24 ` Pascal J. Bourguignon
2011-01-04 15:43 ` Raffael Cavallaro
2011-01-04 10:18 ` Didier Verna
2011-01-01 22:50 ` girosenth
2011-01-02 21:11 ` Thien-Thi Nguyen
2011-01-03 16:21 ` José A. Romero L.
2011-01-03 18:03 ` jacko
2011-01-02 23:45 ` Chip Eastham
2011-01-01 18:27 ` How to improve the readability of Steve Revilak
2011-01-01 19:22 ` How to improve the readability of (any) LISP or any highlevel functional language to the level of FORTH ? prad
2011-01-01 23:56 ` Pascal Costanza
2011-01-02 5:39 ` D Herring
2011-01-02 14:17 ` Frank GOENNINGER
2011-01-02 14:53 ` Jerome Baum
2011-01-02 14:58 ` LanX
2011-01-02 17:55 ` Bernd Paysan
2011-01-03 18:07 ` jacko
2011-01-02 12:59 ` Doug Hoffman
2011-01-02 19:14 ` w_a_x_man
2011-01-03 5:20 ` Elizabeth D Rather
2011-01-03 10:48 ` MarkWills
2011-01-03 15:13 ` LanX
2011-01-03 18:20 ` jacko
2011-01-03 18:22 ` jacko
2011-01-03 10:18 ` Didier Verna
2011-01-04 6:47 ` pineapple
2011-01-04 14:14 ` P.M.Lawrence
2011-01-05 14:58 ` Xah Lee
2011-01-05 16:21 ` Andrew Haley
2011-01-05 21:29 ` Pascal J. Bourguignon
2011-01-06 8:57 ` Jonathan Groll
2011-01-07 5:36 ` Xah Lee
2011-01-07 13:28 ` Andrew Haley
2011-01-07 16:19 ` Xah Lee
2011-01-05 17:59 ` Elena
2011-01-05 20:13 ` Xah Lee
2011-01-05 21:42 ` Pascal J. Bourguignon
2011-01-06 13:38 ` Doug Hoffman
2011-01-06 19:20 ` Pascal J. Bourguignon
2011-01-07 0:09 ` w_a_x_man
2011-01-07 12:04 ` Doug Hoffman
2011-01-06 22:59 ` Xah Lee
2011-01-07 11:47 ` Jan Burse
2011-01-21 10:03 ` rupertlssmith
2011-01-21 16:08 ` Jan Burse
2011-01-21 21:43 ` D. J. Penton
2011-01-18 22:55 ` m_l_g3
2011-01-19 13:45 ` Doug Hoffman
2011-01-21 16:15 ` Jan Burse
-- strict thread matches above, loose matches on Subject: below --
2011-01-02 16:50 Drew Adams
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).