forked from tomhanika/conexp-clj
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfunction-context.clj
103 lines (84 loc) · 2.76 KB
/
function-context.clj
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
;; Daniel Borchmann, 2010
;; This file is in the public domain.
;; Computes a context of function used by Artem to explore certain
;; properties of functions on a 2-elemental set. After loading (which
;; may take a moment) you can use stem-base or explore-attributes to
;; explore the context function-context.
(require 'conexp.main)
(in-ns 'conexp.main)
;;; First define some properties of functions (not all defined by Artem)
(defn idempotent? [f S]
(forall [A (subsets S)]
(= (f (f A)) (f A))))
(defn intensive? [f S]
(forall [A (subsets S)]
(subset? (f A) A)))
(defn extensive? [f S]
(forall [A (subsets S)]
(subset? A (f A))))
(defn monotone? [f S]
(forall [A (subsets S),
B (subsets S)]
(=> (subset? A B)
(subset? (f A) (f B)))))
(defn antitone? [f S]
(forall [A (subsets S),
B (subsets S)]
(=> (subset? A B)
(subset? (f B) (f A)))))
(defn outcast? [f S]
(forall [A (subsets S),
B (subsets S)]
(=> (and (subset? (f B) A) (subset? A B))
(= (f B) (f A)))))
(defn heritage? [f S]
(forall [A (subsets S),
B (subsets S)]
(=> (subset? A B)
(subset? (intersection (f B) A)
(f A)))))
(defn constancy? [f S]
(forall [A (subsets S),
B (subsets S)]
(=> (subset? A B)
(and (=> (empty? (f B))
(empty? (f A)))
(=> (not (empty? (intersection A (f B))))
(= (f A) (intersection (f B) A)))))))
(defn exchange? [f S]
(forall [A (subsets S),
x S,
y S]
(=> (and (not= x y)
(not (contains? (f A) x))
(not (contains? (f A) y))
(contains? (f (conj A x)) y))
(contains? (f (conj A y)) x))))
(defn antiexchange? [f S]
(forall [A (subsets S),
x S,
y S]
(=> (and (not= x y)
(not (contains? (f A) x))
(not (contains? (f A) y))
(contains? (f (conj A x)) y))
(not (contains? (f (conj A y)) x)))))
;;; Now generate all functions on an n-elemental set
(use '[clojure.math.combinatorics :only (selections)])
(defn all-possible-funcs-on
"Generates all functions, as hash-maps, on the subsets of base."
[base]
(let [subs (subsets base)]
(map #(zipmap subs %)
(selections subs (expt 2 (count base))))))
(def function-context
(make-context (set (all-possible-funcs-on #{0 1}))
'#{idempotent?, intensive?, extensive?, monotone?, antitone?,
outcast?, heritage?, exchange?, constancy?}
;; Note: This is a trick to get good names for the
;; attributes (instead of Clojure's way of writing
;; functions)
(fn [f p]
(@(resolve p) f #{0 1}))))
;;;
nil