-
Notifications
You must be signed in to change notification settings - Fork 1
/
ndgrid.jl
52 lines (45 loc) · 1.34 KB
/
ndgrid.jl
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
# This file was formerly a part of Julia. License is MIT: https://julialang.org/license
ndgrid(v::AbstractVector) = copy(v)
function ndgrid(v1::AbstractVector{T}, v2::AbstractVector{T}) where T
m, n = length(v1), length(v2)
v1 = reshape(v1, m, 1)
v2 = reshape(v2, 1, n)
(repeat(v1, 1, n), repeat(v2, m, 1))
end
function ndgrid_fill(a, v, s, snext)
for j = 1:length(a)
a[j] = v[div(rem(j-1, snext), s)+1]
end
end
function ndgrid(vs::AbstractVector{T}...) where T
n = length(vs)
sz = map(length, vs)
out = ntuple(i->Array{T}(undef, sz), n)
s = 1
for i=1:n
a = out[i]::Array
v = vs[i]
snext = s*size(a,i)
ndgrid_fill(a, v, s, snext)
s = snext
end
out
end
meshgrid(v::AbstractVector) = meshgrid(v, v)
function meshgrid(vx::AbstractVector{T}, vy::AbstractVector{T}) where T
m, n = length(vy), length(vx)
vx = reshape(vx, 1, n)
vy = reshape(vy, m, 1)
(repeat(vx, m, 1), repeat(vy, 1, n))
end
function meshgrid(vx::AbstractVector{T}, vy::AbstractVector{T},
vz::AbstractVector{T}) where T
m, n, o = length(vy), length(vx), length(vz)
vx = reshape(vx, 1, n, 1)
vy = reshape(vy, m, 1, 1)
vz = reshape(vz, 1, 1, o)
om = fill(1, m)
on = fill(1, n)
oo = fill(1, o)
(vx[om, :, oo], vy[:, on, oo], vz[om, on, :])
end