鲲鹏社区首页
中文
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助

laplacian

函数功能

计算图像的二阶微分。

函数接口

1
void kcv_laplacian_acc(const double *_src, size_t rows, size_t cols, double *_dst);

参数

参数名

描述

取值范围

输入/输出

src

输入图像。

非空且申请内存大小为rows*cols*sizeof(double)

输入

rows

输入图像行数。

(1,16384]

输入

cols

输入图像列数。

(1, 16384]

输入

dst

输出图像。

非空且申请内存大小与src一致

输出

返回值

  • 成功:返回LITHO_IMG_STS_NO_ERR
  • 失败:返回错误码。

错误码

错误码

描述

LITHO_IMG_STS_NULL_PTR_ERR

参数“src”或“dst”存在空指针。

LITHO_IMG_STS_SIZE_ERR

参数“rows”或“cols”值小于等于1。

示例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <stdio.h>
#include <stdlib.h>
#include <complex.h>
#include <iostream>
#include <vector>
#include "kp_litho_img.h"

void test_kcv_laplacian_acc() {
    const size_t src_rows = 5; // 可调整
    const size_t src_cols = 5; // 可调整
    const size_t dst_rows = 2; // 可调整
    const size_t dst_cols = 2; // 可调整
    int length = src_rows * src_cols;
    double *src = (double *)malloc(length * sizeof(double));
    double *dst = (double *)malloc(length * sizeof(double));
    // 初始化输入图像(这里使用一个简单的5x5图像)
    double src_data[5][5] = {
        {0, 0, 0, 0, 0},
        {0, 1, 1, 1, 0},
        {0, 1, 0, 1, 0},
        {0, 1, 1, 1, 0},
        {0, 0, 0, 0, 0}
    };
    for (size_t i = 0; i < src_rows; i++) {
        for (size_t j = 0; j < src_cols; j++) {
            src[i * src_cols + j] = src_data[i][j];
        }
    }
    // 调用函数
    cv::kcv_laplacian_acc(src, src_rows, src_cols, dst);
    // 打印结果(这里只打印部分结果)
    printf("Upsampled Image:\n");
    for (size_t i = 0; i < dst_rows; i++) {
        for (size_t j = 0; j < dst_cols; j++) {
            printf("%.2f ", dst[i * dst_cols + j]);
            if (j == dst_cols - 1) {
                printf("\n");
            }
        }
    }
}
int main() {
    test_kcv_laplacian_acc();
    return 0;
}

运行结果:

1
2
3
Upsampled Image:
0.00 0.00 
0.00 0.00