From c75abeb76fd77e301ded99ba4b8737f53953b43a Mon Sep 17 00:00:00 2001 From: Eduardo Julian Date: Thu, 26 Jan 2017 18:50:34 -0400 Subject: - Renamed Bounded to Interval. --- stdlib/source/lux/control/bounded.lux | 15 ------------- stdlib/source/lux/control/interval.lux | 32 ++++++++++++++++++++++++++ stdlib/source/lux/data/number.lux | 35 +++++++++++++++-------------- stdlib/source/lux/math/logic/continuous.lux | 6 ++--- stdlib/test/test/lux/data/number.lux | 16 ++++++------- 5 files changed, 61 insertions(+), 43 deletions(-) delete mode 100644 stdlib/source/lux/control/bounded.lux create mode 100644 stdlib/source/lux/control/interval.lux diff --git a/stdlib/source/lux/control/bounded.lux b/stdlib/source/lux/control/bounded.lux deleted file mode 100644 index a81135261..000000000 --- a/stdlib/source/lux/control/bounded.lux +++ /dev/null @@ -1,15 +0,0 @@ -## Copyright (c) Eduardo Julian. All rights reserved. -## This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. -## If a copy of the MPL was not distributed with this file, -## You can obtain one at http://mozilla.org/MPL/2.0/. - -(;module: lux) - -## Signatures -(sig: #export (Bounded a) - {#;doc "A representation of top and bottom boundaries for an ordered type."} - (: a - top) - - (: a - bottom)) diff --git a/stdlib/source/lux/control/interval.lux b/stdlib/source/lux/control/interval.lux new file mode 100644 index 000000000..511195c93 --- /dev/null +++ b/stdlib/source/lux/control/interval.lux @@ -0,0 +1,32 @@ +## Copyright (c) Eduardo Julian. All rights reserved. +## This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. +## If a copy of the MPL was not distributed with this file, +## You can obtain one at http://mozilla.org/MPL/2.0/. + +(;module: + lux + (lux (control ord))) + +## Signatures +(sig: #export (Interval a) + {#;doc "A representation of top and bottom boundaries for an ordered type."} + (: (Ord a) + ord) + + (: a + top) + + (: a + bottom)) + +(def: #export (within? Interval elem) + (All [a] (-> (Interval a) a Bool)) + (let [(^open) Interval] + (if (>= bottom top) + ## Inside order + (and (>= bottom elem) + (<= top elem)) + ## Outside order + (and (<= bottom elem) + (>= top elem)) + ))) diff --git a/stdlib/source/lux/data/number.lux b/stdlib/source/lux/data/number.lux index 695f9c7b9..e9c49b38e 100644 --- a/stdlib/source/lux/data/number.lux +++ b/stdlib/source/lux/data/number.lux @@ -11,7 +11,7 @@ hash [ord] enum - bounded + interval codec) (data error))) @@ -102,15 +102,16 @@ [Int Ord i.inc i.dec] ) -(do-template [ ] - [(struct: #export _ (Bounded ) +(do-template [ ] + [(struct: #export _ (Interval ) + (def: ord ) (def: top ) (def: bottom ))] - [ Nat (_lux_proc ["nat" "max-value"] []) (_lux_proc ["nat" "min-value"] [])] - [ Int (_lux_proc ["jvm" "getstatic:java.lang.Long:MAX_VALUE"] []) (_lux_proc ["jvm" "getstatic:java.lang.Long:MIN_VALUE"] [])] - [Real (_lux_proc ["jvm" "getstatic:java.lang.Double:MAX_VALUE"] []) (_lux_proc ["jvm" "getstatic:java.lang.Double:MIN_VALUE"] [])] - [Deg (_lux_proc ["deg" "max-value"] []) (_lux_proc ["deg" "min-value"] [])]) + [ Nat Ord (_lux_proc ["nat" "max-value"] []) (_lux_proc ["nat" "min-value"] [])] + [ Int Ord (_lux_proc ["jvm" "getstatic:java.lang.Long:MAX_VALUE"] []) (_lux_proc ["jvm" "getstatic:java.lang.Long:MIN_VALUE"] [])] + [Real Ord (_lux_proc ["jvm" "getstatic:java.lang.Double:MAX_VALUE"] []) (_lux_proc ["jvm" "getstatic:java.lang.Double:MIN_VALUE"] [])] + [Deg Ord (_lux_proc ["deg" "max-value"] []) (_lux_proc ["deg" "min-value"] [])]) (do-template [ ] [(struct: #export (Monoid ) @@ -119,20 +120,20 @@ [ Add@Monoid Nat +0 n.+] [ Mul@Monoid Nat +1 n.*] - [ Max@Monoid Nat (:: Bounded bottom) n.max] - [ Min@Monoid Nat (:: Bounded top) n.min] + [ Max@Monoid Nat (:: Interval bottom) n.max] + [ Min@Monoid Nat (:: Interval top) n.min] [ Add@Monoid Int 0 i.+] [ Mul@Monoid Int 1 i.*] - [ Max@Monoid Int (:: Bounded bottom) i.max] - [ Min@Monoid Int (:: Bounded top) i.min] + [ Max@Monoid Int (:: Interval bottom) i.max] + [ Min@Monoid Int (:: Interval top) i.min] [Add@Monoid Real 0.0 r.+] [Mul@Monoid Real 1.0 r.*] - [Max@Monoid Real (:: Bounded bottom) r.max] - [Min@Monoid Real (:: Bounded top) r.min] - [Add@Monoid Deg (:: Bounded bottom) d.+] - [Mul@Monoid Deg (:: Bounded top) d.*] - [Max@Monoid Deg (:: Bounded bottom) d.max] - [Min@Monoid Deg (:: Bounded top) d.min] + [Max@Monoid Real (:: Interval bottom) r.max] + [Min@Monoid Real (:: Interval top) r.min] + [Add@Monoid Deg (:: Interval bottom) d.+] + [Mul@Monoid Deg (:: Interval top) d.*] + [Max@Monoid Deg (:: Interval bottom) d.max] + [Min@Monoid Deg (:: Interval top) d.min] ) (def: (text.replace pattern value template) diff --git a/stdlib/source/lux/math/logic/continuous.lux b/stdlib/source/lux/math/logic/continuous.lux index ccd5795d7..0e7e0de9b 100644 --- a/stdlib/source/lux/math/logic/continuous.lux +++ b/stdlib/source/lux/math/logic/continuous.lux @@ -5,7 +5,7 @@ (;module: lux - (lux (data [number "Deg/" Bounded Number]))) + (lux (data [number "Deg/" Interval]))) (def: #export TRUE Deg Deg/top) (def: #export FALSE Deg Deg/bottom) @@ -19,9 +19,9 @@ [or~ d.max] ) -(def: #export not~ +(def: #export (not~ input) (-> Deg Deg) - Deg/negate) + (d.- input TRUE)) (def: #export (implies~ consequent antecedent) (-> Deg Deg Deg) diff --git a/stdlib/test/test/lux/data/number.lux b/stdlib/test/test/lux/data/number.lux index 4de7d4c14..3ac5f0bf3 100644 --- a/stdlib/test/test/lux/data/number.lux +++ b/stdlib/test/test/lux/data/number.lux @@ -68,18 +68,18 @@ ["Int" R;int Enum Number] ) -(do-template [category rand-gen ] - [(test: (format "[" category "] " "Bounded") +(do-template [category rand-gen ] + [(test: (format "[" category "] " "Interval") [x (|> rand-gen (R;filter )) #let [(^open) ]] - (assert "" (and (<= x (:: bottom)) - (>= x (:: top)))))] + (assert "" (and (<= x (:: bottom)) + (>= x (:: top)))))] - ["Nat" R;nat Number Bounded (lambda [_] true)] - ["Int" R;int Number Bounded (lambda [_] true)] + ["Nat" R;nat Number Interval (lambda [_] true)] + ["Int" R;int Number Interval (lambda [_] true)] ## Both min and max values will be positive (thus, greater than zero) - ["Real" R;real Number Bounded (r.> 0.0)] - ["Deg" R;deg Number Bounded (lambda [_] true)] + ["Real" R;real Number Interval (r.> 0.0)] + ["Deg" R;deg Number Interval (lambda [_] true)] ) (do-template [category rand-gen ] -- cgit v1.2.3