From d7a87119708cbd0d489aa98985fc8c918b4fcbb5 Mon Sep 17 00:00:00 2001 From: Fredrik Ekre Date: Fri, 30 Nov 2018 01:17:21 +0100 Subject: [PATCH] Compat annotation for #29890 (broadcasting CartesianIndices). --- base/multidimensional.jl | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/base/multidimensional.jl b/base/multidimensional.jl index 3c353fa649cd7..a91f172ffc2ae 100644 --- a/base/multidimensional.jl +++ b/base/multidimensional.jl @@ -211,6 +211,27 @@ module IteratorsMD CartesianIndex(1, 2) ``` + ## Broadcasting + + `CartesianIndices` support broadcasting arithmetic (+ and -) with a `CartesianIndex`. + + !!! compat "Julia 1.1" + Broadcasting of CartesianIndices requires at least Julia 1.1. + + ```jldoctest + julia> CartesianIndices(rand(1,2)) + 1×2 CartesianIndices{2,Tuple{Base.OneTo{Int64},Base.OneTo{Int64}}}: + CartesianIndex(1, 1) CartesianIndex(1, 2) + + julia> CI = CartesianIndex(3, 4) + CartesianIndex(3, 4) + + julia> CIs .+ CI + 2×2 CartesianIndices{2,Tuple{UnitRange{Int64},UnitRange{Int64}}}: + CartesianIndex(4, 5) CartesianIndex(4, 6) + CartesianIndex(5, 5) CartesianIndex(5, 6) + ``` + For cartesian to linear index conversion, see [`LinearIndices`](@ref). """ struct CartesianIndices{N,R<:NTuple{N,AbstractUnitRange{Int}}} <: AbstractArray{CartesianIndex{N},N}