Skip to content
This repository has been archived by the owner on May 14, 2021. It is now read-only.

Commit

Permalink
Moved files to temp directory, started reorganization.
Browse files Browse the repository at this point in the history
  • Loading branch information
tpapp committed Jan 24, 2013
1 parent 9884c15 commit a0f522b
Show file tree
Hide file tree
Showing 23 changed files with 865 additions and 408 deletions.
143 changes: 143 additions & 0 deletions arithmetic-type.lisp
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
;;; -*- Mode:Lisp; Syntax:ANSI-Common-Lisp; Coding:utf-8 -*-

(in-package #:cl-num-utils)

(defun all-float-types ()
"Return a list of float types."
'(short-float single-float double-float long-float))

(defun available-float-type? (type)
"Return T iff type is available as a specialized array element type."
(equal type (upgraded-array-element-type type)))

(defun array-float-types ()
"Return a list of float types which are upgraded to themselves.
Consequences are undefined if modified."
(load-time-value
(remove-if (complement #'available-float-type?) (all-float-types))))

(defun array-float-and-complex-types ()
"Return a list of float types which are upgraded to themselves.
Consequences are undefined if modified."
(load-time-value
(remove-if (complement #'available-float-type?)
(append (all-float-types)
(mapcar (lambda (type) `(complex ,type))
(all-float-types))))
t))



(defun recognized-float-types ()
(let ((float '(short-float single-float double-float long-float)))
(concatenate 'vector float
(mapcar (curry #'list 'complex) float))))

(macrolet ((define% ()
`(defun float-type-index (type)
(cond
,@(let ((index 0))
(map 'list (lambda (type)
(prog1 `((subtypep type ',type) ,index)
(incf index)))
(recognized-float-types)))
(t nil)))))
(define%))

(defun float-contagion-matrix ()
(let ((indexes (ivec (length (recognized-float-types)))))
(outer* indexes indexes
(lambda (i1 i2)
))))

(defun float-contagion (&rest types)
(declare (optimize speed))
(let ((matrix (load-time-value
(let ((matrix (make-array '(8 8)
:element-type '(integer 0 7))))
(dotimes (i1 8)
(dotimes (i2 8)
(multiple-value-bind (c1 f1) (floor i1 4)
(multiple-value-bind (c2 f2) (floor i2 4)
(setf (aref matrix i1 i2)
(+ (max f1 f2) (* 4 (max c1 c2))))))))
matrix))))
(declare (type (simple-array (integer 0 7) (8 8)) matrix))
(if types
(aref #(short-float
single-float
double-float
long-float
(complex short-float)
(complex single-float)
(complex double-float)
(complex long-float))
(reduce (lambda (i1 i2) (aref matrix i1 i2)) types
:key (lambda (type)
(cond
((subtypep type 'short-float) 0)
((subtypep type 'single-float) 1)
((subtypep type 'double-float) 2)
((subtypep type 'long-float) 3)
((subtypep type '(complex short-float)) 4)
((subtypep type '(complex single-float)) 5)
((subtypep type '(complex double-float)) 6)
((subtypep type '(complex long-float)) 7)
(t (return-from float-contagion t))))))
nil)))



(defmacro define-float-contagion ()
)

(defun float-contagion (type1 type2)
(let+ (()
((&labels classify (type)
(cond
((subtypep type 'complex) (values (classify ())))
)
(typecase type
(complex )
(float ))
)
)))
)

(defmacro define-arithmetic-contagion (function float-types
&optional (docstring ""))
"Define (FUNCTION TYPES) which returns the result type applying float and
complex contagion rules to TYPES, considering FLOAT-TYPES and their complex
counterparts. For types outside these, T is returned."
(let+ (((&flet map-types (function)
(loop for type in float-types
for index from 0
collect (funcall function type index))))
((&macrolet amap-types (form)
`(map-types (lambda (type index) ,form)))))
`(defun ,function (types)
,docstring
(declare (optimize speed))
(let ((complex? nil)
(float 0))
(declare (type fixnum float))
(loop for type in types do
(let+ (((&values f c?)
(cond
,@(amap-types `((subtypep type '(complex ,type))
(values ,index t)))
,@(amap-types `((subtypep type ',type) ,index))
(t (return-from ,function t)))))
(maxf float f)
(setf complex? (or complex? c?))))
(if complex?
(case float ,@(amap-types `(,index '(complex ,type))))
(case float ,@(amap-types `(,index ',type))))))))

(define-arithmetic-contagion array-arithmetic-contagion
#.(array-float-types)
"Return the upgraded element type of the arguments, applying rules of
float and complex contagion.")

(array-arithmetic-contagion '(double-float (complex single-float)))

File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
50 changes: 50 additions & 0 deletions src/old/sparse-array.lisp
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
;;; -*- Mode:Lisp; Syntax:ANSI-Common-Lisp; Coding:utf-8 -*-

(in-package #:cl-num-utils)

(defclass sparse-array ()
((elements :accessor elements :initarg :elements
:initform (make-hash-table :test #'equal))
(limits :accessor limits :initarg :limits)
(initial-value :accessor initial-value :initarg :initial-value :initform nil))
(:documentation "Sparse arrays are indexed by a rectilinear coordinate
system. Unless set, elements are left at their initial value. If
initial-value is a function, it is called with the subscripts to initialize
the elements."))

(defun sparse-array-extend-limits (limits subscripts)
"Extend limits to incorporate subscripts. Does error checking on the length
of subscripts."
(let ((rank (length limits)))
(assert (= rank (length subscripts)))
(loop :for index :below rank
:for subscript :in subscripts
:do (check-type subscript fixnum)
(aif (aref limits index)
(progn
(minf (car it) subscript)
(maxf (cdr it) (1+ subscript)))
(setf (aref limits index) (cons subscript (1+ subscript)))))))

(defun sparse-array-initial-value (initial-value subscripts)
"Initial value semantics for sparse arrays -- functions are called with
subscripts."
(if (functionp initial-value)
(apply initial-value subscripts)
initial-value))

(defmethod initialize-instance :after ((sparse-array sparse-array)
&key rank &allow-other-keys)
(check-type rank (integer 0))
(setf (limits sparse-array) (make-array rank :initial-element nil)))

(defmethod ref ((sparse-array sparse-array) &rest subscripts)
(let+ (((&slots-r/o elements initial-value) sparse-array)
((&values value present?) (gethash subscripts elements)))
(if present?
value
(sparse-array-initial-value initial-value subscripts))))

(defmethod (setf ref) (value (sparse-array sparse-array) &rest subscripts)
(sparse-array-extend-limits (limits sparse-array) subscripts)
(setf (gethash subscripts (elements sparse-array)) value))
File renamed without changes.
Loading

0 comments on commit a0f522b

Please sign in to comment.