-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_accuracy.py
34 lines (26 loc) · 975 Bytes
/
test_accuracy.py
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
import meaShear
import numpy as np
import astropy.io.fits as pyfits
import numpy.lib.recfunctions as rfn
def run_noiseless_gal(itest):
# Read PSF image
psfData=pyfits.getdata('../data/psf_test_%d.fits' %(itest))
# Read GAL image
galDatAll=pyfits.getdata('../data/gal_test_%d.fits' %(itest))
imgList=[galDatAll[i*64:(i+1)*64,0:64] for i in range(4)]
ellRes=[]
for i in range(4):
eR=meaShear.measureEllip(imgList[i],psfData,scale_par=0.85,weight_par=100.)
ellRes.append(eR)
ellRes = rfn.stack_arrays(ellRes,usemask=False)
g1_est=np.average(ellRes['fpfs_e1'])/np.average(ellRes['fpfs_RE'])
g2_est=np.average(ellRes['fpfs_e2'])/np.average(ellRes['fpfs_RE'])
np.testing.assert_almost_equal(g1_est, 0.02, 5)
# 1e-5 accuracy
np.testing.assert_almost_equal(g2_est, 0.00, 5)
# 1e-5 accuracy
return
def test_noiseless_gals():
run_noiseless_gal(itest=1)
run_noiseless_gal(itest=2)
return