- 
                Notifications
    You must be signed in to change notification settings 
- Fork 27
Implemented clamp(t, i::ClosedInterval) #77
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
Conversation
| Codecov Report
 @@            Coverage Diff             @@
##           master      #77      +/-   ##
==========================================
+ Coverage   90.63%   90.94%   +0.30%     
==========================================
  Files           3        3              
  Lines         267      265       -2     
==========================================
- Hits          242      241       -1     
+ Misses         25       24       -1     
 Continue to review full report at Codecov. 
 | 
| Can you add a test for broadcasting? I'd expect   julia> clamp.([pi, 1.0, big(10.)], 2..9.)
  3-element Vector{BigFloat}:
   3.141592653589793238462643383279502884197169399375105820974944592307816406286198
   2.0
   9.0though perhaps it's not clear how broadcasting would work... | 
| At the moment, that's an error: julia> clamp.([pi, 1.0, big(10.)], 2..9.)
ERROR: MethodError: no method matching iterate(::ClosedInterval{Float64})
Closest candidates are:
  iterate(::Union{LinRange, StepRangeLen}) at range.jl:664
  iterate(::Union{LinRange, StepRangeLen}, ::Int64) at range.jl:664
  iterate(::T) where T<:Union{Base.KeySet{var"#s79", var"#s78"} where {var"#s79", var"#s78"<:Dict}, Base.ValueIterator{var"#s77"} where var"#s77"<:Dict} at dict.jl:693
  ...
Stacktrace:
 [1] _collect(cont::UnitRange{Int64}, itr::ClosedInterval{Float64}, #unused#::Base.HasEltype, isz::Base.SizeUnknown)
   @ Base ./array.jl:613
 [2] collect(itr::ClosedInterval{Float64})
   @ Base ./array.jl:602
 [3] broadcastable(x::ClosedInterval{Float64})
   @ Base.Broadcast ./broadcast.jl:682
 [4] broadcasted(::Function, ::Vector{BigFloat}, ::ClosedInterval{Float64})
   @ Base.Broadcast ./broadcast.jl:1313
 [5] top-level scope
   @ REPL[9]:1which of course can be solved by julia> Base.Broadcast.broadcastable(i::ClosedInterval) = Ref(i)
julia> clamp.([pi, 1.0, big(10.)], 2..9.)
3-element Vector{BigFloat}:
 3.141592653589793238462643383279502884197169399375105820974944592307816406286198
 2.0
 9.0I don't know if that opens a can of worms or not. Should the  julia> (2..9) .+ 3
ERROR: MethodError: no method matching +(::ClosedInterval{Int64}, ::Int64)
Closest candidates are:
  +(::Any, ::Any, ::Any, ::Any...) at operators.jl:560
  +(::T, ::T) where T<:Union{Int128, Int16, Int32, Int64, Int8, UInt128, UInt16, UInt32, UInt64, UInt8} at int.jl:87
  +(::Rational, ::Integer) at rational.jl:288
  ...
Stacktrace:
 [1] _broadcast_getindex_evalf
   @ ./broadcast.jl:648 [inlined]
 [2] _broadcast_getindex
   @ ./broadcast.jl:621 [inlined]
 [3] getindex
   @ ./broadcast.jl:575 [inlined]
 [4] copy
   @ ./broadcast.jl:898 [inlined]
 [5] materialize(bc::Base.Broadcast.Broadcasted{Base.Broadcast.DefaultArrayStyle{0}, Nothing, typeof(+), Tuple{Base.RefValue{ClosedInterval{Int64}}, Int64}})
   @ Base.Broadcast ./broadcast.jl:883
 [6] top-level scope
   @ REPL[12]:1instead of julia> (2..9.) .+ 1
ERROR: MethodError: no method matching iterate(::ClosedInterval{Float64})
Closest candidates are:
  iterate(::Union{LinRange, StepRangeLen}) at range.jl:664
  iterate(::Union{LinRange, StepRangeLen}, ::Int64) at range.jl:664
  iterate(::T) where T<:Union{Base.KeySet{var"#s79", var"#s78"} where {var"#s79", var"#s78"<:Dict}, Base.ValueIterator{var"#s77"} where var"#s77"<:Dict} at dict.jl:693
  ...
Stacktrace:
 [1] _collect(cont::UnitRange{Int64}, itr::ClosedInterval{Float64}, #unused#::Base.HasEltype, isz::Base.SizeUnknown)
   @ Base ./array.jl:613
 [2] collect(itr::ClosedInterval{Float64})
   @ Base ./array.jl:602
 [3] broadcastable(x::ClosedInterval{Float64})
   @ Base.Broadcast ./broadcast.jl:682
 [4] broadcasted(::Function, ::ClosedInterval{Float64}, ::Int64)
   @ Base.Broadcast ./broadcast.jl:1312
 [5] top-level scope
   @ REPL[4]:1without the overload. For now, I've added the test case  | 
| I think forget broadcasting for now | 
| So, merge as-is? | 
| Bump 🙂 | 
With this PR, we can do
I am unsure if
clampmakes sense for non-closed intervals, so I onlyimplemented it for
ClosedInterval.