Healpy如何在每个像素上写标号

如何在Healpy天图上标上像素的坐标,示例如下:

import matplotlib
import healpy as hp
matplotlib.rcParams.update({'font.size': 8})
nside = 4
mmap = np.arange(hp.nside2npix(nside))
hp.mollview(mmap, title='', cbar=None)
for i in range(len(testmap)):
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi, '%d'%i)
plt.show()

效果图:
在这里插入图片描述
orthview视图:

import matplotlib
import healpy as hp
matplotlib.rcParams.update({'font.size': 8})
nside = 4
mmap = np.arange(hp.nside2npix(nside))
hp.orthview(mmap, title='', cbar=None)
for i in range(len(testmap)):
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi, '%d'%i)
plt.show()

效果图:
在这里插入图片描述
orthview半视图

import matplotlib
import healpy as hp
matplotlib.rcParams.update({'font.size': 8})
nside = 4
mmap = np.arange(hp.nside2npix(nside))
hp.orthview(mmap, title='', cbar=None, half_sky=True)
for i in range(len(testmap)):
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi, '%d'%i)
plt.show()

效果图:
在这里插入图片描述
选择某个几个像素值:

import matplotlib
matplotlib.rcParams.update({'font.size': 8})

nside_temp = 1
mmap_temp = np.zeros(hp.nside2npix(nside_temp))
mmap_temp[4] = 1
mmap_temp4 = hp.ud_grade(mmap_temp, 4)
nozeros = np.array(np.where(mmap_temp4 != 0))
nside = 4

mmap = np.arange(hp.nside2npix(nside))
hp.mollview(mmap, title='', cbar=None)

sss = 0
for i in range(len(mmap)):
    if i in nozeros:
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi + 0.12, '%d(%d)'%(i, sss), color='r')
        sss = sss + 1
    else:
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi, '%d'%i)
plt.show()

效果图:
在这里插入图片描述
rothview视图:

import matplotlib
matplotlib.rcParams.update({'font.size': 8})

nside_temp = 1
mmap_temp = np.zeros(hp.nside2npix(nside_temp))
mmap_temp[4] = 1
mmap_temp4 = hp.ud_grade(mmap_temp, 4)
nozeros = np.array(np.where(mmap_temp4 != 0))
nside = 4

mmap = np.arange(hp.nside2npix(nside))
hp.orthview(mmap, title='', cbar=None, half_sky=True)

sss = 0
for i in range(len(mmap)):
    if i in nozeros:
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi + 0.12, '%d(%d)'%(i, sss), color='r')
        sss = sss + 1
    else:
        theta, phi = hp.pix2ang(nside, i)
        hp.projtext(theta, phi, '%d'%i)
plt.show()

效果图:
在这里插入图片描述
在每个像素上画点:

import healpy as hp
import numpy as np
import matplotlib.pyplot as plt
import warnings
warnings.filterwarnings('ignore')

import matplotlib as mpl

# cmap = mpl.cm.summer

m = np.zeros(hp.nside2npix(1))
mrang = np.arange(hp.nside2npix(4))
m[3] = 1
m4 = hp.ud_grade(m, 4)
mmmm = m4*np.NAN
pixs4 = np.array(np.nonzero(m4))

mmmm[pixs4] = mrang[pixs4]
hp.orthview(mmmm, title="", half_sky=True, rot=(-20,30), cbar=None, hold=True, norm='hist')
hp.graticule()
loc = hp.pix2ang(4, np.arange(hp.nside2npix(4)), lonlat=True)
locpoint4 = hp.pix2ang(4, pixs4, lonlat=True)
hp.projscatter(loc, lonlat=True, c='r', s=5)
for i in np.arange(16):
    hp.projtext(locpoint4[0][0][i],  locpoint4[1][0][i], "%d"%i, lonlat=True, fontsize = 16)
plt.savefig('gaussian.png', dpi = 100, transparent = True, bbox_inches='tight')
plt.show()

效果图:
在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星空下0516

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值