- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在 Python 中使用 OpenCV 将图像从 RGB 转换为 LMS,反之亦然。据我了解,我应该使用给定的 3x3 变换矩阵并将其乘以 3x1 RGB/LMS 矩阵。使用的转换矩阵可以在 here 中找到。
我在这个网站上探索了 previously asked questions,但不幸的是它们使用 C++,这是一种我还不精通的语言,我很难理解他们到底是如何解决他们的问题的。
到目前为止,这是我的代码:[截至 2019-05-19 已解决]
import numpy as np
import cv2
#Transformation Matrix#
MsRGB = np.zeros((3,3), dtype='float')
MHPE = np.zeros((3,3), dtype='float')
MsRGB = np.array([[0.4124564, 0.3575761, 0.1804375],
[0.2126729, 0.7151522, 0.0721750],
[0.0193339, 0.1191920, 0.9503041]])
MHPE = np.array([[ 0.4002, 0.7076, -0.0808],
[-0.2263, 1.1653, 0.0457],
[ 0, 0, 0.9182]])
Trgb2lms = MHPE @ MsRGB
Tlms2rgb = np.linalg.inv(Trgb2lms)
imgpath = "(insert file directory here)"
imgIN = cv2.imread(imgpath,cv2.IMREAD_UNCHANGED)
imgINrgb = cv2.cvtColor(imgIN, cv2.COLOR_BGR2RGB)
x,y,z = imgINrgb.shape
imgLMS = np.zeros((x,y,z), dtype='float')
imgReshaped = imgINrgb.transpose(2, 0, 1).reshape(3,-1)
imgLMS = Trgb2lms @ imgReshaped #Convert to LMS
imgOUT = Tlms2rgb @ imgLMS #Convert back to RGB
imgLMS = imgLMS.reshape(z, x, y).transpose(1, 2, 0).astype(np.uint8)
imgOUT = imgOUT.reshape(z, x, y).transpose(1, 2, 0).astype(np.uint8)
imgOUT = cv2.cvtColor(imgOUT, cv2.COLOR_RGB2BGR)
cv2.imshow('Input', imgIN)
cv2.imshow('LMS', imgLMS)
cv2.imshow('Output', imgOUT)
cv2.waitKey(0)
cv2.destroyAllWindows()
代码现在能够使用给定的变换矩阵对给定的 RGB 图像执行线性变换。结果可以在 here 中找到。
最佳答案
鉴于您的问题的上下文,存在一些错误:
T
未定义。从您的代码上下文来看,这应该是 Trgb2lms
,因此我们需要更改它们。
根据我从问题中收集到的信息,您正在对图像中的所有像素应用线性变换。为此,您需要 reshape 矩阵,使我们有三行,其中每行对应一个像素,然后展开沿列的所有像素。在那种情况下,reshape
方法是不正确的。您不仅需要打乱维度以便最后一个维度排在第一位,而且您还需要设置 reshape
的最后一个维度,使其为 -1。这意味着我们将自动填充列,使其包含图像中的像素总数。
最后,完成线性变换后,您需要将矩阵重新整形为原始图像大小。您可以使用最终的 reshape
调用并使用原始调用中的 x, y
和 z
来推断图像尺寸。请记住,当我们 reshape 时, channel 首先出现,因此我们必须再次排列尺寸。在我们进行转换后,您还需要返回无符号 8 位精度。
另外,为了进行比较,让我们通过逆变换来运行它,以确保我们拥有原始数据。
因此:
import numpy as np
import cv2
#Transformation Matrix#
MsRGB = np.zeros((3,3), dtype='float')
MHPE = np.zeros((3,3), dtype='float')
MsRGB = np.array([[0.4124564, 0.3575761, 0.1804375],
[0.2126729, 0.7151522, 0.0721750],
[0.0193339, 0.1191920, 0.9503041]])
MHPE = np.array([[ 0.4002, 0.7076, -0.0808],
[-0.2263, 1.1653, 0.0457],
[ 0, 0, 0.9182]])
Trgb2lms = MHPE @ MsRGB
# Change
Tlms2rgb = np.linalg.inv(Trgb2lms)
imgpath = "(insert filename here)"
imgIN = cv2.imread(imgpath,cv2.IMREAD_UNCHANGED)
imgINrgb = cv2.cvtColor(imgIN, cv2.COLOR_BGR2RGB)
x,y,z = imgINrgb.shape
imgLMS = np.zeros((x,y,z), dtype='float')
#imgFlatten = imgINrgb.flatten()
# Change
imgReshaped = imgINrgb.transpose(2, 0, 1).reshape(3,-1)
# Change
imgLMS = Trgb2lms @ imgReshaped
imgOUT = Tlms2rgb @ imgLMS
# New
imgLMS = imgLMS.transpose(z, x, y).permute(1, 2, 0).astype(np.uint8)
imgOUT = imgOUT.transpose(z, x, y).permute(1, 2, 0).astype(np.uint8)
关于python - 使用 OpenCV 将 RGB 图像转换为 LMS,反之亦然,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56200998/
我不明白 canvas 中的 sis id 概念。 canvas 中有多个 sis 类型的 sis id's,例如:sis_course_id,sis_user_id。 我发现的一个非常小的解释是这样
C++ 库 Eigen 给我留下了深刻的印象,它使用表达式模板在矩阵/向量计算中获得了巨大的加速。 我想在 scala 中克隆这个库。据我所知,scalas 类型系统还不够强大,无法做这样的事情,但它
我正在使用名为 Ilias ( http://www.ilias.de/ ) 的学习管理系统。我收到一个生成自定义报告的请求,该报告将详细说明所有用户和每个问题的分数。 有人知道我可以在数据库中哪里找
我正在阅读从 ADL 网站下载的 pdf 'SCORM 程序员用户指南',我了解到我们只能在 LMS 中存储一些特定的信息集;比如学习者姓名、分数等。 我想知道我能否制作一个 SCO,它可以将我的 O
我正在尝试使用 eBay Large Merchant Services API 批量上传调用。这个 API 和文档是出了名的糟糕(我发现了一篇博客文章解释了它并反对它 here )。我能找到的最接近
>>>import adaptfilt Traceback (most recent call last): File "", line 1, in import adaptfilt
以下是工作代码,它没有抛出任何错误,但我想使用 jQuery 将数据从播放 SCORM 包的播放器发送到 LMS。 代码- SCORM Player -
即使在初始化之后,SCORM 包也没有与 LMS 通信- 抛出错误- 未找到 SCORM 实现。 我的文件夹结构- -index.php -player.php -course/SCORM-cours
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以
您好,我正在寻找一种使用 JavaScript 为页面添加书签的方法,以便当用户重新打开类(class)时,它可以通过将其发送到 SCORM/Moodle 来记住他或她所在的页面。 大家有什么想法吗?
我遇到了流动问题。我正在构建一个服装类(class),该类(class)基于 SCORM 2004 第 3 版,并部署在 SABA LMS 上。我正在做的是: 我使用“API.SetValue”来设置
能否请您告诉我如何为下面的 matlab 代码的 LMS 算法绘制 MSE 曲线。提前致谢。 clc close all clear all N=input('length of sequence N
我正在开发符合 SCORM 标准的 LMS,但 Captivate 生成的内容存在一些问题。 基本上,行为是:如果您快速看到一个 SCO(captivate 生成的内容),例如有 15 张幻灯片,每张
我正在尝试从 Moodle LMS 检索以前保存的数据,但似乎有些东西不起作用。这就是我正在做的: 我将 SCORM (v2004) 包加载到 Moodle 中并执行一些操作(例如保存导航数据或设置完
我正在尝试修改以下文件,默认为 OpenEDX lms。 account_settings_factory_spec.js account_settings_view.js 但是在重新运行 paver
我正在尝试编译 lms-suit,它是 Lime Microsystems LMS 系列收发器的控制软件。从这里的 gitbub 下载: https://github.com/myriadrf/lms
我正在尝试编写一些非常简单的 LMS 批量梯度下降,但我相信我在梯度方面做错了。 theta 的数量级与初始值之间的比率对于 theta 的元素来说非常不同,因此 theta[2] 都不会t 移动(例
我尝试了 LMS 算法的示例: import numpy as np from neupy import algorithms input_data = np.array([[1, 0], [2, 2
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我想我会对这个问题采取很多态度,甚至会投一些反对票,但我真的迷路了。 我知道 SCORM 代表什么以及它有什么用处。我看到了像 scorm.com 这样的付费“引擎”,但它的起价是 2 万美元....
我是一名优秀的程序员,十分优秀!