Astropy Cutout2D, поднять ValueError - PullRequest
1 голос
/ 17 марта 2019

Я пытаюсь использовать Astropy's Cutout2D для проверки представленной процедуры . Моя цель состоит в том, чтобы извлечь изображение .png для каждого источника, который у меня есть в основном каталоге правды, используя RA и DEC.

Заголовки для файла:

SIMPLE  =                    T  /                                               
BITPIX  =                  -32  /                                               
NAXIS   =                    4  /                                               
NAXIS1  =                30000  /                                               
NAXIS2  =                30000  /                                               
NAXIS3  =                    1  /                                               
NAXIS4  =                    1  /                                               
EXTEND  =                    T  /                                               
BSCALE  =    1.00000000000E+00  /                                               
BZERO   =    0.00000000000E+00  /                                               
BLANK   =                   -1  /                                               
BUNIT   = 'JY/BEAM '  /                                                         
DATE-OBS= '2000-01-01T12:00:00.0'  /                                            
CRPIX1  =    1.63840000000E+04  /                                               
CDELT1  =   -6.71387000000E-05  /                                               
CRVAL1  =    0.00000000000E+00  /                                               
CTYPE1  = 'RA---SIN'  /                                                         
CRPIX2  =    1.63840000000E+04  /                                               
CDELT2  =    6.71387000000E-05  /                                               
CRVAL2  =   -3.00000000000E+01  /                                               
CTYPE2  = 'DEC--SIN'  /                                                         
CRPIX3  =    1.00000000000E+00  /                                               
CDELT3  =    4.20000000000E+08  /                                               
CRVAL3  =    1.40000000000E+09  /                                               
CTYPE3  = 'FREQ    '  /                                                         
CRPIX4  =    1.00000000000E+00  /                                               
CDELT4  =    1.00000000000E+00  /                                               
CRVAL4  =    1.00000000000E+00  /                                               
CTYPE4  = 'STOKES  '  /        
...      

Я использую этот небольшой скрипт, скопированный из документации:

hdu = fits.open(file)[0]
data=hdu.data
w = WCS(file)
    position = SkyCoord(24.17*u.deg, 15.78*u.deg,frame='fk5',equinox='J2000.0'  
    size = u.Quantity((10,10), u.arcsec)  
    cutout = Cutout2D(data, posit

ion, size, fill_value=np.nan,  wcs=w) 

Я понял:

Traceback (most recent call last):
  File "###/Cutoff_patches.py", line 113, in <module>
    cutout = Cutout2D(data, position, size,   wcs=w)
  File "##_venv/lib/python3.5/site-packages/astropy/nddata/utils.py", line 686, in __init__
    return_position=True)
  File "##_venv/lib/python3.5/site-packages/astropy/nddata/utils.py", line 211, in extract_array
    shape, position, mode=mode)
  File "##_venv/lib/python3.5/site-packages/astropy/nddata/utils.py", line 91, in overlap_slices
    raise ValueError('"large_array_shape" and "small_array_shape" must '
ValueError: "large_array_shape" and "small_array_shape" must have the same number of dimensions.

Понятия не имею, почему это происходит и как это решить.

Я также попытался изменить форму, как упоминалось:

data = data.reshape(data.shape[2:])

а также

data=np.squeeze(data)

но потом я получаю одинаковое для них обоих:

Traceback (most recent call last):
  File "##/Cutoff_patches.py", line 114, in <module>
    cutout = Cutout2D(data, position, size,   wcs=w)
  File "##venv/lib/python3.5/site-packages/astropy/nddata/utils.py", line 686, in __init__
    return_position=True)
  File "/##_venv/lib/python3.5/site-packages/astropy/nddata/utils.py", line 211, in extract_array
    shape, position, mode=mode)
  File "##_venv/lib/python3.5/site-packages/astropy/nddata/utils.py", line 106, in overlap_slices
    raise NoOverlapError('Arrays do not overlap.')
astropy.nddata.utils.NoOverlapError: Arrays do not overlap.

Process finished with exit code 1
...