What is wrong with my code(bottom of post)?  I keep getting this
error.  Line 24 is "(get-cell [x r c] 1))" in the Matrix deftype and
36 is "(print (get-cell one r c) " "))" in the first nested "doseq"s.
I'm on Windows 7 with Clojure 1.2.

Exception in thread "main" java.lang.IllegalArgumentException:
Argument is not an array (core.clj:0)
        at clojure.lang.Compiler.eval(Compiler.java:5440)
        at clojure.lang.Compiler.load(Compiler.java:5857)
        at clojure.lang.Compiler.loadFile(Compiler.java:5820)
        at clojure.main$load_script.invoke(main.clj:221)
        at clojure.main$script_opt.invoke(main.clj:273)
        at clojure.main$main.doInvoke(main.clj:354)
        at clojure.lang.RestFn.invoke(RestFn.java:409)
        at clojure.lang.Var.invoke(Var.java:365)
        at clojure.lang.AFn.applyToHelper(AFn.java:163)
        at clojure.lang.Var.applyTo(Var.java:482)
        at clojure.main.main(main.java:37)
Caused by: java.lang.IllegalArgumentException: Argument is not an
array
        at java.lang.reflect.Array.get(Native Method)
        at clojure.core$aget.invoke(core.clj:2994)
        at clojure.lang.AFn.applyToHelper(AFn.java:165)
        at clojure.lang.RestFn.applyTo(RestFn.java:133)
        at clojure.core$apply.invoke(core.clj:542)
        at clojure.core$aget.doInvoke(core.clj:2996)
        at clojure.lang.RestFn.invoke(RestFn.java:443)
        at com.curious.scratch.core.Matrix2D.get_cell(core.clj:24)
        at com.curious.scratch.core$eval122.invoke(core.clj:36)
        at clojure.lang.Compiler.eval(Compiler.java:5424)
        ... 10 more

(def float-array-class (class (float-array 1)))
(defprotocol Matrix
  (matrix-data [x])
  (matrix-height [x])
  (matrix-width [x])
  (matrix-add [x] [x y] [x y & args])
  (get-cell [x r] [x r c]))

(deftype Matrix2D [data height width]
  Matrix
  (matrix-data [x] data)
  (matrix-height [x] height)
  (matrix-width [x] width)
  (matrix-add [x] x)
  (matrix-add [x y]
              (let [x-data (matrix-data x)
                    y-data (matrix-data y)
                    z-data (amap ^floats x-data index z-data (+ (aget
^floats x-data index) (aget ^floats y-data index)))]
                (Matrix2D. z-data (matrix-width x) (matrix-height
x))))
  (matrix-add [x y & args] (reduce matrix-add (matrix-add x y) args))
  (get-cell [x r] (get-cell x r 0))
  (get-cell [x r c] 1))

(defn matrix [data height width]
  (if (instance? float-array-class data)
    (Matrix2D. data height width)
    (Matrix2D. (float-array data) height width)))

(def one (matrix (range 10) 5 2))
(def two (matrix-add one one))

(doseq [r (range (matrix-height one))]
  (doseq [c (range (matrix-width one))]
    (print (get-cell one r c) " "))
  (println))

(doseq [r (range (matrix-height two))]
  (doseq [c (range (matrix-width two))]
    (print (get-cell two r c) " "))
  (println))

-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en

Reply via email to