-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcontourcloud.pro
107 lines (91 loc) · 3.29 KB
/
contourcloud.pro
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
function contourcloud, xin, yin, vin, tin, x0 = x0, y0 = y0, $
v0 = v0, clev = clev_in, count = count, all_neighbors = all_neighbors
;+
; NAME:
; CONTOURCLOUD
;
; PURPOSE:
; Given input vectors returns a vector of lowest contour levels such
; that the corresponding element in the input is >= the contour
; level.
;
; CALLING SEQUENCE:
; t_cont = CONTOURCLOUD(x, y, v, t, x0 = x0, y0 = y0, v0 = v0,
; [clev = clev, count = count])
;
; INPUTS:
; X,Y,V,T -- Vectors containing the data (from VECTORIFY.pro)
; X0, Y0, V0 -- Position of the kernel
; KEYWORD PARAMETERS:
; CLEV -- Contour levels to use;
; COUNT -- Number of pixels >= that contour level.
;
; OUTPUTS:
; T_CONT - a vector of lowest contour levels such
; that the corresponding element in the input is >= the contour
; level.
;
; MODIFICATION HISTORY:
;
; Fri Mar 24 11:35:49 2006, Erik
; Added all_neighbors compatibility
;
; Documented -- Fri Sep 2 16:36:25 2005, Erik Rosolowsky
;-
; %&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&
; DEFINITIONS AND INPUT
; %&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&
; COPY ARRAYS SO WE DON'T FUCK ANYTHING UP
x = xin
y = yin
v = vin
t = tin
; SORT BY DECREASING ANTENNA TEMPERATURE AND REORDER ALL OF THE
; ARRAYS. THE BRIGHTEST PIXEL IS NOW ELEMENT 0.
sort_t = reverse(sort(t))
x = x[sort_t]
y = y[sort_t]
v = v[sort_t]
t = t[sort_t]
; MAKE A 3-D CUBE THE SIZE OF THE CLOUD
cubify, x, y, v, t, cube = cube, indcube = indcube, /pad, $
location = location
; GET THE INDEX OF THE SEED POINT
seedind = location[where((x eq x0) AND (y eq y0) AND (v eq v0))]
; CREATE THE OUTPUT ARRAY AND MAKE IT "NaN" TO START WITH
contours = t*!values.f_nan
; CREATE THE ARRAY OF POSSIBLE CONTOURS TO LOOP OVER AND MAKE SURE
; THAT THEY ARE IN DESCENDING ORDER
if (n_elements(clev_in) eq 0) then $
clev = t else $
clev = clev_in[reverse(sort(clev_in))]
; %&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&
; LOOP OVER THE CONTOUR LEVELS IN ORDER TO ASSIGN EACH CLOUD PIXEL TO
; THE RIGHT ONE.
; %&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&%&
; if keyword_set(halt) then stop
count = lonarr(n_elements(clev))
for i = 0, n_elements(clev)-1 do begin
if n_elements(clev) gt 3 then $
counter, i, n_elements(clev), ' out of '
; FLAG ALL VALUES ABOVE THE CURRENT CONTOUR
mask = cube ge clev[i]
; Count number above this contour level
count[i] = total(mask)
; IDENTIFY THE REGIONS OF CONTIGUOUS EMISSION
regions = label_region(mask, /ULONG, all_neighbors = all_neighbors)
; PICK OUT THE PIXELS IN THE SAME REGION AS THE SEED POINT THAT HAVE
; NOT YET BEEN ASSIGNED A HIGHER CONTOUR VALUE
new_in_contour = where((regions[location] eq (regions[seedind])[0]) AND $
(finite(contours) eq 0) AND $
((regions[seedind])[0] ne 0), num)
; IF WE HAVE ANY NEW PIXELS, ASSIGN THEM TO THIS CONTOUR LEVEL
if (num gt 0) then $
contours[new_in_contour] = clev[i]
endfor
; JUGGLE THE ORDER BACK TO MATCH THE INPUT ARRAYS
dummy = contours
contours[sort_t] = dummy
return, contours
end ; OF CONTOURCLOUD