- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我注意到 4.1 MB/s @50fps 1280x720 bgr8。
.....和 3.7 MB/s @50fps 1280x720 单声道8。
我预计灰度的带宽消耗会减少大约 3 倍。
我完全编辑了我的问题以简化并使其更直接。
下面是我的简单 C++ 程序及其输出,它可以重现我的发现。 lenna.png
#include <iostream>
#include <vector>
#include <opencv2/imgproc/imgproc.hpp> // gray
#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
using namespace cv;
using namespace std;
int main( int argc, char** argv )
{
Mat im, imGray;
im = imread( "lenna.png", IMREAD_COLOR ); // Read the file
imGray = imread( "lenna.png", IMREAD_GRAYSCALE ); // Read the file
if( im.empty() ) // Check for invalid input
{
cout << "Could not open or find the image" << std::endl ;
return -1;
}
if(true){
std::vector<int> params;
params.resize(9, 0);
params[0] = cv::IMWRITE_JPEG_QUALITY;
params[1] = 80;
params[2] = cv::IMWRITE_JPEG_PROGRESSIVE;
params[3] = 0;
params[4] = cv::IMWRITE_JPEG_OPTIMIZE;
params[5] = 0;
params[6] = cv::IMWRITE_JPEG_RST_INTERVAL;
params[7] = 0;
std::vector< uchar > buffer, bufferGray;
if (cv::imencode(".jpeg", im, buffer, params))
{
float cRatio = (float)(im.rows * im.cols * im.elemSize())
/ (float)buffer.size();
printf("BGR8 Jpeg image size: %lu KB, Compression Ratio: 1:%.2f\n", buffer.size()/1024, cRatio);
}
else
{
printf("cv::imencode (jpeg) failed on bgr8 image\n");
}
if (cv::imencode(".jpeg", imGray, bufferGray, params))
{
float cRatio = (float)(imGray.rows * imGray.cols * imGray.elemSize())
/ (float)bufferGray.size();
printf("MONO8 Jpeg image size: %lu KB, Compression Ratio: 1:%.2f\n\n", bufferGray.size()/1024, cRatio);
}
else
{
printf("cv::imencode (jpeg) failed on mono8 image\n");
}
}
imshow( "BGR8", im );
imshow( "MONO8", imGray );
waitKey(0);
return 0;
}
g++ -g -O3 main.cpp -o main pkg-config --libs --cflags opencv4
jai@jai:~$ opencv_version
4.2.0
jai@jai:~$ opencv_version -v | grep jpeg
JPEG: /usr/lib/x86_64-linux-gnu/libjpeg.so (ver 80)
jai@jai:~$ ldconfig -p | grep jpeg
libmjpegutils-2.1.so.0 (libc6,x86-64) => /lib/x86_64-linux-gnu/libmjpegutils-2.1.so.0
libjpegxr.so.0 (libc6,x86-64) => /lib/x86_64-linux-gnu/libjpegxr.so.0
libjpeg.so.8 (libc6,x86-64) => /lib/x86_64-linux-gnu/libjpeg.so.8
libjpeg.so (libc6,x86-64) => /lib/x86_64-linux-gnu/libjpeg.so
libgdcmjpeg16.so.3.0 (libc6,x86-64) => /lib/x86_64-linux-gnu/libgdcmjpeg16.so.3.0
libgdcmjpeg16.so (libc6,x86-64) => /lib/x86_64-linux-gnu/libgdcmjpeg16.so
libgdcmjpeg12.so.3.0 (libc6,x86-64) => /lib/x86_64-linux-gnu/libgdcmjpeg12.so.3.0
libgdcmjpeg12.so (libc6,x86-64) => /lib/x86_64-linux-gnu/libgdcmjpeg12.so
libgdcmjpeg8.so.3.0 (libc6,x86-64) => /lib/x86_64-linux-gnu/libgdcmjpeg8.so.3.0
libgdcmjpeg8.so (libc6,x86-64) => /lib/x86_64-linux-gnu/libgdcmjpeg8.so
jai@jai:~$
我检查了 opencv4、opencv3.4.0 和 opencv3.4.9。
最佳答案
JPEG 在其默认编码器设置中执行 4:2:0 chroma subsampling .因此,彩色图像的带宽是灰度图像的三倍的假设是错误的。相反,它应该是因子 1,5。但另外:
关于opencv - 为什么 cv::imencode 为 bgr8 和 mono8 图像提供相似大小的输出缓冲区?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62975064/
我尝试将 BGR 转换为 YCrCb 以增加亮度并将其转换回 BGR cvSplit(亮度, y, cr, cb, 0); << 拆分不需要顺序吧? ...对亮度分量做点什么 cvMerge(temp
我正在将 OpenCV 与 Python 结合使用。我有一张图片,我想要做的是将 BGR 值 [0, 0, 255] 的所有像素设置为 [0, 255, 255]。 我问了一个previous que
java中BufferedImage判断图像通道顺序并转RGB/BGR 一般来说Java ImageIO处理读取图像时,一般是RGB或ARGB格式,但是有的时候,我们需要图像是BGR格式, 比如
我有一张以白纸为背景的叶子图片,我需要去除噪声(黄点)并获取叶子的像素值(bgr)。 我使用绿色阈值来检测叶子并用原始图像对其进行掩蔽。我使用 cv2.mean 来获取像素值,但它计算了所有像素,包括
RGB 颜色由三个分量组成:红色 (0-255)、绿色 (0-255) 和蓝色 (0-255)。 BGR 色彩空间到底是什么?它与 RGB 色彩空间有何不同? 最佳答案 关于字节顺序。 RGB 是一个
我想将(很多)JPEG 图像转换为 Sun Raster 格式(例如,参见 here),因为我的程序只能使用这种格式。 问题是我的程序只允许旧类型的图像 或标准,即像素以 BGR 顺序写入。 (我应该
我有一些 BGR 图片: cv::Mat image; 我想从图像中的所有像素中减去矢量: [10, 103, 196] 意味着所有像素的蓝色 channel 将减少 10,绿色 channel 减少
我正在尝试将图像从 RBG(OpenCV 中的 BGR)手动转换为 YCbCr 色彩空间。 我的图像是一张 png 彩色图像,宽度为 800,高度为 600,3 个 channel ,16 位深度。
我知道如何将字节数组转换为图像。这是我的代码: //Here create the Bitmap to the know height, width and format Bitmap bmp = n
我正在使用 libjpeg 将 jpeg 图像从磁盘解码到堆上分配的内存缓冲区。我使用 jpeg_read_scanlines 从文件中读取和解码每个扫描线。这工作得很好,将每个像素解码为 24 位
我正在使用 OpenCV 库进行图像处理。 我想转换一个 System.Drawing.Bitmap到Image .我该怎么做? 最佳答案 Image 构造函数有一个 Bitmap 重载(假设您正在使
我有一个颜色为 BGR 的图像。如何转换 PIL 图像以高效交换每个像素的 B 和 R 元素? 最佳答案 我知道这是一个老问题,但我遇到了同样的问题并通过以下方法解决了: img = img[:,:,
好吧,我的目标很简单——尝试从包含打包/交错 BGR 数据(也可以是 RGB)的缓冲区创建 JPEG 编码图像。 NVidia 文档包含一个 example ,正确的图像输入基本上描述了here .
根据documentation ,BGR 图像在 OpenCV 中以这种方式表示: (来源:opencv.org) 我的问题:这张图片显示的数组的尺寸是多少? 最佳答案 来自 the docs 图像属
我正在从网络摄像头的缓冲区中获取位图。当我将它们分配给 PictureBox 时,红色和蓝色会颠倒过来。 我可以对位图或 PictureBox 做些什么来使红色和蓝色出现在适当的位置? 最佳答案 以下
这可能很简单,但我正在尝试将提供 RGB 字符串颜色的源转换为 Java 中 BGR 字符串的输出。我一直在为 shifting 和 Long.decode 以及 Long.toHexString 绞
GetDIBits() 没有将正确的 BGR 值传递给 COLORREF 数组: #include #include using namespace std; int main() {int i;
我已经将一些数据记录为 npy 文件。我尝试显示图像 (data[0]) 以检查它是否适用于以下代码 import numpy as np import cv2 train_data = np.loa
文档似乎没有解释 HSV->BGR 转换的预期输入范围。这是一些示例代码,我试图在将其转换为 HSV 后取回原始 BGR 值。有谁知道预期的缩放比例? #include #include cv::
我正在从 YUV420 解码器捕获原始输出。我得到了三个指针:分别是 Y(1920*1080)、U(960*540) 和 V(960*540)。 我想使用 OpenCV 将图像保存为 JPEG。我尝试
我是一名优秀的程序员,十分优秀!