[Gsll-devel] cannot compile lu.lisp's invert-matrix example

Mirko Vukovic mirko.vukovic at gmail.com
Tue Aug 5 17:29:15 UTC 2008


Hello Liam (& others)

I am using SBCL 1.014 and GSL with a timestamp from march of this year.

I am trying to use the lu.lisp library and cannot compile the invert-matrix
example.  The error message is "deleting unreachable code" at the (letm.
If I comment out the calls to lu-... and (data-inv) and do instead (data
mmat), then it will compile.

I am including the transcript at the end of this message.

Any clue as to what could be wrong?

Thanks,

Mirko


CL-USER> (in-package :gsl)
#<PACKAGE "GSLL">
GSL> (defun invert-matrix (mat)
  "Invert the matrix."
  (letm ((mmat (matrix-double-float mat))
     (dim (array-dimension mat 0))
     (per (permutation dim))
     (inv (matrix-double-float dim dim)))
    (lu-decomp mmat per)
    (lu-invert mmat per inv)
    (data inv)))
; in: LAMBDA NIL
;     (GSLL:LETM
;    ((GSLL::MMAT (GSLL:MATRIX-DOUBLE-FLOAT GSLL::MAT))
;     (GSLL::DIM (ARRAY-DIMENSION GSLL::MAT 0))
;     (GSLL::PER (GSLL:PERMUTATION GSLL::DIM))
;     (GSLL::INV (GSLL:MATRIX-DOUBLE-FLOAT GSLL::DIM GSLL::DIM)))
;    (GSLL:LU-DECOMP GSLL::MMAT GSLL::PER)
;    (GSLL:LU-INVERT GSLL::MMAT GSLL::PER GSLL::INV) (GSLL:DATA GSLL::INV))
; --> LET* UNWIND-PROTECT FLET BLOCK MULTIPLE-VALUE-BIND
; --> MULTIPLE-VALUE-CALL BLOCK SB-C::%WITHIN-CLEANUP RETURN-FROM PROGN
; --> UNLESS COND IF PROGN SETF LET*
; ==>
;   GSLL::PER
;
; note: deleting unreachable code

; ==>
;   GSLL::INV
;
; note: deleting unreachable code
;
; compilation unit finished
;   printed 2 notes
STYLE-WARNING: redefining INVERT-MATRIX in DEFUN
INVERT-MATRIX
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mailman.common-lisp.net/pipermail/gsll-devel/attachments/20080805/31e0992e/attachment.html>


More information about the gsll-devel mailing list