We have noted a “confetti” problem in some of the ALMA-IMF cube images. It is called confetti because one of its manifestations is individual bright pixels in the model image.
This notebook shows where confetti is - and is not a problem.
https://github.com/ALMA-IMF/notebooks/blob/master/ConfettiQA.ipynb
Preliminaries: skip this
from spectral_cube import SpectralCube import warnings warnings.simplefilter('ignore')
%matplotlib inline import pylab as pl from astropy.visualization import simple_norm
from astropy import units as u
G008.67 Continuum
This is the G008.67 continuum image in Band 3.
It has “confetti” pieces in the model image, but there is no problem: no artificial point sources are introduced.
contmodel = SpectralCube.read('/orange/adamginsburg/ALMA_IMF/2017.1.01355.L/imaging_results/G008.67_B3_uid___A001_X1296_X1c1_continuum_merged_12M_robust-0.5_selfcal5_finaliter.model.tt0', format='casa_image') contimage = SpectralCube.read('/orange/adamginsburg/ALMA_IMF/2017.1.01355.L/imaging_results/G008.67_B3_uid___A001_X1296_X1c1_continuum_merged_12M_robust-0.5_selfcal5_finaliter.image.tt0', format='casa_image') contresid = SpectralCube.read('/orange/adamginsburg/ALMA_IMF/2017.1.01355.L/imaging_results/G008.67_B3_uid___A001_X1296_X1c1_continuum_merged_12M_robust-0.5_selfcal5_finaliter.residual.tt0', format='casa_image')
# zoom in contslc = (0, slice(950,1050), slice(1900,2050))
pl.figure(figsize=(15,15)) pl.imshow(contmodel[contslc].value, norm=simple_norm(contmodel[contslc].value, max_percent=99.995, stretch='asinh'), interpolation='none', origin='lower') _=pl.title("model")
data:image/s3,"s3://crabby-images/e2315/e231520cf5e2cc92aefce844cc4ff4cd5b533420" alt=""
pl.figure(figsize=(15,15)) im = contimage[0][contslc[1:]].value pl.imshow(im, norm=simple_norm(im, stretch='log', max_percent=99.995), interpolation='none', origin='lower') _=pl.title("image")
data:image/s3,"s3://crabby-images/25db1/25db1e643b79fa10e68cc3620de4b6a82fc136e7" alt=""
pl.figure(figsize=(15,15)) im = contresid[0][contslc[1:]].value pl.imshow(im, norm=simple_norm(im, stretch='linear'), interpolation='none', origin='lower') _=pl.title("Residual")
data:image/s3,"s3://crabby-images/ef119/ef1198a3e010a58f9ab463ba34475590bb1ba9ed" alt=""
G008.67 Cube
The G008.67 cube does have a problem!
cube = SpectralCube.read('/orange/adamginsburg/ALMA_IMF/2017.1.01355.L/imaging_results/G008.67_B3_spw0_12M_n2hp.image', format='casa_image').with_spectral_unit(u.km/u.s, velocity_convention='radio') resid = SpectralCube.read('/orange/adamginsburg/ALMA_IMF/2017.1.01355.L/imaging_results/G008.67_B3_spw0_12M_n2hp.residual', format='casa_image').with_spectral_unit(u.km/u.s, velocity_convention='radio') model = SpectralCube.read('/orange/adamginsburg/ALMA_IMF/2017.1.01355.L/imaging_results/G008.67_B3_spw0_12M_n2hp.model', format='casa_image').with_spectral_unit(u.km/u.s, velocity_convention='radio')
xslc = slice(1620,1654) yslc = slice(709,743) cubeslice = (slice(None), yslc, xslc) cube1slice = (98, yslc, xslc)
Confetti: a false (?) point source
In the image below, we see a new source introduced in the 35.140 km/s panel.
There is no comparable source in either of the adjacent panels!
That means either there is a genuinely pointlike source with linewidth much narrower than 0.77 km/s, or this source is fake.
specpix = np.arange(94,94+9) panels = cube[cubeslice].plot_channel_maps(3,3,specpix, fig_smallest_dim_inches=15, norm=simple_norm(cube[cube1slice].value))
data:image/s3,"s3://crabby-images/b5633/b563398500350c6a395defd56391353685c5297d" alt=""
It is caused by one hot (bright) pixel surrounded by many faint pixels
panels = model[cubeslice].plot_channel_maps(3,3,specpix, fig_smallest_dim_inches=15, norm=simple_norm(model[cube1slice].value, stretch='log', max_percent=99.93))
data:image/s3,"s3://crabby-images/93297/932974270aa46ecf0a5591b61d1ec693e6d0b8b4" alt=""
There is no sign of it in the residual - it is apparently canceled out between positive and negative components added to the model
panels = resid[cubeslice].plot_channel_maps(3,3,specpix, fig_smallest_dim_inches=15)
data:image/s3,"s3://crabby-images/74a6c/74a6c797f1b08fae623b6076039a02a2eb87ad61" alt=""
The manifestation in the spectra is a very sharp peak at just one pixel.
pl.figure(figsize=(14,6)) xx,yy=1638,725 cube[:,yy,xx].quicklook() resid[:,yy,xx].quicklook() modspec = model[:,yy,xx] pl.plot(cube.spectral_axis, modspec*cube.pixels_per_beam, label='model')
data:image/s3,"s3://crabby-images/b3cce/b3cceb486392bd6953c70986a41acb27fd6f02d9" alt=""
Pixels to either side look fine
pl.figure(figsize=(14,14)) ii = 1 for dx in (-1,0,1): for dy in (-1,0,1): ax = pl.subplot(3, 3, ii) ii +=1 cube[:,yy+dy,xx+dx].quicklook() resid[:,yy+dy,xx+dx].quicklook() modspec = model[:,yy+dy,xx+dx] ax.plot(cube.spectral_axis, modspec*cube.pixels_per_beam, label='model') ax.set_title(f"dx={dx} dy={dy}")
data:image/s3,"s3://crabby-images/8f216/8f216a0832e1073be6b3960c3b1fc93660fc48b3" alt=""
When is confetti not a problem?
Here is an example you might think is “confetti”, but is a real source
xc, yc = 1812, 905 xslc = slice(xc-12,xc+12) yslc = slice(yc-12,yc+12) cubeslice = (slice(94,94+9), yslc, xslc) cube1slice = (94, yslc, xslc)
specpix = np.arange(9) panels = cube[cubeslice].plot_channel_maps(3,3,specpix, fig_smallest_dim_inches=15, norm=simple_norm(cube[cube1slice].value, min_cut=cube[cubeslice].min().value, max_cut=cube[cubeslice].max().value, stretch='linear'))
data:image/s3,"s3://crabby-images/81e7d/81e7da763991854b049f1e26a9ba0458c47c5e46" alt=""
panels = model[cubeslice].plot_channel_maps(3,3,specpix, fig_smallest_dim_inches=15, norm=simple_norm(model[cube1slice].value, stretch='asinh', max_percent=99.9, min_cut=model[cubeslice].min().value, max_cut=model[cubeslice].max().value, ))
data:image/s3,"s3://crabby-images/b4b20/b4b20bf5b6a15e7e7405bcd5a3804bca7c9a6a5c" alt=""
panels = resid[cubeslice].plot_channel_maps(3,3,specpix, fig_smallest_dim_inches=15)
data:image/s3,"s3://crabby-images/46397/46397a0613d9147d339535fa43ff7d66c39cf7ae" alt=""
pl.figure(figsize=(14,14)) ii = 1 for dx in (-1,0,1): for dy in (-1,0,1): ax = pl.subplot(3, 3, ii) ii +=1 cube[:,yc+dy,xc+dx].quicklook() resid[:,yc+dy,xc+dx].quicklook() modspec = model[:,yc+dy,xc+dx] ax.plot(cube.spectral_axis, modspec*cube.pixels_per_beam, label='model') ax.set_title(f"dx={dx} dy={dy}")
data:image/s3,"s3://crabby-images/13a1a/13a1a6c266b81d25c63eee827160b883a67a1a1c" alt=""
Conclusion
“Confetti” is a problem, but it is not trivial to find in the model data alone. It exhibits no features in the residual.
Key features to look out for are:
- Narrow-line features (single channel)
- Extremely bright pointlike peaks in the model (note that this is not independent evidence of a problem! All point sources occupy single pixels in the model image by definition!)
- Bright pointlike peaks sitting on top of slightly extended negative backgrounds in the model (this is how the model is “canceled out” in the residual)