m基于Faster R-CNN网络的火灾识别系统matlab仿真,带GUI界面

1.算法仿真效果

使用matlab2022a版本仿真结果如下:


测试1:



测试2:



测试3:



测试4:



通过matlab操作界面,会对图片中的火灾区域进行识别,并输出检测框。


识别火灾之后,会同步更新输出:



此外,本程序还提供了其他更多的样本供测试使用:



2.算法涉及理论知识概要

Faster R-CNN是一种基于深度学习的目标检测算法,具有较高的准确性和效率,被广泛应用于各种场景的目标检测任务中。下面我们将详细介绍基于Faster R-CNN网络的火灾识别系统的原理和数学公式。


Faster R-CNN是一种基于Region proposal network(RPN)和Fast R-CNN的深度学习目标检测算法。该算法主要由两部分组成:RPN网络和Fast R-CNN网络。


2.1RPN网络

RPN网络是一种基于卷积神经网络的端到端目标检测算法,它可以生成候选区域(Region proposals),并利用卷积神经网络对候选区域进行特征提取。RPN网络通过滑动窗口的方式生成不同大小的候选区域,并对每个候选区域进行分类和回归,以确定其是否包含目标以及目标的具体位置和大小。


RPN网络的数学公式可以表示为:


RPN(x, y, w, h, cls) = [max(0, B1 + exp(B2 × (x - B3) × (y - B4)))] × w × h × cls


其中,(x, y, w, h)表示候选区域的位置和大小,cls表示候选区域的类别得分。B1、B2、B3、B4是RPN网络的参数,可以通过训练得到。


2.2Fast R-CNN网络

Fast R-CNN网络是一种基于卷积神经网络的目标检测算法,它可以对输入图像中的每个区域进行特征提取,并输出目标检测结果。Fast R-CNN网络主要由卷积神经网络、Region proposal网络和全连接层组成。卷积神经网络用于提取输入图像的特征,Region proposal网络用于生成候选区域,全连接层用于对候选区域进行分类和回归,以确定目标的具体位置和大小。


Faster R-CNN的数学公式可以表示为:


Faster R-CNN = (RPN + Fast R-CNN) + NMS


其中,RPN和Fast R-CNN是两个主要的组成部分,NMS(Non-Maximum Suppression)是一种后处理方法,用于去除冗余的检测框。


Fast R-CNN网络的数学公式可以表示为:


Fast R-CNN(x, y, w, h, cls) = [max(0, B1 + exp(B2 × (x - B3) × (y - B4)))] × w × h × cls + B5


其中,(x, y, w, h)表示目标的位置和大小,cls表示目标的类别得分。B1、B2、B3、B4、B5是Fast R-CNN网络的参数,可以通过训练得到。


2.3 NMS

NMS的数学公式可以表示为:


NMS(IoU) = argmax{cls} (IoU < Threshold)


其中,IoU表示检测框与真实框的交并比,cls表示检测框的类别得分,Threshold是交并比的阈值。NMS算法根据IoU的大小对检测框进行排序,选择IoU最小的检测框作为最终的检测结果。


基于Faster R-CNN网络的火灾识别系统是一种利用深度学习算法实现火灾检测的方法,具有较高的准确性和效率。该系统的核心是Faster R-CNN算法,该算法主要由RPN网络和Fast R-CNN网络组成,可以对输入图像中的每个区域进行特征提取并输出目标检测结果。


3.MATLAB核心程序

% --- Executes on button press in pushbutton1.

function pushbutton1_Callback(hObject, eventdata, handles)

% hObject    handle to pushbutton1 (see GCBO)

% eventdata  reserved - to be defined in a future version of MATLAB

% handles    structure with handles and user data (see GUIDATA)

global im;

cla (handles.axes1,'reset')

cla (handles.axes2,'reset')

set(handles.edit1,'string',num2str(0));

set(handles.edit2,'string',num2str(0));

set(handles.edit5,'string',num2str(0));

set(handles.edit6,'string',num2str(0));


axes(handles.axes1);

[filename,pathname]=uigetfile({'*.bmp;*.jpg;*.png;*.jpeg;*.tif'},'选择一个图片','F:\test');

str=[pathname filename];

% 判断文件是否为空,也可以不用这个操作!直接读入图片也可以的

% im = imread(str);

% imshow(im)

if isequal(filename,0)||isequal(pathname,0)

warndlg('please select a picture first!','warning');

return;

else

im = imread(str);

imshow(im);

end



% --- Executes on button press in pushbutton2.

function pushbutton2_Callback(hObject, eventdata, handles)

% hObject    handle to pushbutton2 (see GCBO)

% eventdata  reserved - to be defined in a future version of MATLAB

% handles    structure with handles and user data (see GUIDATA)

global im;

load net015.mat

In_layer_Size   = [224 224 3];

I               = im;

I               = imresize(I,In_layer_Size(1:2));

[bboxes,scores] = detect(detector,I);


if isempty(bboxes)==0

I1              = insertObjectAnnotation(I,'rectangle',bboxes,scores);

axes(handles.axes2);

imshow(I1)

else


I1              = I;

axes(handles.axes2);

imshow(I1)

end

bboxes

scores

set(handles.edit1,'string',num2str((bboxes(1))));

set(handles.edit6,'string',num2str((bboxes(2))));


set(handles.edit2,'string',num2str((bboxes(3))*(bboxes(4))));

set(handles.edit5,'string',num2str(max(scores)));

% --- Executes on button press in pushbutton3.




% --- Executes on button press in pushbutton5.

function pushbutton5_Callback(hObject, eventdata, handles)

% hObject    handle to pushbutton5 (see GCBO)

% eventdata  reserved - to be defined in a future version of MATLAB

% handles    structure with handles and user data (see GUIDATA)

clc;

clear;

close all;



function edit1_Callback(hObject, eventdata, handles)

% hObject    handle to edit1 (see GCBO)

% eventdata  reserved - to be defined in a future version of MATLAB

% handles    structure with handles and user data (see GUIDATA)


% Hints: get(hObject,'String') returns contents of edit1 as text

%        str2double(get(hObject,'String')) returns contents of edit1 as a double



% --- Executes during object creation, after setting all properties.

function edit1_CreateFcn(hObject, eventdata, handles)

% hObject    handle to edit1 (see GCBO)

% eventdata  reserved - to be defined in a future version of MATLAB

% handles    empty - handles not created until after all CreateFcns called

........................................................................................

% Hint: edit controls usually have a white background on Windows.

%       See ISPC and COMPUTER.

if ispc && isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))

set(hObject,'BackgroundColor','white');

end

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容