-
Notifications
You must be signed in to change notification settings - Fork 33
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
#162 - Add macros to automatically create boilerplate code #228
Changes from 6 commits
f75f6d3
00df076
5ddb0ca
8e9f0b8
9348d4a
714a8eb
76da433
345fc24
b85d1e4
c69313d
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,4 +9,7 @@ end | |
|
||
```@docs | ||
sign_cadlag | ||
@commutative_neutral | ||
@commutative_absorbing | ||
@commutative_neutral_absorbing | ||
``` |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -20,6 +20,10 @@ The Cartesian product of three elements is obtained recursively. | |
See also `CartesianProductArray` for an implementation of a Cartesian product of | ||
many sets without recursion, instead using an array. | ||
|
||
The `EmptySet` is the absorbing element for `CartesianProduct`. | ||
|
||
Constructors: | ||
|
||
- `CartesianProduct{N<:Real, S1<:LazySet{N}, S2<:LazySet{N}}(X1::S1, X2::S2)` | ||
-- default constructor | ||
|
||
|
@@ -45,9 +49,12 @@ CartesianProduct(Xarr::Vector{S}) where {S<:LazySet{N}} where {N<:Real} = | |
: CartesianProduct(Xarr[1], | ||
CartesianProduct(Xarr[2:length(Xarr)]))) | ||
|
||
# EmptySet is the absorbing element for CartesianProduct | ||
@commutative_absorbing(CartesianProduct, EmptySet) | ||
|
||
""" | ||
``` | ||
*(X::LazySet, Y::LazySet)::CartesianProduct | ||
*(X::LazySet, Y::LazySet) | ||
``` | ||
|
||
Return the Cartesian product of two convex sets. | ||
|
@@ -61,7 +68,7 @@ Return the Cartesian product of two convex sets. | |
|
||
The Cartesian product of the two convex sets. | ||
""" | ||
*(X::LazySet, Y::LazySet)::CartesianProduct = CartesianProduct(X, Y) | ||
*(X::LazySet, Y::LazySet) = CartesianProduct(X, Y) | ||
|
||
""" | ||
× | ||
|
@@ -70,43 +77,6 @@ Alias for the binary Cartesian product. | |
""" | ||
×(X::LazySet, Y::LazySet) = *(X, Y) | ||
|
||
""" | ||
X × ∅ | ||
|
||
Right multiplication of a set by an empty set. | ||
|
||
### Input | ||
|
||
- `X` -- a convex set | ||
- `∅` -- an empty set | ||
|
||
### Output | ||
|
||
An empty set, because the empty set is the absorbing element for the | ||
Cartesian product. | ||
""" | ||
*(::LazySet, ∅::EmptySet) = ∅ | ||
|
||
""" | ||
∅ × X | ||
|
||
Left multiplication of a set by an empty set. | ||
|
||
### Input | ||
|
||
- `X` -- a convex set | ||
- `∅` -- an empty set | ||
|
||
### Output | ||
|
||
An empty set, because the empty set is the absorbing element for the | ||
Cartesian product. | ||
""" | ||
*(∅::EmptySet, ::LazySet) = ∅ | ||
|
||
# special case: pure empty set multiplication (we require the same numeric type) | ||
(*(∅::E, ::E)) where {E<:EmptySet} = ∅ | ||
|
||
""" | ||
dim(cp::CartesianProduct)::Int | ||
|
||
|
@@ -180,32 +150,34 @@ Type that represents the Cartesian product of a finite number of convex sets. | |
|
||
### Notes | ||
|
||
- `CartesianProductArray(array::Vector{<:LazySet})` -- default constructor | ||
The `EmptySet` is the absorbing element for `CartesianProductArray`. | ||
|
||
- `CartesianProductArray()` -- constructor for an empty Cartesian product | ||
Constructors: | ||
|
||
- `CartesianProductArray(n::Int, [N]::Type=Float64)` | ||
-- constructor for an empty Cartesian product with size hint and numeric type | ||
- `CartesianProductArray(array::Vector{<:LazySet})` -- default constructor | ||
|
||
- `CartesianProductArray([n]::Int=0, [N]::Type=Float64)` | ||
-- constructor for an empty product with optional size hint and numeric type | ||
""" | ||
struct CartesianProductArray{N<:Real, S<:LazySet{N}} <: LazySet{N} | ||
array::Vector{S} | ||
end | ||
|
||
# type-less convenience constructor | ||
CartesianProductArray(arr::Vector{S}) where {S<:LazySet{N}} where {N<:Real} = | ||
CartesianProductArray{N, S}(arr) | ||
# constructor for an empty Cartesian product of floats | ||
CartesianProductArray() = | ||
CartesianProductArray{Float64, LazySet{Float64}}(Vector{LazySet{Float64}}(0)) | ||
# constructor for an empty Cartesian product with size hint and numeric type | ||
function CartesianProductArray(n::Int, N::Type=Float64)::CartesianProductArray | ||
|
||
# constructor for an empty product with optional size hint and numeric type | ||
function CartesianProductArray(n::Int=0, N::Type=Float64)::CartesianProductArray | ||
arr = Vector{LazySet{N}}(0) | ||
sizehint!(arr, n) | ||
return CartesianProductArray(arr) | ||
end | ||
|
||
""" | ||
``` | ||
*(cpa::CartesianProductArray, S::LazySet)::CartesianProductArray | ||
CartesianProductArray(cpa::CartesianProductArray, | ||
S::LazySet)::CartesianProductArray | ||
``` | ||
|
||
Multiply a convex set to a Cartesian product of a finite number of convex sets | ||
|
@@ -220,14 +192,16 @@ from the right. | |
|
||
The modified Cartesian product of a finite number of convex sets. | ||
""" | ||
function *(cpa::CartesianProductArray, S::LazySet)::CartesianProductArray | ||
function CartesianProductArray(cpa::CartesianProductArray, | ||
S::LazySet)::CartesianProductArray | ||
push!(cpa.array, S) | ||
return cpa | ||
end | ||
|
||
""" | ||
``` | ||
*(S::LazySet, cpa::CartesianProductArray)::CartesianProductArray | ||
CartesianProductArray(S::LazySet, | ||
cpa::CartesianProductArray)::CartesianProductArray | ||
``` | ||
|
||
Multiply a convex set to a Cartesian product of a finite number of convex sets | ||
|
@@ -242,52 +216,15 @@ from the left. | |
|
||
The modified Cartesian product of a finite number of convex sets. | ||
""" | ||
function *(S::LazySet, cpa::CartesianProductArray)::CartesianProductArray | ||
push!(cpa.array, S) | ||
return cpa | ||
function CartesianProductArray(S::LazySet, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok, this change is to save the symbol julia> b = Ball2(zeros(2), 1.);
julia> c = CartesianProductArray([b, b])
julia> CartesianProductArray(b, c)
LazySets.CartesianProductArray{Float64,LazySets.Ball2{Float64}}(LazySets.Ball2{Float64}[LazySets.Ball2{Float64}([0.0, 0.0], 1.0), LazySets.Ball2{Float64}([0.0, 0.0], 1.0), LazySets.Ball2{Float64}([0.0, 0.0],
1.0)])
julia> b * c
LazySets.CartesianProduct{Float64,LazySets.Ball2{Float64},LazySets.CartesianProductArray{Float64,LazySets.Ball2{Float64}}}(LazySets.Ball2{Float64}([0.0, 0.0], 1.0), LazySets.CartesianProductArray{Float64,Laz
ySets.Ball2{Float64}}(LazySets.Ball2{Float64}[LazySets.Ball2{Float64}([0.0, 0.0], 1.0), LazySets.Ball2{Float64}([0.0, 0.0], 1.0), LazySets.Ball2{Float64}([0.0, 0.0], 1.0)])) i doubt a bit, but maybe it is more sensible the new behavior. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Actually I wanted to discuss this. I propose to additionally add a similar macro relating There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Okay, I took a note in the related issue #162. |
||
cpa::CartesianProductArray)::CartesianProductArray | ||
return CartesianProductArray(cpa, S) | ||
end | ||
|
||
""" | ||
``` | ||
*(cpa::CartesianProductArray, ∅::EmptySet) | ||
``` | ||
|
||
Right multiplication of a `CartesianProductArray` by an empty set. | ||
|
||
### Input | ||
|
||
- `cpa` -- Cartesian product array | ||
- `∅` -- an empty set | ||
|
||
### Output | ||
|
||
An empty set, because the empty set is the absorbing element for the | ||
Cartesian product. | ||
""" | ||
*(::CartesianProductArray, ∅::EmptySet) = ∅ | ||
|
||
""" | ||
``` | ||
*(S::EmptySet, cpa::CartesianProductArray) | ||
``` | ||
|
||
Left multiplication of a set by an empty set. | ||
|
||
### Input | ||
|
||
- `X` -- a convex set | ||
- `∅` -- an empty set | ||
|
||
### Output | ||
|
||
An empty set, because the empty set is the absorbing element for the | ||
Cartesian product. | ||
""" | ||
*(∅::EmptySet, ::CartesianProductArray) = ∅ | ||
|
||
""" | ||
``` | ||
*(cpa1::CartesianProductArray, cpa2::CartesianProductArray)::CartesianProductArray | ||
CartesianProductArray(cpa1::CartesianProductArray, | ||
cpa2::CartesianProductArray)::CartesianProductArray | ||
``` | ||
|
||
Multiply a finite Cartesian product of convex sets to another finite Cartesian | ||
|
@@ -302,12 +239,15 @@ product. | |
|
||
The modified first Cartesian product. | ||
""" | ||
function *(cpa1::CartesianProductArray, | ||
cpa2::CartesianProductArray)::CartesianProductArray | ||
function CartesianProductArray(cpa1::CartesianProductArray, | ||
cpa2::CartesianProductArray)::CartesianProductArray | ||
append!(cpa1.array, cpa2.array) | ||
return cpa1 | ||
end | ||
|
||
# EmptySet is the absorbing element for CartesianProduct | ||
@commutative_absorbing(CartesianProductArray, EmptySet) | ||
|
||
""" | ||
array(cpa::CartesianProductArray{N, S})::Vector{S} where {N<:Real, S<:LazySet{N}} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
while we are at this line, a general thought is that i find the illustration of the different constructors to be more friendly if it is given as a proper example, rather than a copy paste of the source code -- if one wants that level of detail, then it's better to just look the code, by clicking on "view source", no? (or use Julia's
@edit
macro). that is to say that for me we can delete this part and instead put some examples of the different uses (in another PR).There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added #232.