0

我创建了一个应该具有类型词法变量的函数ARRAY

(defun give-rank-vec (dir-1 dir-2 file-1 file-2)
  (let* ((cm-size (array-dimension (Swc (make-ff-array dir-1 file-1)
                                        (make-ff-array dir-2 file-2)) 
                                    0))
         (rank-dump-vec (make-array `(,cm-size)))     
         (Swc' (Swc (make-ff-array dir-1 file-1)
                    (make-ff-array dir-2 file-2))) 
         (Sbc' (Sbc (make-ff-array dir-1 file-1) 
                    (make-ff-array dir-2 file-2))))
    (dotimes (j cm-size) 
      (setf (svref rank-dump-vec j) 
            (/ (get-element Sbc' j j) 
               (get-element Swc' j j))))   
   rank-dump-vec))  



(defun Sbc (cmatrix1 cmatrix2)
  (add-matrices (Si cmatrix1) 
                (Si cmatrix2)))


(defun add-matrices (A B)
  (let ((C (make-array (array-dimensions A))))
    (dotimes (i (array-dimension A 0))
      (dotimes (j (array-dimension A 1))
        (setf (aref C i j) (+ (aref A i j) (aref B i j)))))
    C))

但是,当我对这个函数进行 SLIME 时,我得到了错误:

The value
  (SBC (MAKE-FF-ARRAY DIR-1 FILE-1)
       (MAKE-FF-ARRAY DIR-2 FILE-2))
is not of type
  ARRAY.
   [Condition of type TYPE-ERROR]

Swc工作正常,因为它似乎返回了一个数组- 但是Sbc没有 - 我Sbc用小型和巨大的(wc 13000 65000 627677)平面文件进行了测试,并且在 SLIME 中调用它时返回了一个数组,但是在这种情况下它不起作用。表达式似乎写对let*了-我不确定我在这里做错了什么。

4

1 回答 1

2

单引号字符'是 Common Lisp 中的终止宏字符。请参见Hyperspec 中的图 2-7

如果你想在一个符号中使用这个字符,你必须用反斜杠或一对竖线来引用它:

CL-USER 65 > '(quote-at-the-end-\' |QUOTE-AT-THE-END-'| quote-at-the-end-|'|)
(QUOTE-AT-THE-END-\' QUOTE-AT-THE-END-\' QUOTE-AT-THE-END-\')
于 2013-02-04T18:22:36.560 回答