From: Damien Mattei <damien.mattei@gmail.com>
To: "Linus Björnstam" <linus.internet@fastmail.se>,
"Jean-Paul Roy" <jean-paul.roy@unice.fr>
Cc: guile-user <guile-user@gnu.org>
Subject: Re: define anywhere
Date: Sat, 12 Jun 2021 01:43:29 +0200 [thread overview]
Message-ID: <CADEOadeaT9J67QpsxdL79nS8CLK8e8vB0rw5YxMfyAahoE9WVA@mail.gmail.com> (raw)
In-Reply-To: <d6fb2866-c707-4c76-aace-648bfbe42a51@www.fastmail.com>
hello Linus,
finally i tested your code with my program and it works.
define worked in if in ssigma-sol-approx
( in
*Preview:*
;; (load "SssRec.scm")
;;(use-modules (syntax define));;(use-modules
(guile/define))(use-modules (guile define))
(include "first-and-rest.scm")(include "list.scm")(include
"postfix.scm")(include "let.scm")(include "definition.scm")(include
"guile/array.scm")(include "block.scm")
;; if data are disordered the algo works also
;; scheme@(guile-user)> (define L-init '(1 3 4 16 17 64 256 275 723
889 1040 1041 1093 1111 1284 1344 1520 2027 2734 3000 4285 5027));;
scheme@(guile-user)> (start-ssigma-sol-approx-linus L-init 19836);;
$1 = (1 3 4 16 17 256 275 723 1040 1041 1284 1344 1520 3000 4285
5027)(define (start-ssigma-sol-approx-linus L t) ;; Sub Set Sum
problem (find solution or approximation)
;; { } are for infix notation as defined in SRFI 105
;; <+ and := are equivalent to (define var value)
{ best-sol <+ (lambda (L1 L2)
{s1 <+ (apply + L1)}
{s2 <+ (apply + L2)}
(if {(abs {t - s1}) <= (abs {t - s2})}
L1
L2)) }
;; := is the same macro as <+
{ best-sol3 := (lambda (L1 L2 L3)
{L22 <+ (best-sol L2 L3)}
(best-sol L1 L22)) }
{ ssigma-sol-approx <+ (lambda (L)
;; def is a macro for declared but unasigned variable, it is
same as (define var '())
;;(def c)
;;(def R)
(if (null? L)
L
($ (define c (first L)) ;; $ = begin
(if {c = t}
(list c) ;; c is the solution
($ (define R (rest L))
(if {c > t}
(best-sol (list c) (ssigma-sol-approx R)) ;; c is to big to
be a solution but could be an approximation
;; c < t at this point, 3 possibilities :
;; c is the best solution
;; c is part of the solution or his approximation
;; or c is not part of solution or his approximation
(best-sol3 (list c) ;; c is the best solution
;; c part of solution or is approximation
(cons c (start-ssigma-sol-approx-linus R {t - c})) ;; we have
to find a solution or an approximation for t-c now
;; c is not part of solution or his approximation
(ssigma-sol-approx R)))))))) }
;; start the function
(ssigma-sol-approx L))
without you module, my solution was:
https://github.com/damien-mattei/library-FunctProg/blob/master/SssRec.scm
*Preview:*
;; scheme@(guile-user)> (define L-init '(1 3 4 16 17 64 256 275 723
889 1040 1041 1093 1111 1284 1344 1520 2027 2734 3000 4285 5027));;
scheme@(guile-user)> (start-ssigma-sol-approx-basic L-init 19836);;
$1 = (1 3 4 16 17 256 275 723 1040 1041 1284 1344 1520 3000 4285
5027);; scheme@(guile-user)> (apply + $1);; $2 = 19836(define
(start-ssigma-sol-approx-basic L t) ;; Sub Set Sum problem (find
solution or approximation)
;; { } are for infix notation as defined in SRFI 105
;; <+ and := are equivalent to (define var value)
{ best-sol <+ (lambda (L1 L2)
{s1 <+ (apply + L1)}
{s2 <+ (apply + L2)}
(if {(abs {t - s1}) <= (abs {t - s2})}
L1
L2)) }
;; := is the same macro as <+
{ best-sol3 := (lambda (L1 L2 L3)
{L22 <+ (best-sol L2 L3)}
(best-sol L1 L22)) }
{ ssigma-sol-approx <+ (lambda (L)
;; def is a macro for declared but unasigned variable, it is
same as (define var '())
(def c)
(def R)
(if (null? L)
L
($ {c <- (first L)} ;; $ = begin
(if {c = t}
(list c) ;; c is the solution
($ {R <- (rest L)}
(if {c > t}
(best-sol (list c) (ssigma-sol-approx R)) ;; c is to big to
be a solution but could be an approximation
;; c < t at this point, 3 possibilities :
;; c is the best solution
;; c is part of the solution or his approximation
;; or c is not part of solution or his approximation
(best-sol3 (list c) ;; c is the best solution
;; c part of solution or is approximation
(cons c (start-ssigma-sol-approx-basic R {t - c})) ;; we have
to find a solution or an approximation for t-c now
;; c is not part of solution or his approximation
(ssigma-sol-approx R)))))))) }
;; start the function
(ssigma-sol-approx L))
just had a few problem making Guile 3.0 find the module from an other sub
directory, but not the falt of you module, my config i think?
Damien
On Sat, Jun 5, 2021 at 5:24 PM Linus Björnstam <linus.internet@fastmail.se>
wrote:
> I implemented this hack before guile 3 got defines in function bodies:
> https://hg.sr.ht/~bjoli/guile-define
>
> Even I guile 3 it allows a more liberal placement of define, but it won't
> work for things like bodies of imported macros (like match)
> --
> Linus Björnstam
>
> On Sat, 5 Jun 2021, at 00:27, Damien Mattei wrote:
> > hello,
> > i'm was considering that i want to be able to define a variable
> > anywhere in
> > code, the way Python do. Few scheme can do that (Bigloo i know)
> > ( the list here is not exact:
> >
> https://www.reddit.com/r/scheme/comments/b73fdz/placement_of_define_inside_lambda_bodies_in/
> > )
> > is it possible in guile to do it? i do not know, so could it be added
> > to
> > the language specification for future release?
> >
> > regards,
> > Damien
> >
>
prev parent reply other threads:[~2021-06-11 23:43 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-04 22:27 define anywhere Damien Mattei
2021-06-05 2:10 ` Taylan Kammer
2021-06-05 8:50 ` Dr. Arne Babenhauserheide
2021-06-05 15:23 ` Linus Björnstam
2021-06-06 8:09 ` Linus Björnstam
2021-06-06 12:02 ` Dr. Arne Babenhauserheide
2021-06-06 13:36 ` Linus Björnstam
2021-06-06 16:45 ` Dr. Arne Babenhauserheide
2021-06-11 8:08 ` Damien Mattei
[not found] ` <CADEOadcwk1D9of6C1owQQSqFNRvUmA=wJKSngySbGsfdDUzoMw@mail.gmail.com>
[not found] ` <28842df5-d82b-4819-b7ad-2148265f7a83@www.fastmail.com>
2021-06-09 9:29 ` Damien Mattei
2021-06-09 10:11 ` Linus Björnstam
2021-06-11 8:15 ` Damien Mattei
2021-06-11 8:07 ` Damien Mattei
2021-06-11 23:43 ` Damien Mattei [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/guile/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CADEOadeaT9J67QpsxdL79nS8CLK8e8vB0rw5YxMfyAahoE9WVA@mail.gmail.com \
--to=damien.mattei@gmail.com \
--cc=guile-user@gnu.org \
--cc=jean-paul.roy@unice.fr \
--cc=linus.internet@fastmail.se \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).