File: test259.thp

package info (click to toggle)
theme-d 7.2.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 21,036 kB
  • sloc: lisp: 9,625; sh: 5,321; makefile: 715; ansic: 477
file content (70 lines) | stat: -rw-r--r-- 1,990 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
;; -*-theme-d-*-

;; Copyright (C) 2014  Tommi Höynälänmaa
;; Distributed under GNU General Public License version 3,
;; see file doc/GPL-3.

;; Expected results: translation and running OK


(define-proper-program (tests test259)


  (import (standard-library core)
	  (standard-library complex)
	  (standard-library matrix)
	  (standard-library console-io))


  (define-param-virtual-method display-matrix (%number)
		       (((mx (:matrix %number)))
			<none>
			(nonpure))
    (let ((rows (field-ref mx 'rows))
	  (columns (field-ref mx 'columns)))
      (do ((i1 <integer> 0 (+ i1 1))) ((>= i1 rows))
	(begin
	  (do ((i2 <integer> 0 (+ i2 1))) ((>= i2 columns))
	    (console-display (matrix-ref mx i1 i2))
	    (if (< i2 (- columns 1))
		(console-display-string " ")))
	  (console-newline)))))


  (define-param-virtual-method display-matrix (%number)
		       (((mx (:diagonal-matrix %number)))
			<none>
			(nonpure))
    (let ((rows (field-ref mx 'len))
	  (columns (field-ref mx 'len)))
      (do ((i1 <integer> 0 (+ i1 1))) ((>= i1 rows))
	(begin
	  (do ((i2 <integer> 0 (+ i2 1))) ((>= i2 columns))
	    (console-display (matrix-ref mx i1 i2))
	    (if (< i2 (- columns 1))
		(console-display-string " ")))
	  (console-newline)))))


  (define-param-virtual-method display-matrix-nl (%number)
		       (((mx (:matrix %number)))
			<none>
			(nonpure))
    (display-matrix mx)
    (console-newline))


  (define main
    (lambda (() <none> nonpure)
      (let ((mx1 (matrix
		  (list
		   (list (complex 0.0 0.0) (complex 1.0 -4.0) (complex 1.5 2.5))
		   (list (complex 1.1 2.1) (complex 3.5 -1.0) (complex 0.0 0.0))
		   (list (complex 1.0 0.0) (complex 0.0 -2.5) (complex 1.0 1.0)))))
	    (mx2 (diagonal-matrix
		  (list (complex -4.5 0.0) (complex -1.0 1.0) (complex 2.5 1.5))))
	    (cv (column-vector
		 (list (complex 5.0 1.0) (complex 0.0 1.0) (complex 2.5 1.0)))))
	(display-matrix-nl (* mx1 mx2))
	(display-matrix-nl (* mx1 cv))
	(display-matrix-nl (* mx2 cv))))))