update code warning fix to master

This commit is contained in:
Xiao Tianci 2021-06-16 17:35:23 +08:00
parent 494639ad8e
commit f5e2394f48
7 changed files with 141 additions and 118 deletions

View File

@ -59,31 +59,41 @@ uint32_t parse_bytes(const uint8_t *buf, bool intel_align) {
int parseExif(const uint8_t *buf, uint32_t len) {
bool intel_align = true;
uint32_t offset = 0;
if (!buf || len < 6) return UNKNOW_ORIENTATION;
if (!buf || len < 6) {
return UNKNOW_ORIENTATION;
}
if (!std::equal(buf, buf + 6, "Exif\0\0")) return UNKNOW_ORIENTATION;
if (!std::equal(buf, buf + 6, "Exif\0\0")) {
return UNKNOW_ORIENTATION;
}
offset += 6;
if (offset + 8 > len) return UNKNOW_ORIENTATION;
if (offset + 8 > len) {
return UNKNOW_ORIENTATION;
}
if (buf[offset] == 'I' && buf[offset + 1] == 'I') {
intel_align = true;
} else if (buf[offset] == 'M' && buf[offset + 1] == 'M') {
intel_align = false;
} else {
if (buf[offset] == 'M' && buf[offset + 1] == 'M')
intel_align = false;
else
return UNKNOW_ORIENTATION;
return UNKNOW_ORIENTATION;
}
offset += 2;
if (parse_bytes<uint16_t>(buf + offset, intel_align) != 0x2a) return UNKNOW_ORIENTATION;
if (parse_bytes<uint16_t>(buf + offset, intel_align) != 0x2a) {
return UNKNOW_ORIENTATION;
}
offset += 2;
uint32_t first_ifd_offset = parse_bytes<uint32_t>(buf + offset, intel_align);
offset += first_ifd_offset - 4;
if (offset >= len) return UNKNOW_ORIENTATION;
if (offset >= len || offset + 2 > len) {
return UNKNOW_ORIENTATION;
}
if (offset + 2 > len) return UNKNOW_ORIENTATION;
int num_entries = parse_bytes<uint16_t>(buf + offset, intel_align);
if (offset + 6 + 12 * num_entries > len) return UNKNOW_ORIENTATION;
if (offset + 6 + 12 * num_entries > len) {
return UNKNOW_ORIENTATION;
}
offset += 2;
while (num_entries > 0) {
uint16_t tag = parse_bytes<uint16_t>(buf + offset, intel_align);

View File

@ -26,8 +26,11 @@
#endif
#endif
#define ANGLE_22_5 0.39269908169872414
#define ANGLE_67_5 1.1780972450961724
constexpr float kAngle22_5 = 0.39269908169872414;
constexpr float kAngle67_5 = 1.1780972450961724;
constexpr int kCertainBorder = 2;
constexpr int kUncertainBorder = 1;
constexpr int kNotBorder = 0;
namespace mindspore {
namespace dataset {
@ -153,8 +156,8 @@ static void NonMaximumSuppression(const LiteMat &gx, const LiteMat &gy, LiteMat
float angle_value = atan2(gy_value_abs, gx_value_abs);
float edge_value = temp[y * gx.width_ + x];
float edge_pre, edge_nex;
if (angle_value < ANGLE_22_5 || angle_value > ANGLE_67_5) {
if (angle_value < ANGLE_22_5) {
if (angle_value < kAngle22_5 || angle_value > kAngle67_5) {
if (angle_value < kAngle22_5) {
edge_pre = GetEdge(temp, gx.width_, gx.height_, x - 1, y);
edge_nex = GetEdge(temp, gx.width_, gx.height_, x + 1, y);
} else {
@ -196,12 +199,12 @@ static void Hysteresis(const LiteMat &edges, uint8_t *dst, double low_thresh, do
int pos = y * edges.width_ + x;
float edge_value = edges_ptr[pos];
if (edge_value > high_thresh) {
buffer[pos] = 2;
buffer[pos] = kCertainBorder;
stack.push_back(pos);
} else if (edge_value <= low_thresh) {
buffer[pos] = 0;
buffer[pos] = kNotBorder;
} else {
buffer[pos] = 1;
buffer[pos] = kUncertainBorder;
}
}
}
@ -220,8 +223,8 @@ static void Hysteresis(const LiteMat &edges, uint8_t *dst, double low_thresh, do
continue;
}
int next = next_y * buffer_step + next_x;
if (buffer[next] == 1) {
buffer[next] = 2;
if (buffer[next] == kUncertainBorder) {
buffer[next] = kCertainBorder;
stack.push_back(next);
}
}
@ -229,7 +232,7 @@ static void Hysteresis(const LiteMat &edges, uint8_t *dst, double low_thresh, do
}
for (int i = 0; i < size; i++) {
if (buffer[i] == 2) {
if (buffer[i] == kCertainBorder) {
dst[i] = 255;
} else {
dst[i] = 0;

View File

@ -14,7 +14,7 @@
* limitations under the License.
*/
#include <math.h>
#include <cmath>
#include "lite_cv/lite_mat.h"
#include "lite_cv/image_process.h"

View File

@ -18,38 +18,36 @@
#include <cfloat>
#include <climits>
#include <cstring>
#include <cmath>
#include <cstring>
#include <limits>
#include <vector>
#include <utility>
#include <random>
#include <utility>
#include <vector>
#ifdef ENABLE_NEON
#include <arm_neon.h>
#endif
#define R2GRAY 9798
#define G2GRAY 19235
#define B2GRAY 3735
#define GRAYSHIFT 15
#define GRAYSHIFT_DELTA (1 << (GRAYSHIFT - 1))
#define U32TOU8CAST(value) ((uint8_t)std::min(value, (uint32_t)UCHAR_MAX))
#define YSCALE 0x0101
#define UTOB (-128)
#define UTOG 25
#define VTOR (-102)
#define VTOG 52
#define YTOG 18997
#define YTOGB (-1160)
#define BTOB (UTOB * 128 + YTOGB)
#define BTOG (UTOG * 128 + VTOG * 128 + YTOGB)
#define BTOR (VTOR * 128 + YTOGB)
#define Equ(a, b) ((std::fabs((a) - (b)) < 1e-6))
namespace mindspore {
namespace dataset {
constexpr uint32_t kR2Gray = 9798;
constexpr uint32_t kG2Gray = 19235;
constexpr uint32_t kB2Gray = 3735;
constexpr int32_t kGrayShift = 15;
constexpr int32_t kGrayShiftDelta = 1 << (kGrayShift - 1);
constexpr int32_t kYScale = 0x0101;
constexpr int32_t kU2B = -128;
constexpr int32_t kU2G = 25;
constexpr int32_t kV2R = -102;
constexpr int32_t kV2G = 52;
constexpr int32_t kY2G = 18997;
constexpr int32_t kY2GB = -1160;
constexpr int32_t kB2B = kU2B * 128 + kY2GB;
constexpr int32_t kB2G = kU2G * 128 + kV2G * 128 + kY2GB;
constexpr int32_t kB2R = kV2R * 128 + kY2GB;
static bool Equal(const float &a, const float &b) { return std::fabs(a - b) < 1e-6; }
static inline void InitBilinearWeight(int *data_ptr, int16_t *weight_ptr, double scale, int dst_length, int src_length,
int a) {
@ -240,7 +238,7 @@ static void ResizeBilinear1C(const unsigned char *src, int src_width, int src_he
delete[] data_buf;
}
static inline uint8_t clip(float value, int min = 0, int max = 255) {
static inline uint8_t clip(float value) {
int int_val = roundf(value);
return std::max<int32_t>(std::numeric_limits<uint8_t>::min(),
std::min<int32_t>(std::numeric_limits<uint8_t>::max(), int_val));
@ -467,18 +465,18 @@ static bool ConvertYUV420SPToBGR(const uint8_t *data, LDataType data_type, bool
u = uv_buf[0];
v = uv_buf[1];
}
uint32_t tmp_y = (uint32_t)(y_buf[0] * YSCALE * YTOG) >> 16;
uint32_t tmp_y = (uint32_t)(y_buf[0] * kYScale * kY2G) >> 16;
// b
bgr_buf[0] = std::clamp((int32_t)(-(u * UTOB) + tmp_y + BTOB) >> 6, 0, 255);
bgr_buf[0] = std::clamp((int32_t)(-(u * kU2B) + tmp_y + kB2B) >> 6, 0, 255);
// g
bgr_buf[1] = std::clamp((int32_t)(-(u * UTOG + v * VTOG) + tmp_y + BTOG) >> 6, 0, 255);
bgr_buf[1] = std::clamp((int32_t)(-(u * kU2G + v * kV2G) + tmp_y + kB2G) >> 6, 0, 255);
// r
bgr_buf[2] = std::clamp((int32_t)(-(v * VTOR) + tmp_y + BTOR) >> 6, 0, 255);
bgr_buf[2] = std::clamp((int32_t)(-(v * kV2R) + tmp_y + kB2R) >> 6, 0, 255);
tmp_y = (uint32_t)(y_buf[1] * YSCALE * YTOG) >> 16;
bgr_buf[3] = std::clamp((int32_t)(-(u * UTOB) + tmp_y + BTOB) >> 6, 0, 255);
bgr_buf[4] = std::clamp((int32_t)(-(u * UTOG + v * VTOG) + tmp_y + BTOG) >> 6, 0, 255);
bgr_buf[5] = std::clamp((int32_t)(-(v * VTOR) + tmp_y + BTOR) >> 6, 0, 255);
tmp_y = (uint32_t)(y_buf[1] * kYScale * kY2G) >> 16;
bgr_buf[3] = std::clamp((int32_t)(-(u * kU2B) + tmp_y + kB2B) >> 6, 0, 255);
bgr_buf[4] = std::clamp((int32_t)(-(u * kU2G + v * kV2G) + tmp_y + kB2G) >> 6, 0, 255);
bgr_buf[5] = std::clamp((int32_t)(-(v * kV2R) + tmp_y + kB2R) >> 6, 0, 255);
y_buf += 2;
uv_buf += 2;
@ -494,10 +492,10 @@ static bool ConvertYUV420SPToBGR(const uint8_t *data, LDataType data_type, bool
u = uv_buf[0];
v = uv_buf[1];
}
uint32_t tmp_y = (uint32_t)(y_buf[0] * YSCALE * YTOG) >> 16;
bgr_buf[0] = std::clamp((int32_t)(-(u * UTOB) + tmp_y + BTOB) >> 6, 0, 255);
bgr_buf[1] = std::clamp((int32_t)(-(u * UTOG + v * VTOG) + tmp_y + BTOG) >> 6, 0, 255);
bgr_buf[2] = std::clamp((int32_t)(-(v * VTOR) + tmp_y + BTOR) >> 6, 0, 255);
uint32_t tmp_y = (uint32_t)(y_buf[0] * kYScale * kY2G) >> 16;
bgr_buf[0] = std::clamp((int32_t)(-(u * kU2B) + tmp_y + kB2B) >> 6, 0, 255);
bgr_buf[1] = std::clamp((int32_t)(-(u * kU2G + v * kV2G) + tmp_y + kB2G) >> 6, 0, 255);
bgr_buf[2] = std::clamp((int32_t)(-(v * kV2R) + tmp_y + kB2R) >> 6, 0, 255);
}
bgr_ptr += bgr_stride;
@ -520,7 +518,7 @@ static bool ConvertRGBAToGRAY(const unsigned char *data, LDataType data_type, in
const unsigned char *data_ptr = data;
for (int y = 0; y < h; y++) {
for (int x = 0; x < w; x++) {
*ptr = (data_ptr[2] * B2GRAY + data_ptr[1] * G2GRAY + data_ptr[0] * R2GRAY + GRAYSHIFT_DELTA) >> GRAYSHIFT;
*ptr = (data_ptr[2] * kB2Gray + data_ptr[1] * kG2Gray + data_ptr[0] * kR2Gray + kGrayShiftDelta) >> kGrayShift;
ptr++;
data_ptr += 4;
}
@ -665,7 +663,7 @@ bool Crop(const LiteMat &src, LiteMat &dst, int x, int y, int w, int h) {
static bool CheckZero(const std::vector<float> &vs) {
for (int i = 0; i < vs.size(); i++) {
if (Equ(vs[i], 0.0f)) {
if (Equal(vs[i], 0.0f)) {
return true;
}
}
@ -804,6 +802,7 @@ static int PadFromPos(int p, int len, PaddBorderType pad_type) {
if (pad_type == PaddBorderType::PADD_BORDER_REPLICATE) {
return p < 0 ? 0 : len - 1;
} else {
// calculate the position of pixel in reflect mode like edcb|abcdef|edcb
return p < 0 ? -p : 2 * len - p - 2;
}
}
@ -1621,7 +1620,7 @@ bool ConvertRgbToGray(const LiteMat &src, LDataType data_type, int w, int h, Lit
const unsigned char *data_ptr = src;
for (int y = 0; y < h; y++) {
for (int x = 0; x < w; x++) {
*ptr = (data_ptr[2] * B2GRAY + data_ptr[1] * G2GRAY + data_ptr[0] * R2GRAY + GRAYSHIFT_DELTA) >> GRAYSHIFT;
*ptr = (data_ptr[2] * kB2Gray + data_ptr[1] * kG2Gray + data_ptr[0] * kR2Gray + kGrayShiftDelta) >> kGrayShift;
ptr++;
data_ptr += 3;
}

View File

@ -20,31 +20,42 @@
#include "lite_cv/lite_mat.h"
#include "lite_cv/image_process.h"
#define BITS 5
#define BITS1 15
#define TAB_SZ (1 << BITS)
#define TAB_SZ2 (TAB_SZ * TAB_SZ)
#define FLOATTOSHORT(value) (IntCastShort(round(value)))
#define REMAP_SCALE (1 << 15)
#define INTTOUCHAR(v) ((uint8_t)((unsigned)v <= UCHAR_MAX ? v : v > 0 ? UCHAR_MAX : 0))
#define SrcValue(y, x) (reinterpret_cast<double *>(src + y * 3))[x]
#define DstValue(y, x) (reinterpret_cast<double *>(dst + y * 3))[x]
constexpr int kBits = 5;
constexpr int kBits1 = 15;
constexpr int kTabSz = 1 << kBits;
constexpr int kTabSz2 = kTabSz * kTabSz;
constexpr int kRemapScale = 1 << 15;
namespace mindspore {
namespace dataset {
static int16_t BWBlock_i[TAB_SZ2][2][2];
static int16_t BWBlock_i[kTabSz2][2][2];
static double SrcValue(const double *src, const int &y, const int &x) { return (src + y * 3)[x]; }
static double &DstValue(double *dst, const int &y, const int &x) { return (dst + y * 3)[x]; }
static double GetDet3(double *src) {
double a1 = SrcValue(0, 0) * (SrcValue(1, 1) * SrcValue(2, 2) - SrcValue(1, 2) * SrcValue(2, 1));
double a2 = SrcValue(0, 1) * (SrcValue(1, 0) * SrcValue(2, 2) - SrcValue(1, 2) * SrcValue(2, 0));
double a3 = SrcValue(0, 2) * (SrcValue(1, 0) * SrcValue(2, 1) - SrcValue(1, 1) * SrcValue(2, 0));
double a1 =
SrcValue(src, 0, 0) * (SrcValue(src, 1, 1) * SrcValue(src, 2, 2) - SrcValue(src, 1, 2) * SrcValue(src, 2, 1));
double a2 =
SrcValue(src, 0, 1) * (SrcValue(src, 1, 0) * SrcValue(src, 2, 2) - SrcValue(src, 1, 2) * SrcValue(src, 2, 0));
double a3 =
SrcValue(src, 0, 2) * (SrcValue(src, 1, 0) * SrcValue(src, 2, 1) - SrcValue(src, 1, 1) * SrcValue(src, 2, 0));
return a1 - a2 + a3;
}
static int16_t IntCastShort(int value) {
return (int16_t)((unsigned)(value - SHRT_MIN) <= (unsigned)USHRT_MAX ? value : value > 0 ? SHRT_MAX : SHRT_MIN);
static uint8_t UIntToUChar(const uint32_t &v) {
return static_cast<uint8_t>(v <= UCHAR_MAX ? v : v > 0 ? UCHAR_MAX : 0);
}
static int16_t IntCastShort(const int &value) {
return static_cast<int16_t>(static_cast<unsigned>(value - SHRT_MIN) <= static_cast<unsigned>(USHRT_MAX)
? value
: value > 0 ? SHRT_MAX : SHRT_MIN);
}
static int16_t FloatToShort(float value) { return IntCastShort(round(value)); }
static void InitWBlockInter(float *wBlock, int wBlockSz) {
float scale = 1.f / wBlockSz;
for (int i = 0; i < wBlockSz; i++, wBlock += 2) {
@ -56,27 +67,27 @@ static void InitWBlockInter(float *wBlock, int wBlockSz) {
static const void *InitWBlock() {
static bool initWB = false;
int16_t *iWBlock = 0;
int16_t *iWBlock = nullptr;
int ks = 2;
iWBlock = BWBlock_i[0][0];
if (!initWB) {
float *_wblock = new float[8 * TAB_SZ];
float *_wblock = new float[8 * kTabSz];
int i, j, h1, h2;
InitWBlockInter(_wblock, TAB_SZ);
for (i = 0; i < TAB_SZ; i++) {
for (j = 0; j < TAB_SZ; j++, iWBlock += ks * ks) {
InitWBlockInter(_wblock, kTabSz);
for (i = 0; i < kTabSz; i++) {
for (j = 0; j < kTabSz; j++, iWBlock += ks * ks) {
int sum_i = 0;
for (h1 = 0; h1 < ks; h1++) {
float vy = _wblock[i * ks + h1];
for (h2 = 0; h2 < ks; h2++) {
float v = vy * _wblock[j * ks + h2];
sum_i += iWBlock[h1 * ks + h2] = FLOATTOSHORT(v * REMAP_SCALE);
sum_i += iWBlock[h1 * ks + h2] = FloatToShort(v * kRemapScale);
}
}
if (sum_i != REMAP_SCALE) {
int df = sum_i - REMAP_SCALE;
if (sum_i != kRemapScale) {
int df = sum_i - kRemapScale;
int ks2 = 1;
int tk1 = ks2;
int tk2 = ks2;
@ -99,14 +110,14 @@ static const void *InitWBlock() {
}
}
}
iWBlock -= TAB_SZ2 * ks * ks;
iWBlock -= kTabSz2 * ks * ks;
delete[] _wblock;
initWB = true;
}
return (const void *)iWBlock;
}
static uint8_t CastToFixed(int v) { return INTTOUCHAR(((v + (1 << (BITS1 - 1))) >> BITS1)); }
static uint8_t CastToFixed(int v) { return UIntToUChar(((v + (1 << (kBits1 - 1))) >> kBits1)); }
static int BorderPolate(int value, int length, PaddBorderType borderType) {
if ((unsigned)value < (unsigned)length) {
@ -345,7 +356,7 @@ static void Remap(const LiteMat &src, LiteMat &dst, LiteMat &map1, const LiteMat
const uint16_t *sa_ptr = map2.ptr<uint16_t>(y + y1) + x;
x1 = 0;
for (; x1 < bwidth; x1++) {
t_a_ptr[x1] = (uint16_t)(sa_ptr[x1] & (TAB_SZ2 - 1));
t_a_ptr[x1] = (uint16_t)(sa_ptr[x1] & (kTabSz2 - 1));
}
}
RemapBilinear(src, lite_part, xy_ptr, a_ptr, wblock, borderType, borderValue);
@ -401,7 +412,7 @@ bool WarpAffineBilinear(const LiteMat &src, LiteMat &dst, const LiteMat &M, int
const int B_SIZE = 64;
int16_t WH[B_SIZE * B_SIZE * 2];
int16_t A_Ptr[B_SIZE * B_SIZE];
int r_delta = SCALE / TAB_SZ / 2;
int r_delta = SCALE / kTabSz / 2;
int x, y, x1, y1;
for (x = 0; x < dst.width_; x++) {
a[x] = round(IM[0] * x * SCALE);
@ -426,11 +437,11 @@ bool WarpAffineBilinear(const LiteMat &src, LiteMat &dst, const LiteMat &M, int
int16_t *t_a = A_Ptr + y1 * t_bw;
x1 = 0;
for (; x1 < t_bw; x1++) {
int X = (X0 + a[x + x1]) >> (10 - BITS);
int Y = (Y0 + b[x + x1]) >> (10 - BITS);
t_xy[x1 * 2] = IntCastShort(X >> BITS);
t_xy[x1 * 2 + 1] = IntCastShort(Y >> BITS);
t_a[x1] = (int16_t)((Y & (TAB_SZ - 1)) * TAB_SZ + (X & (TAB_SZ - 1)));
int X = (X0 + a[x + x1]) >> (10 - kBits);
int Y = (Y0 + b[x + x1]) >> (10 - kBits);
t_xy[x1 * 2] = IntCastShort(X >> kBits);
t_xy[x1 * 2 + 1] = IntCastShort(Y >> kBits);
t_a[x1] = (int16_t)((Y & (kTabSz - 1)) * kTabSz + (X & (kTabSz - 1)));
}
}
@ -449,27 +460,27 @@ static void PerspectiveInvert(double *src, double *dst) {
value = 1. / value;
double v[9];
v[0] = (SrcValue(1, 1) * SrcValue(2, 2) - SrcValue(1, 2) * SrcValue(2, 1)) * value;
v[1] = (SrcValue(0, 2) * SrcValue(2, 1) - SrcValue(0, 1) * SrcValue(2, 2)) * value;
v[2] = (SrcValue(0, 1) * SrcValue(1, 2) - SrcValue(0, 2) * SrcValue(1, 1)) * value;
v[0] = (SrcValue(src, 1, 1) * SrcValue(src, 2, 2) - SrcValue(src, 1, 2) * SrcValue(src, 2, 1)) * value;
v[1] = (SrcValue(src, 0, 2) * SrcValue(src, 2, 1) - SrcValue(src, 0, 1) * SrcValue(src, 2, 2)) * value;
v[2] = (SrcValue(src, 0, 1) * SrcValue(src, 1, 2) - SrcValue(src, 0, 2) * SrcValue(src, 1, 1)) * value;
v[3] = (SrcValue(1, 2) * SrcValue(2, 0) - SrcValue(1, 0) * SrcValue(2, 2)) * value;
v[4] = (SrcValue(0, 0) * SrcValue(2, 2) - SrcValue(0, 2) * SrcValue(2, 0)) * value;
v[5] = (SrcValue(0, 2) * SrcValue(1, 0) - SrcValue(0, 0) * SrcValue(1, 2)) * value;
v[3] = (SrcValue(src, 1, 2) * SrcValue(src, 2, 0) - SrcValue(src, 1, 0) * SrcValue(src, 2, 2)) * value;
v[4] = (SrcValue(src, 0, 0) * SrcValue(src, 2, 2) - SrcValue(src, 0, 2) * SrcValue(src, 2, 0)) * value;
v[5] = (SrcValue(src, 0, 2) * SrcValue(src, 1, 0) - SrcValue(src, 0, 0) * SrcValue(src, 1, 2)) * value;
v[6] = (SrcValue(1, 0) * SrcValue(2, 1) - SrcValue(1, 1) * SrcValue(2, 0)) * value;
v[7] = (SrcValue(0, 1) * SrcValue(2, 0) - SrcValue(0, 0) * SrcValue(2, 1)) * value;
v[8] = (SrcValue(0, 0) * SrcValue(1, 1) - SrcValue(0, 1) * SrcValue(1, 0)) * value;
v[6] = (SrcValue(src, 1, 0) * SrcValue(src, 2, 1) - SrcValue(src, 1, 1) * SrcValue(src, 2, 0)) * value;
v[7] = (SrcValue(src, 0, 1) * SrcValue(src, 2, 0) - SrcValue(src, 0, 0) * SrcValue(src, 2, 1)) * value;
v[8] = (SrcValue(src, 0, 0) * SrcValue(src, 1, 1) - SrcValue(src, 0, 1) * SrcValue(src, 1, 0)) * value;
DstValue(0, 0) = v[0];
DstValue(0, 1) = v[1];
DstValue(0, 2) = v[2];
DstValue(1, 0) = v[3];
DstValue(1, 1) = v[4];
DstValue(1, 2) = v[5];
DstValue(2, 0) = v[6];
DstValue(2, 1) = v[7];
DstValue(2, 2) = v[8];
DstValue(dst, 0, 0) = v[0];
DstValue(dst, 0, 1) = v[1];
DstValue(dst, 0, 2) = v[2];
DstValue(dst, 1, 0) = v[3];
DstValue(dst, 1, 1) = v[4];
DstValue(dst, 1, 2) = v[5];
DstValue(dst, 2, 0) = v[6];
DstValue(dst, 2, 1) = v[7];
DstValue(dst, 2, 2) = v[8];
}
}
@ -532,15 +543,15 @@ bool WarpPerspectiveBilinear(const LiteMat &src, LiteMat &dst, const LiteMat &M,
int16_t *t_a = TA + y1 * tw;
for (int x1 = 0; x1 < tw; x1++) {
double W = WV + IM[6] * x1;
W = W ? TAB_SZ / W : 0;
W = W ? kTabSz / W : 0;
double fX = std::max((double)INT_MIN, std::min((double)INT_MAX, (XV + IM[0] * x1) * W)); // NOLINT
double fY = std::max((double)INT_MIN, std::min((double)INT_MAX, (YV + IM[3] * x1) * W)); // NOLINT
int X = round(fX);
int Y = round(fY);
xy[x1 * 2] = IntCastShort(X >> BITS);
xy[x1 * 2 + 1] = IntCastShort(Y >> BITS);
t_a[x1] = (int16_t)((Y & (TAB_SZ - 1)) * TAB_SZ + (X & (TAB_SZ - 1)));
xy[x1 * 2] = IntCastShort(X >> kBits);
xy[x1 * 2 + 1] = IntCastShort(Y >> kBits);
t_a[x1] = (int16_t)((Y & (kTabSz - 1)) * kTabSz + (X & (kTabSz - 1)));
}
}
LiteMat _matA(tw, th, 1, TA, LDataType::UINT16);

View File

@ -22,8 +22,8 @@ import subprocess
import sys
import mindspore
def main():
def main():
"""Entry point for cache service"""
cache_admin_dir = os.path.join(os.path.dirname(mindspore.__file__), "bin")
os.chdir(cache_admin_dir)

View File

@ -13,8 +13,8 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef MINDSPORE_CCSRC_MINDDATA_DATASET_ENGINE_DATASETOPS_SOURCE_ALBUM_ANDROID_OP_H_
#define MINDSPORE_CCSRC_MINDDATA_DATASET_ENGINE_DATASETOPS_SOURCE_ALBUM_ANDROID_OP_H_
#ifndef MINDSPORE_LITE_MINDDATA_WRAPPER_ALBUM_OP_ANDROID_H_
#define MINDSPORE_LITE_MINDDATA_WRAPPER_ALBUM_OP_ANDROID_H_
#include <deque>
#include <memory>
@ -190,4 +190,4 @@ class AlbumOp {
};
} // namespace dataset
} // namespace mindspore
#endif // MINDSPORE_CCSRC_MINDDATA_DATASET_ENGINE_DATASETOPS_SOURCE_ALBUM_ANDROID_OP_H_
#endif // MINDSPORE_LITE_MINDDATA_WRAPPER_ALBUM_OP_ANDROID_H_