Diff
checker
टेक्स्ट
टेक्स्ट
छवियां
दस्तावेज़
Excel
फ़ोल्डर्स
Legal
Enterprise
डेस्कटॉप
मूल्य
साइन इन करें
Diffchecker डेस्कटॉप डाउनलोड करें
टेक्स्ट की तुलना करें
दो टेक्स्ट फ़ाइलों के बीच अंतर ढूंढें
उपकरण
इतिहास
रियल-टाइम एडिटर
अपरिवर्तित संक्षिप्त करें
लाइन रैप बंद
लेआउट
विभाजित
संयुक्त
परिवर्तन हाइलाइट करें
स्मार्ट
शब्द
अक्षर
सिंटैक्स हाइलाइटिंग
सिंटैक्स चुनें
अनदेखा करें
टेक्स्ट बदलें
पहले अंतर पर जाएँ
इनपुट संपादित करें
Diffchecker Desktop
Diffchecker चलाने का सबसे सुरक्षित तरीका। Diffchecker Desktop ऐप पाएं: आपके diffs कभी आपके कंप्यूटर से बाहर नहीं जाते!
Desktop पाएं
resize_bgr2yuyv_diff
बनाया गया
4 वर्ष पहले
Diff कभी समाप्त नहीं होता
साफ़
निर्यात करें
शेयर करें
समझाएं
26 हटाए गए
लाइनें
कुल
हटाया गया
अक्षर
कुल
हटाया गया
इस सुविधा का उपयोग जारी रखने के लिए, अपग्रेड करें
Diff
checker
Pro
मूल्य देखें
100 लाइनें
सभी को कॉपी करें
20 जोड़े गए
लाइनें
कुल
जोड़ा गया
अक्षर
कुल
जोड़ा गया
इस सुविधा का उपयोग जारी रखने के लिए, अपग्रेड करें
Diff
checker
Pro
मूल्य देखें
94 लाइनें
सभी को कॉपी करें
#include "hls_stream.h"
#include "hls_stream.h"
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
#include "ap_int.h"
#include "common/xf_common.hpp"
#include "common/xf_common.hpp"
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
#include "common/xf_
infra
.hpp"
#include "common/xf_
utility.hpp"
#include "imgproc/xf_
resize
.hpp"
#include "imgproc/xf_cvt_color
.hpp"
#include "imgproc/xf_
cvt_color_1
.hpp"
#define DATA_WIDTH 24
#define DATA_WIDTH 24
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
#define WIDTH 1920
#define HEIGHT 1080
#define NPIX XF_NPPC1
#define NPIX XF_NPPC1
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
#define
WIDTH 3840
#define
IN_
TYPE
XF_8UC3
#define HEIGHT 2160
#define
OUT_TYPE
XF_
16UC1
#define FILTER_SIZE 3
#define
TYPE
XF_8UC3
#define
INTERPOLATION
XF_
INTERPOLATION_BILINEAR
#define MAXDOWNSCALE 9
typedef xf::cv::ap_axiu<DATA_WIDTH,1,1,1> interface_t;
typedef xf::cv::ap_axiu<DATA_WIDTH,1,1,1> interface_t;
typedef hls::stream<interface_t> stream_t;
typedef hls::stream<interface_t> stream_t;
template <int W, int TYPE, int ROWS, int COLS, int NPPC>
template <int W, int TYPE, int ROWS, int COLS, int NPPC>
void axis2xfMat (hls::stream<ap_axiu<W, 1, 1, 1> >& AXI_video_strm, xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img) {
void axis2xfMat (hls::stream<ap_axiu<W, 1, 1, 1> >& AXI_video_strm, xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img) {
ap_axiu<W, 1, 1, 1> axi;
ap_axiu<W, 1, 1, 1> axi;
const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC);
const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC);
int rows = img.rows;
int rows = img.rows;
int cols = img.cols >> XF_BITSHIFT(NPPC);
int cols = img.cols >> XF_BITSHIFT(NPPC);
assert(img.rows <= ROWS);
assert(img.rows <= ROWS);
assert(img.cols <= COLS);
assert(img.cols <= COLS);
loop_row_axi2mat:
loop_row_axi2mat:
for (int i = 0; i < rows; i++) {
for (int i = 0; i < rows; i++) {
loop_col_zxi2mat:
loop_col_zxi2mat:
for (int j = 0; j < cols; j++) {
for (int j = 0; j < cols; j++) {
#pragma HLS loop_flatten off
#pragma HLS loop_flatten off
#pragma HLS pipeline II=1
#pragma HLS pipeline II=1
AXI_video_strm.read(axi);
AXI_video_strm.read(axi);
img.write(i*rows + j, axi.data(m_pix_width - 1, 0));
img.write(i*rows + j, axi.data(m_pix_width - 1, 0));
}
}
}
}
}
}
template <int W, int TYPE, int ROWS, int COLS, int NPPC>
template <int W, int TYPE, int ROWS, int COLS, int NPPC>
void xfMat2axis(xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img, hls::stream<ap_axiu<W, 1, 1, 1> >& dst) {
void xfMat2axis(xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img, hls::stream<ap_axiu<W, 1, 1, 1> >& dst) {
ap_axiu<W, 1, 1, 1> axi;
ap_axiu<W, 1, 1, 1> axi;
int rows = img.rows;
int rows = img.rows;
int cols = img.cols >> XF_BITSHIFT(NPPC);
int cols = img.cols >> XF_BITSHIFT(NPPC);
assert(img.rows <= ROWS);
assert(img.rows <= ROWS);
assert(img.cols <= COLS);
assert(img.cols <= COLS);
const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC);
const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC);
loop_row_mat2axi:
loop_row_mat2axi:
for (int i = 0; i < rows; i++) {
for (int i = 0; i < rows; i++) {
loop_col_mat2axi:
loop_col_mat2axi:
for (int j = 0; j < cols; j++) {
for (int j = 0; j < cols; j++) {
#pragma HLS loop_flatten off
#pragma HLS loop_flatten off
#pragma HLS pipeline II = 1
#pragma HLS pipeline II = 1
if ((j == cols-1) && (i == rows-1)) {
if ((j == cols-1) && (i == rows-1)) {
axi.last = 1;
axi.last = 1;
} else {
} else {
axi.last = 0;
axi.last = 0;
}
}
axi.data = 0;
axi.data = 0;
axi.data(m_pix_width - 1, 0) = img.read(i*rows + j);
axi.data(m_pix_width - 1, 0) = img.read(i*rows + j);
axi.keep = -1;
axi.keep = -1;
dst.write(axi);
dst.write(axi);
}
}
}
}
}
}
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
void
resize
_accel(stream_t& src, stream_t& dst
,
void
bgr2yuyv
_accel(stream_t& src, stream_t& dst
) {
int src_rows, int src_cols,
int dst_rows, int dst_cols
) {
#pragma HLS INTERFACE axis register both port=src
#pragma HLS INTERFACE axis register both port=src
#pragma HLS INTERFACE axis register both port=dst
#pragma HLS INTERFACE axis register both port=dst
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
#pragma HLS INTERFACE s_axilite port=src_rows
#pragma HLS INTERFACE s_axilite port=src_cols
#pragma HLS INTERFACE s_axilite port=dst_rows
#pragma HLS INTERFACE s_axilite port=dst_cols
#pragma HLS INTERFACE s_axilite port=return
#pragma HLS INTERFACE s_axilite port=return
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
xf::cv::Mat<
TYPE, HEIGHT, WIDTH, NPIX> src_mat(
src_rows, src_cols
);
xf::cv::Mat<
IN_
TYPE, HEIGHT, WIDTH, NPIX> src_mat(
HEIGHT, WIDTH
);
xf::cv::Mat<
TYPE, HEIGHT, WIDTH, NPIX> dst_mat(
dst_rows, dst_cols
);
xf::cv::Mat<
OUT_
TYPE, HEIGHT, WIDTH, NPIX> dst_mat(
HEIGHT, WIDTH
);
#pragma HLS DATAFLOW
#pragma HLS DATAFLOW
कॉपी
कॉपी हुआ
कॉपी
कॉपी हुआ
axis2xfMat<DATA_WIDTH,
TYPE, HEIGHT, WIDTH, NPIX>(src, src_mat);
axis2xfMat<DATA_WIDTH,
IN_
TYPE, HEIGHT, WIDTH, NPIX>(src, src_mat);
xf::cv::
resize<INTERPOLATION,
TYPE, HEIGHT, WIDTH,
HEIGHT, WIDTH,
NPIX
, MAXDOWNSCALE
>(src_mat, dst_mat);
xf::cv::
bgr2yuyv<IN_TYPE, OUT_
TYPE, HEIGHT, WIDTH,
NPIX
>(src_mat, dst_mat);
xfMat2axis<DATA_WIDTH,
TYPE, HEIGHT, WIDTH, NPIX>(dst_mat, dst);
xfMat2axis<DATA_WIDTH,
OUT_
TYPE, HEIGHT, WIDTH, NPIX>(dst_mat, dst);
}
}
सेव किए गए Diffs
ऑरिजनल टेक्स्ट
फ़ाइल खोलें
#include "hls_stream.h" #include "common/xf_common.hpp" #include "common/xf_infra.hpp" #include "imgproc/xf_resize.hpp" #define DATA_WIDTH 24 #define NPIX XF_NPPC1 #define WIDTH 3840 #define HEIGHT 2160 #define FILTER_SIZE 3 #define TYPE XF_8UC3 #define INTERPOLATION XF_INTERPOLATION_BILINEAR #define MAXDOWNSCALE 9 typedef xf::cv::ap_axiu<DATA_WIDTH,1,1,1> interface_t; typedef hls::stream<interface_t> stream_t; template <int W, int TYPE, int ROWS, int COLS, int NPPC> void axis2xfMat (hls::stream<ap_axiu<W, 1, 1, 1> >& AXI_video_strm, xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img) { ap_axiu<W, 1, 1, 1> axi; const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC); int rows = img.rows; int cols = img.cols >> XF_BITSHIFT(NPPC); assert(img.rows <= ROWS); assert(img.cols <= COLS); loop_row_axi2mat: for (int i = 0; i < rows; i++) { loop_col_zxi2mat: for (int j = 0; j < cols; j++) { #pragma HLS loop_flatten off #pragma HLS pipeline II=1 AXI_video_strm.read(axi); img.write(i*rows + j, axi.data(m_pix_width - 1, 0)); } } } template <int W, int TYPE, int ROWS, int COLS, int NPPC> void xfMat2axis(xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img, hls::stream<ap_axiu<W, 1, 1, 1> >& dst) { ap_axiu<W, 1, 1, 1> axi; int rows = img.rows; int cols = img.cols >> XF_BITSHIFT(NPPC); assert(img.rows <= ROWS); assert(img.cols <= COLS); const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC); loop_row_mat2axi: for (int i = 0; i < rows; i++) { loop_col_mat2axi: for (int j = 0; j < cols; j++) { #pragma HLS loop_flatten off #pragma HLS pipeline II = 1 if ((j == cols-1) && (i == rows-1)) { axi.last = 1; } else { axi.last = 0; } axi.data = 0; axi.data(m_pix_width - 1, 0) = img.read(i*rows + j); axi.keep = -1; dst.write(axi); } } } void resize_accel(stream_t& src, stream_t& dst, int src_rows, int src_cols, int dst_rows, int dst_cols) { #pragma HLS INTERFACE axis register both port=src #pragma HLS INTERFACE axis register both port=dst #pragma HLS INTERFACE s_axilite port=src_rows #pragma HLS INTERFACE s_axilite port=src_cols #pragma HLS INTERFACE s_axilite port=dst_rows #pragma HLS INTERFACE s_axilite port=dst_cols #pragma HLS INTERFACE s_axilite port=return xf::cv::Mat<TYPE, HEIGHT, WIDTH, NPIX> src_mat(src_rows, src_cols); xf::cv::Mat<TYPE, HEIGHT, WIDTH, NPIX> dst_mat(dst_rows, dst_cols); #pragma HLS DATAFLOW axis2xfMat<DATA_WIDTH, TYPE, HEIGHT, WIDTH, NPIX>(src, src_mat); xf::cv::resize<INTERPOLATION, TYPE, HEIGHT, WIDTH, HEIGHT, WIDTH, NPIX, MAXDOWNSCALE>(src_mat, dst_mat); xfMat2axis<DATA_WIDTH, TYPE, HEIGHT, WIDTH, NPIX>(dst_mat, dst); }
परिवर्तित टेक्स्ट
फ़ाइल खोलें
#include "hls_stream.h" #include "ap_int.h" #include "common/xf_common.hpp" #include "common/xf_utility.hpp" #include "imgproc/xf_cvt_color.hpp" #include "imgproc/xf_cvt_color_1.hpp" #define DATA_WIDTH 24 #define WIDTH 1920 #define HEIGHT 1080 #define NPIX XF_NPPC1 #define IN_TYPE XF_8UC3 #define OUT_TYPE XF_16UC1 typedef xf::cv::ap_axiu<DATA_WIDTH,1,1,1> interface_t; typedef hls::stream<interface_t> stream_t; template <int W, int TYPE, int ROWS, int COLS, int NPPC> void axis2xfMat (hls::stream<ap_axiu<W, 1, 1, 1> >& AXI_video_strm, xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img) { ap_axiu<W, 1, 1, 1> axi; const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC); int rows = img.rows; int cols = img.cols >> XF_BITSHIFT(NPPC); assert(img.rows <= ROWS); assert(img.cols <= COLS); loop_row_axi2mat: for (int i = 0; i < rows; i++) { loop_col_zxi2mat: for (int j = 0; j < cols; j++) { #pragma HLS loop_flatten off #pragma HLS pipeline II=1 AXI_video_strm.read(axi); img.write(i*rows + j, axi.data(m_pix_width - 1, 0)); } } } template <int W, int TYPE, int ROWS, int COLS, int NPPC> void xfMat2axis(xf::cv::Mat<TYPE, ROWS, COLS, NPPC>& img, hls::stream<ap_axiu<W, 1, 1, 1> >& dst) { ap_axiu<W, 1, 1, 1> axi; int rows = img.rows; int cols = img.cols >> XF_BITSHIFT(NPPC); assert(img.rows <= ROWS); assert(img.cols <= COLS); const int m_pix_width = XF_PIXELWIDTH(TYPE, NPPC) * XF_NPIXPERCYCLE(NPPC); loop_row_mat2axi: for (int i = 0; i < rows; i++) { loop_col_mat2axi: for (int j = 0; j < cols; j++) { #pragma HLS loop_flatten off #pragma HLS pipeline II = 1 if ((j == cols-1) && (i == rows-1)) { axi.last = 1; } else { axi.last = 0; } axi.data = 0; axi.data(m_pix_width - 1, 0) = img.read(i*rows + j); axi.keep = -1; dst.write(axi); } } } void bgr2yuyv_accel(stream_t& src, stream_t& dst) { #pragma HLS INTERFACE axis register both port=src #pragma HLS INTERFACE axis register both port=dst #pragma HLS INTERFACE s_axilite port=return xf::cv::Mat<IN_TYPE, HEIGHT, WIDTH, NPIX> src_mat(HEIGHT, WIDTH); xf::cv::Mat<OUT_TYPE, HEIGHT, WIDTH, NPIX> dst_mat(HEIGHT, WIDTH); #pragma HLS DATAFLOW axis2xfMat<DATA_WIDTH, IN_TYPE, HEIGHT, WIDTH, NPIX>(src, src_mat); xf::cv::bgr2yuyv<IN_TYPE, OUT_TYPE, HEIGHT, WIDTH, NPIX>(src_mat, dst_mat); xfMat2axis<DATA_WIDTH, OUT_TYPE, HEIGHT, WIDTH, NPIX>(dst_mat, dst); }
अंतर खोजें