- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想绘制一个相敏光谱图,如本出版物中所做的那样(图 3 右栏,图 4 顶部面板):https://doi.org/10.1016/j.jmr.2014.10.004
对于那些无法访问该出版物的人:这是一个时频数据集的热图,通过使用 HSV 颜色空间中的值来对数据进行颜色编码,以表示特定时间特定频率的幅度和色调表示该频率分量的相位。
此类数据集中的每个点都是一个复数。
我可以做的是将数据转换为符合我规范的 RGB(A)
数组,然后使用 imshow
进行绘制。
但这似乎有点迂回(更像是我正在寻找的函数会在后台执行此操作)。是否有一个我太盲目而无法找到的内置函数可以满足我的要求?
最佳答案
所以我改编了Matplotlib documentation中的解决方案解决我的问题,并希望在这里分享给遇到同样问题的人。
这个想法是绘制颜色编码相位图与黑色 alpha 编码模量图的叠加。
这是我的代码(缺少轴标签等,但应该很容易添加):
import numpy as np
import matplotlib.pyplot as plt
def huevalueplot(cmplxarray):
# Creating the black cover layer
black = np.full((*cmplxarray.shape, 4), 0.)
black[:,:,-1] = np.abs(cmplxarray) / np.abs(cmplxarray).max()
black[:,:,-1] = 1 - black[:,:,-1]
# Actual plot
fig, ax = plt.subplots()
# Plotting phases using 'hsv' colormap (the 'hue' part)
ax.imshow(np.angle(cmplxarray), cmap='hsv')
# Plotting the modulus array as the 'value' part
ax.imshow(black)
ax.set_axis_off()
# Create complex sample data
minval = -2
maxval = 2
step = 0.01
datareal = np.arange(minval, maxval+step, step)
dataimag = datareal * 1j
cmplxarray = np.zeros((datareal.size, datareal.size), dtype=complex)
for i in range(datareal.size):
for k in range(datareal.size):
cmplxarray[i,k] = datareal[i] + dataimag[k]
# Plot
huevalueplot(cmplxarray)
希望它对将来的人有所帮助。
关于python - Matplotlib 复数热图 : Modulus and phase as hue and value?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56577154/
我目前正在学习gradle。 我有以下代码 task simpleCopy(type: Copy){ from 'source.xml' into 'destinationFolder
尝试提交到 Hg 存储库时出现以下错误: Z:\wormcard_maker>hg commit -m "asdf" transaction abort! rollback completed abo
为什么只有 servlet 的服务阶段和 portlet 的操作和渲染阶段来处理请求? 最佳答案 Servlet API 设计用于处理从浏览器发送的 HTTP 请求并返回合适的响应。 Portlet
我已经使用下面的方法为 MySQL 数据库配置了用户定义的数据源。 WebSphere 8.5 mysql-cluster-gpl-7.4.6 mysql-connector-java-5.1.9-b
我是数字信号处理领域的新手,正在尝试了解什么是相位展开以及为什么需要它。到目前为止,我已经读到这样做是为了避免相位跳跃,并避免将 2pi 的倍数添加到两个相位之间的差异中,但我不明白为什么会发生相位跳
我正在开发一种算法来比较两个数字列表。这些列表表示使用 robust peak detection method 在信号中发现的峰.我希望想出一些方法来确定峰值是同相、异相还是两者都不是(无法确定)。
这是我在 stackoverflow 上的第一篇文章,所以如果我遇到一个彻头彻尾的傻瓜,或者如果我无法让自己完全清楚,请不要对我发火。 :-) 这是我的问题:我正在尝试编写一个 javascript
据我所知,这是组件 React 生命周期的“阶段”: 挂载:挂载是渲染 render 方法本身返回的 JSX 的阶段。更新:更新是更新组件状态并重新绘制应用程序的阶段。卸载:顾名思义,卸载是组件生命周
我有一个关于 maven pom 的问题。我有这个 pom.xml maven-antrun-plugin package
我正在学习线程和同步,我正在尝试建立一个“阶段”系统,其中第一阶段生成一条消息(为了方便起见,一个 int ),然后将其传递到第二阶段,该阶段修改它(将其乘以 2),然后将其传递到最后一个阶段,进一步
RosettaCode 给出了 Cooley–Tukey FFT 算法的简单实现 here .问题如下,是从数学和编程的角度来看的。假设一个程序的输入是一个信号的频谱,我们想要生成一个具有这样频谱的信
我正在使用 OpenCV 3.2.0 进行一些傅立叶空间计算。为了在逆 DFT 后获得相位图像,我尝试使用 cv::phase()但我注意到在某些情况下,它返回接近 2*Pi 的值(在我看来)应该返回
我试图通过 opencv python 中的 Sobel 函数获取渐变的方向。问题是当我向相位函数提供 x 和 y 方向的梯度时,它总是给我相同的结果,无论相位度数是真还是假。这是示例代码: img
快速版: 如果我所掌握的唯一信息是每个上升沿出现的时间,我可以使用什么算法来确定两个具有不同频率的方波信号之间的“相位差”? 详细版: 我正在从事一个嵌入式软件项目,遇到了一个有趣的问题。我正在从两个
在JavaScript: Understanding the Weird Parts讲师解释说,变量的内存是在所谓的创建阶段设置的(并且 undefined 已分配);然后执行阶段发生。但是,当我们不
当我运行时: kubectl get pods --field-selector=status.phase=Running 我懂了: NAME READY STATUS R
我试图了解 R 的非标准评估。这是一个示例怪癖: > f g h g(1:10) [1] "x" > h(1:10) [1] "1:10" 怎么来的? g 和 h 结果之间差异的确切来源是什么? 编辑
我发现这个代码片段是某人为引导模式编写的 Angular 指令的一部分。 //Update the visible value when the dialog is closed
这是我的: 构建.gradle task makeDirectoryStructure(type:Exec){ description 'Creates directory structure
我使用了 MongoDB 中的 mapReduce 编程的 java 教程,最终得到了以下代码: package mapReduceExample; import com.mongodb.BasicD
我是一名优秀的程序员,十分优秀!