main.cpp 1.19 KB
Newer Older
1
2
3
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
liucong's avatar
liucong committed
4
5
6
#include <Unet.h>
#include <SimpleLog.h>
#include <Filesystem.h>
7

liucong's avatar
liucong committed
8
int main()
9
{
liucong's avatar
liucong committed
10
11
12
13
14
15
    // 加载Unet模型
    migraphxSamples::Unet unet;
    migraphxSamples::InitializationParameterOfSegmentation initParamOfSegmentationUnet;
    initParamOfSegmentationUnet.configFilePath = CONFIG_FILE;
    migraphxSamples::ErrorCode errorCode=unet.Initialize(initParamOfSegmentationUnet);
    if(errorCode!=migraphxSamples::SUCCESS)
16
    {
liucong's avatar
liucong committed
17
18
        LOG_ERROR(stdout, "fail to initialize Unet!\n");
        exit(-1);
19
    }
liucong's avatar
liucong committed
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
    LOG_INFO(stdout, "succeed to initialize Unet\n");

    // 读取图像
    cv::Mat srcImage =cv::imread("../Resource/Images/car1.jpeg", 1);
   
    // 推理
    cv::Mat maskImage;   
    double time1 = cv::getTickCount();
    unet.Segmentation(srcImage, maskImage);
    double time2 = cv::getTickCount();
    double elapsedTime = (time2 - time1) * 1000 / cv::getTickFrequency();
    LOG_INFO(stdout, "inference time:%f ms\n", elapsedTime);
    LOG_INFO(stdout,"========== Segmentation Results ==========\n");
    LOG_INFO(stdout,"Segmentation results have been saved to ./Result.jpg\n");
    cv::imwrite("./Result.jpg", maskImage);

36
37
    return 0;
}