Ripser.py学习 (2):展示
创始人
2025-05-31 13:02:36

文章目录

  • 1 一些基本库
  • 2 测试数据
  • 3 使用默认设置
  • 4 素数基础上的同伦
  • 5 设置需要计算的同伦类别
  • 6 指定撕裂滤流的最大半径
  • 7 绘制选项
    • 7.1 坐标轴范围
    • 7.2 颜色图
    • 7.3 生命周期

1 一些基本库

from ripser import ripser
from persim import plot_diagrams
import matplotlib.pyplot as plt
import numpy as np
from sklearn import datasets

2 测试数据

data = datasets.make_circles(n_samples=100)[0] + 5 * datasets.make_circles(n_samples=100)[0] 
plt.scatter(data[:, 0], data[:, 1])
plt.show()

输出如下:

3 使用默认设置

计算H0H_0H0​和H1H_1H1​并绘制:

dgms = ripser(data)['dgms']
plot_diagrams(dgms, show=True)

输出如下:

当然也可以分开展示H0H_0H0​和H1H_1H1​:

plot_diagrams(dgms, plot_only=[0], ax=plt.subplot(121))
plot_diagrams(dgms, plot_only=[1], ax=plt.subplot(122))
plt.show()

输出如下:

4 素数基础上的同伦

通过设置coeff=p,计算p≥2p\geq2p≥2时的同伦:

dgms = ripser(data, coeff=3)['dgms']
plot_diagrams(dgms, plot_only=[1], title="Homology of Z/3Z", show=True)

输出如下:

5 设置需要计算的同伦类别

默认情况下只展示H0H_0H0​和H1H_1H1​。通过设置maxdim=p,可以计算H0,…,HpH_0,\dots,H_pH0​,…,Hp​。需要注意的是,p>1p>1p>1的计算相对较慢:

dgms = ripser(data, maxdim=2)['dgms']
plot_diagrams(dgms, show=True)

输出如下:

6 指定撕裂滤流的最大半径

用于限制VR complex的最大半径,图中的坐标值可以直接体现这一点:

dgms = ripser(data, thresh=1.5)['dgms']
plot_diagrams(dgms, show=True)

输出如下:

7 绘制选项

7.1 坐标轴范围

dgms = ripser(data)['dgms']
plot_diagrams(dgms, xy_range=[-2, 10, -1, 20], show=True)

输出如下:

7.2 颜色图

查看所有可用的颜色图

import matplotlib as mpl
print(mpl.style.available)

输出如下:

['Solarize_Light2', '_classic_test_patch', '_mpl-gallery', '_mpl-gallery-nogrid', 'bmh', 'classic', 'dark_background',
'fast', 'fivethirtyeight', 'ggplot', 'grayscale',
'seaborn', 'seaborn-bright', 'seaborn-colorblind', 'seaborn-dark', 'seaborn-dark-palette', 'seaborn-darkgrid',
'seaborn-deep', 'seaborn-muted', 'seaborn-notebook', 'seaborn-paper', 'seaborn-pastel', 'seaborn-poster',
'seaborn-talk', 'seaborn-ticks', 'seaborn-white', 'seaborn-whitegrid', 'tableau-colorblind10']

添加颜色图选项:

dgms = ripser(data)['dgms']
plot_diagrams(dgms, colormap='Solarize_Light2', show=True)

输出如下:

7.3 生命周期

plot_diagrams(dgms, lifetime=True, show=True)

输出如下:

相关内容

热门资讯

日本财务大臣就日元走弱发出警告... 来源:环球市场播报 在日本央行当天稍早宣布加息并召开新闻发布会后,日元兑美元明显走软,日本财务大臣...
特朗普五天圣诞长假期不会惠及大... 来源:环球市场播报 特朗普总统签署行政命令,允许联邦雇员今年12月24日和12月26日放假,这引发...
小米17 Ultra发布在即,... 12月18日,小米公司通过官方微博宣布与徕卡的全球影像战略合作正式升级,此次升级引入全新的“战略共创...
视频丨高市早苗持续遭批,日本民... 日本首相高市早苗的涉台错误言论引发日本国内持续批评。19日,部分日本民众在东京举行抗议集会,要求高市...
一场千万美元的赌注:造一个替你... 出品|虎嗅科技组作者|李一飞编辑|陈伊凡头图|视觉中国“AI原生100”是虎嗅科技组推出针对AI原生...