Halcon联合C#的口罩佩戴实时识别

3 篇文章 0 订阅
1 篇文章 0 订阅

记录大学作品,先展示一下最终成品
运行前
在这里插入图片描述

识别通过
在这里插入图片描述
识别不通过
在这里插入图片描述
目前用网络上图片测试,识别精确度大概85%,后续进一步提高精准度,并可能加入人脸识别提示框,提高受检人可视度。

言归正传,要实现halcon和c#联合口罩佩戴实时识别,以下步骤:

一、深度学习训练网络模型

首先, 使用halcon提供的深度学习工具箱开发深度学习模型,进行深度学习模型的开发和训练,训练好模型后,将模型保存为.hdl文件。
在这里插入图片描述

以下是基于halcon深度学习的步骤:

准备训练数据集,建议数据集至少包含几百至几千张图片,同时需要对数据集进行标注,标注的内容根据实际需求而定。

在这里插入图片描述

使用halcon提供的图像预处理函数对数据集进行预处理,如图像增强、裁剪、缩放等。

*数据预处理
RawDataFolder := 'ImageData/'+['OK','NG']
read_dl_classifier_data_set (RawDataFolder, 'last_folder', RawImageFiles, Labels, LabelIndices, Classes)
PreprocessedFolder := 'preprocessedFolder'
OverwritePreprocessingFolder := true
 
*RemovePreprocessingAfterExample := true
 
file_exists (PreprocessedFolder, FileExists)
if (not FileExists or OverwritePreprocessingFolder)
    if (FileExists)
        remove_dir_recursively (PreprocessedFolder)     
    endif
    make_dir (PreprocessedFolder)
    for I := 0 to |Classes| - 1 by 1
        make_dir (PreprocessedFolder + '/' + Classes[I])
    endfor
    parse_filename (RawImageFiles, BaseNames, Extensions, Directories)
    ObjectFilesOut := PreprocessedFolder + '/' + Labels + '/' + BaseNames + '.hobj'
    check_output_file_names_for_duplicates (RawImageFiles, ObjectFilesOut)
    for I := 0 to |RawImageFiles| - 1 by 1
        read_image (Image, RawImageFiles[I])
        zoom_image_size (Image, Image, DlImageWidth, DlImageHeight, 'constant')
        convert_image_type (Image, Image, 'real')
        RescaleRange:=(DlRangeMax - DlRangeMin)/255.0
        scale_image (Image, Image, RescaleRange, DlRangeMin)
        count_obj (Image, Number)
        for Index := 1 to Number by 1
            select_obj (Image, ObjectSelected, Index)
            count_channels (ObjectSelected, Channel)
            if (Channel != DlNumChannels)
                compose3(ObjectSelected, ObjectSelected, ObjectSelected, ThreeChannelImage)
                replace_obj (Image, ThreeChannelImage, Image, 1)
            endif
        endfor
        
        * Write preprocessed image to hobj file.
        write_object (Image, ObjectFilesOut[I])
    endfor
    dev_clear_window ()
    dev_disp_text ('图片预处理阶段完成!', 'window', 'top', 'left', 'black', [], [])
endif
 
read_dl_classifier_data_set (PreprocessedFolder, 'last_folder', ImageFiles, Labels, LabelsIndices, Classes) 
 
TrainingPercent := 80 
ValidationPercent := 20 
**(ValidationImages, ValidationLabels)、测试集(TestImages, TestLabels)
split_dl_classifier_data_set (ImageFiles, Labels, TrainingPercent, ValidationPercent, TrainingImages, TrainingLabels, ValidationImages, ValidationLabels, TestImages, TestLabels) 
stop ()

使用halcon提供的深度学习工具箱进行模型的开发和训练,halcon支持多种深度学习模型,如卷积神经网络(CNN)、循环神经网络(RNN)等。
在模型的开发过程中,需要选择合适的网络结构、损失函数、优化算法等,并进行超参数调优,以达到最优的识别效果。

**设置超参数**
*设置类别超参数
set_dl_classifier_param (DLClassifierHandle, 'classes', Classes) 
BatchSize := 5
set_dl_classifier_param (DLClassifierHandle, 'batch_size', BatchSize) 
 
try 
    set_dl_classifier_param (DLClassifierHandle, 'runtime_init', 'immediately') 
catch (Exception) 
    dev_disp_error_text (Exception) 
    stop () 
endtry 
 
InitialLearningRate := 0.001 
set_dl_classifier_param (DLClassifierHandle, 'learning_rate', InitialLearningRate) 
 
 
LearningRateStepEveryNthEpoch := 50
LearningRateStepRatio := 0.1 
NumEpochs := 100

使用训练好的模型进行图像识别,可以使用halcon提供的深度学习函数进行图像分类、目标检测、语义分割等任务。

**训练分类器**
dev_clear_window () 
* 
PlotIterationInterval := 1
FileName := 'classifier_minist.hdl' 
train_fruit_classifier (DLClassifierHandle, FileName, NumEpochs, TrainingImages, TrainingLabels, ValidationImages, ValidationLabels, LearningRateStepEveryNthEpoch, LearningRateStepRatio, PlotIterationInterval, WindowHandle) 
dev_disp_text ('Press Run (F5) to continue', 'window', 'bottom', 'right', 'black', [], [])
stop ()
read_dl_classifier (FileName, DLClassifierHandle)
* 
* Compute the confusion matrix for the validation data set.
get_predicted_classes (ValidationImages, DLClassifierHandle, PredictedClassesValidation)
gen_confusion_matrix (ValidationLabels, PredictedClassesValidation, [], [], WindowHandle, ConfusionMatrix)
dev_disp_text ('Validation data', 'window', 'top', 'left', 'gray', 'box', 'false')
dev_disp_text ('Press Run (F5) to continue', 'window', 'bottom', 'right', 'black', [], [])
stop ()

二、halcon中实现检测功能

然后,在halcon中读取已经训练好的网络模型,实现视频流的图像采集、图像预处理、图像检测、结果显示等功能,

read_dl_classifier ('classifier_minist.hdl', DLClassifierHandle)   
get_dl_classifier_param (DLClassifierHandle, 'image_range_min', DlRangeMin)
get_dl_classifier_param (DLClassifierHandle, 'image_range_max', DlRangeMax)
get_dl_classifier_param (DLClassifierHandle, 'image_width', DlImageWidth)
get_dl_classifier_param (DLClassifierHandle, 'image_height', DlImageHeight)
WindowWidth:=800
WindowHeight:=600
dev_open_window (0, 0, WindowWidth, WindowHeight, 'black', WindowHandle)
open_framegrabber ('DirectShow', 1, 1, 0, 0, 0, 0, 'default', 8, 'rgb', -1, 'false', 'default', '[0] USB2.0 HD UVC WebCam', 0, -1, AcqHandle)
grab_image_start (AcqHandle, -1)
while (true)
    grab_image_async (Image, AcqHandle, -1)
    zoom_image_size (Image, Image, DlImageWidth, DlImageHeight, 'constant')
    convert_image_type (Image, Image, 'real')
    RescaleRange:=(DlRangeMax - DlRangeMin)/255.0
    scale_image (Image, Image, RescaleRange, DlRangeMin)
    apply_dl_classifier (Image, DLClassifierHandle, DLClassifierResultHandle)  
    get_dl_classifier_result (DLClassifierResultHandle, 'all', 'predicted_classes', PredictedClass)   
    Text := 'Predicted class: ' + PredictedClass
    if (PredictedClass == 'OK')
        disp_message (WindowHandle, Text, 'window', 12, 12, 'green', 'false')
    else
        disp_message (WindowHandle, Text, 'window', 12, 12, 'red', 'false')       
    endif   
endwhile
close_framegrabber (AcqHandle)

并把代码导出C#文件。
在这里插入图片描述

三、联合C#进行软件封装

接下来,使用C#开发图形界面,并引用halcon封装的dll动态库,在C#中使用halcon提供的HOperatorSet.ReadDlClassifier函数加载网络模型,将深度学习模型导入到C#中。

在这里插入图片描述
引入C#文件,实现图像检测以及结果显示等功能。再通过C#中使用多线程技术,实现实时识别功能。
在这里插入图片描述

最终实现效果为:通过摄像头实时采集图像,使用halcon深度学习模型进行口罩佩戴识别,将结果以图片形式显示在C#图形界面上,实现口罩佩戴的实时监测。

  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: 基于HALCON联合C的开发方式,可以实现高效、可靠的机器视觉应用。 HALCON是一种功能强大的机器视觉库,提供了丰富的图像处理和分析算法。而C语言是一种通用的编程语言,具有广泛的应用领域。将HALCON与C语言结合使用,可以充分发挥两者的优势,实现更复杂的图像处理任务。 在开发过程中,可以使用C语言编写程序的框架和逻辑,然后调用HALCON提供的函数完成图像处理的实际操作。HALCON提供了丰富的函数接口,方便开发人员进行图像的获取、预处理、分析和识别等操作。 需要注意的是,使用HALCON联合C进行开发,需要先安装HALCON的开发环境,并将HALCON的库文件和头文件正确配置到C语言开发环境中。然后,可以在C语言的开发环境中调用HALCON提供的函数,实现相关的图像处理功能。 通过HALCON联合C的开发方式,可以灵活地应对不同的图像处理需求。同时,C语言的高效性和HALCON丰富的算法支持,可以在开发过程中提供更好的性能和效果。因此,这种联合开发方式在工业视觉、自动化检测等领域具有广泛的应用前景。 ### 回答2: Halcon是一款机器视觉开发软件,与C语言可以进行联合开发。基于Halcon联合C语言的开发,可以实现更加灵活和高效的机器视觉应用。 首先,在使用Halcon进行图像处理和分析时,可以调用C语言中的一些功能来增强其处理能力。例如,使用C语言的数学库可以进行更复杂的数值计算,如矩阵运算、统计分析等。而Halcon本身对于图像的处理速度较慢,可以通过调用C语言的图像处理库来加速图像处理的速度。此外,C语言还可以用于与外部硬件进行通信,如相机、传感器等的接口控制。 另外,Halcon与C语言的联合开发还可以实现更加高级的功能和应用。通过C语言的编程能力,可以实现与其他软件和系统的对接,如与数据库进行数据交互、与控制系统进行联动控制等。这样可以将机器视觉应用与其他系统进行完美融合,实现更加智能和自动化的控制。 总的来说,基于Halcon联合C语言的开发,可以让我们充分发挥两者的优势,实现更加灵活、高效和智能的机器视觉应用。无论是图像处理的速度和精度,还是与外部系统的联动控制,都能得到更好的实现。这种联合开发的方式,可以为机器视觉应用的开发带来更多的可能性和挑战。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Single118

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值