forked from anjmarsh/nustar_transient_search
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsensitivity_th3.pro
87 lines (69 loc) · 2.41 KB
/
sensitivity_th3.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
;+
; NAME:
; SENSITIVITY_TH3
;PURPOSE:
; Calculate flare scaling matrix corresponding to an input NuSTAR
; image cube. Simulated 3MK flare is added to input image cube, then
; scalings are calculated to give a 'barely detectable' event.
;
; This is defined as the scaling that yields
; max(dm_flare) = 2*max(dm_noflare)
;
; dm is the 'diff_matrix' generated by the transient_search procedure
;
;INPUTS:
; Image cube
;OPTIONAL:
; Frame # for initial flare addition
;OUTPUTS:
; Matrix of scaling factors for every frame and every pixel in the
; input image cube
function sensitivity_th3, im, frame=frame
common flare3, flare3
flare3 = mrdfits('/home/andrew/nusim/Solar/flare_sim_3MK_10s.events.fits',1,fh)
SetDefaultValue, frame, 0
dwell_th = 100 ;temporal binning - 100s for thermal emission
pix_size = 58 ;spatial binning - NuSTAR HPD
erange = [2.5,4] ;energy range for thermal
ima = im.imcube
ta = transient_search(ima)
da = ta.diff_matrix
maxa = max(da) ;diff_max for no-flare case
print, 'Non-flare maximum = ' + string(fix(maxa))
xlen = (size(ima))[1]
ylen = (size(ima))[2]
n_frames = (size(ima))[3]
sarray = float( ima * 0)
;figure out correct flare pixel indices
si = 0.01
ai = add_flare3(ima, frame, scale=si, pix_size=pix_size, erange=erange)
w = where( ai[*,*,frame] eq max(ai[*,*,frame]) )
flare_peak = array_indices( ai[*,*,frame], w )
xshiftpos = xlen - flare_peak[0]
yshiftpos = ylen - flare_peak[1]
;test scaling for every pixel in every frame
for frame=0,n_frames-1 do begin
for xshift = -flare_peak[0], xshiftpos-1 do begin
for yshift = -flare_peak[1], yshiftpos-1 do begin
si = 0.01 ;initial scaling
ai = add_flare3(ima, frame, scale=si, pix_size=pix_size, move=[xshift,yshift], erange=erange)
ti = transient_search(ai)
dfi = ti.diff_matrix
maxdi = max(dfi) ;initial diff_max
print, 'Initial maximum with flare = ' + string(fix(maxdi))
while (maxdi GT 2*maxa) do begin ;loop until max = 2*noflare_diff_max
si = si - 0.0001 ;scale down in increments
af = add_flare3(ima, frame, scale=si, pix_size=pix_size, move=[xshift,yshift], erange=erange)
tf = transient_search(af)
dff = tf.diff_matrix
maxdi = max(dff)
print,maxdi,' ',si
endwhile
x = flare_peak[0] + xshift
y = flare_peak[1] + yshift
sarray[x,y,frame] = si
endfor
endfor
endfor
return, sarray
END