最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

【路徑規(guī)劃】基于改進(jìn)動(dòng)態(tài)窗口法DWA實(shí)現(xiàn)機(jī)器人動(dòng)態(tài)避障matlab源碼含 GUI

2021-08-04 22:59 作者:Matlab工程師  | 我要投稿

一、簡(jiǎn)介

DWA算法全稱(chēng)為dynamic window approach,其原理主要是在速度空間(v,w)中采樣多組速度,并模擬這些速度在一定時(shí)間內(nèi)的運(yùn)動(dòng)軌跡,再通過(guò)一個(gè)評(píng)價(jià)函數(shù)對(duì)這些軌跡打分,最優(yōu)的速度被選擇出來(lái)發(fā)送給下位機(jī)。
1 原理分析

在這里插入圖片描述


在這里插入圖片描述


在這里插入圖片描述


2 速度采樣

機(jī)器人的軌跡運(yùn)動(dòng)模型有了,根據(jù)速度就可以推算出軌跡。
因此只需采樣很多速度,推算軌跡,然后評(píng)價(jià)這些軌跡好不好就行了。
(一)移動(dòng)機(jī)器人受自身最大速度最小速度的限制
(二) 移動(dòng)機(jī)器人受電機(jī)性能的影響:由于電機(jī)力矩有限,存在最大的加減速限制,因此移動(dòng)機(jī)器人軌跡前向模擬的周期sim_period內(nèi),存在一個(gè)動(dòng)態(tài)窗口,在該窗口內(nèi)的速度是機(jī)器人能夠?qū)嶋H達(dá)到的速度:
(三) 基于移動(dòng)機(jī)器人安全的考慮:為了能夠在碰到障礙物前停下來(lái), 因此在最大減速度條件下, 速度有一個(gè)范圍。

二、源代碼

function varargout = Simulate(varargin) clc SamplingPeriod = 0.1; time = 0; timer1 = []; txt_timer = []; FuzzyLoaded = 0; Z1 = []; Z2 = []; W_Zone = 20; H_Zone = 20; data = importdata ('fuzzytabledata.mat'); OUT1 = data.OUT1; OUT2 = data.OUT2; Z1 = reshape(OUT1(102:end,1)',101,[]); Z2 = reshape(OUT2(102:end,1)',101,[]); FuzzyLoaded = 1; scrsz = get(0,'ScreenSize'); % Create a figure that will have a uitable, axes and checkboxes figure('Position',[15*scrsz(3)/100 70 scrsz(3)-2*(15*scrsz(3)/100) scrsz(4)-100],... ? ? ? 'WindowStyle', 'normal',... ? ? ? 'CloseRequestFcn',{@CloseFcn},... ? ? ? 'Name', '具有動(dòng)態(tài)障礙物的DWA仿真',... ?% Title figure ? ? ? 'NumberTitle', 'off') % Do not show figure number ? % figure('Position',[15*scrsz(3)/100 70 scrsz(3)-2*(15*scrsz(3)/100) scrsz(4)-100],... % ? ? ? ?'WindowStyle', 'normal',... % ? ? ? ?'CloseRequestFcn',{@CloseFcn},... % ? ? ? ?'Name', '具有動(dòng)態(tài)障礙物的DWA仿真',... ?% Title figure % ? ? ? ?'NumberTitle', 'off',... % Do not show figure number % ? ? ? ?'MenuBar', 'none'); ? ? ?% Hide standard menu bar menus % Create an axes set x and y limits to the value extremes, and format labels W_Zone = ceil(W_Zone/10)*10; H_Zone = ceil(H_Zone/10)*10; haxes = axes('Units', 'normalized',... ? ? ? ? ? ? 'Position', [.25 .05 0.75 0.9],... ? ? ? ? ? ? 'XLim', [-W_Zone/2 W_Zone/2],... ? ? ? ? ? ? 'YLim', [-H_Zone/2 H_Zone/2],... ? ? ? ? ? ? 'XLimMode', 'manual',... ? ? ? ? ? ? 'YLimMode', 'manual',... ? ? ? ? ? ? 'XTick',-W_Zone/2:1:W_Zone/2,... ? ? ? ? ? ? 'YTick',-H_Zone/2:1:H_Zone/2);%,... % ? ? ? ? ? ? ?'XTickLabel',... % ? ? ? ? ? ? ?{'-10 m','-5 m','0','5 m','10 m'},... % ? ? ? ? ? ? ?'YTickLabel',... % ? ? ? ? ? ? ?{'-10 m','-5 m','0','5 m','10 m'}); set(haxes,'DataAspectRatio',[1 1 1]); title(haxes, '移動(dòng)機(jī)器人動(dòng)態(tài)避障仿真') ? % Describe data set % Prevent axes from clearing when new lines or markers are plotted hold(haxes, 'all') grid on; uicontrol('Style', 'pushbutton',... ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ?'Position', [.02 .86 .2 .05],... ? ? ? ? ?'String', '開(kāi)始仿真',... ? ? ? ? ?'Value', 0,... ? ? ? ? ?'Callback', {@StartSimulation}); uicontrol('Style', 'pushbutton',... ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ?'Position', [.02 .81 .2 .05],... ? ? ? ? ?'String', '重新仿真',... ? ? ? ? ?'Value', 0,... ? ? ? ? ?'Callback', {@ResetSimulation}); % % Create a text to show timer; txt_timer = uicontrol('Style', 'text',... ? ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ? ?'Position', [.02 .915 .2 .035],... ? ? ? ? ? ?'FontWeight', 'bold',... ? ? ? ? ? ?'ForegroundColor', [0 .2 .8],... ? ? ? ? ? ?'fontname', 'Helvetica',... ? ? ? ? ? ?'fontsize', 14,... ? ? ? ? ? ?'BackgroundColor', 'w', 'String','00:00 00'); ? ? ? % % Create some texts to monitor variables; txt_inp1 = uicontrol('Style', 'text', 'Units', 'normalized', 'Position', [.05 .54 .08 .035],... ? ? ? ? ? ?'FontWeight', 'bold', 'ForegroundColor', [0 0 0], 'fontname', 'Helvetica', 'fontsize', 12, 'BackgroundColor', [0.9 0.9 0.9]); txt_inp2 = uicontrol('Style', 'text', 'Units', 'normalized', 'Position', [.14 .54 .08 .035],... ? ? ? ? ? ?'FontWeight', 'bold', 'ForegroundColor', [0 0 0], 'fontname', 'Helvetica', 'fontsize', 12, 'BackgroundColor', [0.9 0.9 0.9]); txt_out1 = uicontrol('Style', 'text', 'Units', 'normalized', 'Position', [.05 .47 .08 .035],... ? ? ? ? ? ?'FontWeight', 'bold', 'ForegroundColor', [0 0 0], 'fontname', 'Helvetica', 'fontsize', 12, 'BackgroundColor', [0.9 0.9 0.9]); txt_out2 = uicontrol('Style', 'text', 'Units', 'normalized', 'Position', [.14 .47 .08 .035],... ? ? ? ? ? ?'FontWeight', 'bold', 'ForegroundColor', [0 0 0], 'fontname', 'Helvetica', 'fontsize', 12, 'BackgroundColor', [0.9 0.9 0.9]); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.05 .61 .15 .025],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 10,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', 'DWA權(quán)值調(diào)整'); ? ? ? ? uicontrol('Style', 'text','Units', 'normalized', 'Position', [.00 .55 .05 .02],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 9,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', 'INPs :'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.00 .48 .05 .02],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 9,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', '誤差值 :'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.05 .58 .08 .02],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 9,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', '目標(biāo)航向角'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.14 .58 .08 .02],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 9,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', '障礙物'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.05 .51 .08 .02],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 9,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', '左偏離'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.14 .51 .08 .02],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 9,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', '右偏離'); ? ? ? ? uicontrol('Style', 'text','Units', 'normalized', 'Position', [.09 .78 .12 .025],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 10,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', 'X ? ? ? ? ? ? Y'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.02 .74 .06 .03],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 10,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', '起始點(diǎn)坐標(biāo):'); uicontrol('Style', 'text','Units', 'normalized', 'Position', [.02 .7 .06 .03],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 10,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8], 'String', ' ?目標(biāo)點(diǎn)坐標(biāo):'); ? ? ? ? % % Create a text get Robot X0 Pos; edit_robot_x0 = uicontrol('Style', 'edit',... ? ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ? ?'Position', [.09 .74 .06 .035],... %'String',... %'Use Plot check boxes to graph columns',... ? ? ? ? ? ?'FontWeight', 'bold',... ? ? ? ? ? ?'fontname', 'Helvetica',... ? ? ? ? ? ?'fontsize', 12); % % Create a text get Robot Y0 Pos; edit_robot_y0 = uicontrol('Style', 'edit',... ? ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ? ?'Position', [.16 .74 .06 .035],... %'String',... %'Use Plot check boxes to graph columns',... ? ? ? ? ? ?'FontWeight', 'bold',... ? ? ? ? ? ?'fontname', 'Helvetica',... ? ? ? ? ? ?'fontsize', 12); ? ? ? ? % % Create a text get Goal X Pos; edit_goal_x = uicontrol('Style', 'edit',... ? ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ? ?'Position', [.09 .7 .06 .035],... %'String',... %'Use Plot check boxes to graph columns',... ? ? ? ? ? ?'FontWeight', 'bold',... ? ? ? ? ? ?'fontname', 'Helvetica',... ? ? ? ? ? ?'fontsize', 12); % % Create a text get Goal Y Pos; edit_goal_y = uicontrol('Style', 'edit',... ? ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ? ?'Position', [.16 .7 .06 .035],... %'String',... %'Use Plot check boxes to graph columns',... ? ? ? ? ? ?'FontWeight', 'bold',... ? ? ? ? ? ?'fontname', 'Helvetica',... ? ? ? ? ? ?'fontsize', 12); uicontrol('Style', 'pushbutton',... ? ? ? ? ?'Units', 'normalized',... ? ? ? ? ?'Position', [.09 .655 .13 .04],... %'TooltipString', 'Update Values Independently',... ? ? ? ? ?'String', '更新',... ? ? ? ? ?'Value', 0,... ? ? ? ? ?'Callback', {@UpdateParams}); slider_x = uicontrol('Style', 'slider','Units', 'normalized', 'Position', [.02 .41 .2 .025],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 10,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8],'Min',0,'Value',1,'Max',2,'SliderStep',[0.01 0.1]); slider_y = uicontrol('Style', 'slider','Units', 'normalized', 'Position', [.02 .37 .2 .025],... ? ? ? ? ? ?'FontWeight', 'bold', 'fontname', 'Helvetica', 'fontsize', 10,... ? ? ? ? ? ?'BackgroundColor', [0.8 0.8 0.8],'Min',0,'Value',1,'Max',2,'SliderStep',[0.01 0.1]); ? ? ? % uicontrol('Style', 'pushbutton',... % ? ? ? ? ? 'Units', 'normalized',... % ? ? ? ? ? 'Position', [0.35 .95 .25 .05],... %'TooltipString', 'Update Values Independently',... % ? ? ? ? ? 'String', 'Save Data',... % ? ? ? ? ? 'Value', 0,... % ? ? ? ? ? 'Callback', {@SaveData}); % % Create an invisible marker plot of the data and save handles % % to the lineseries objects; use this to simulate data brushing. % % hmkrs = plot([1:10],[1:10].^2, 'LineStyle', 'none',... % % ? ? ? ? ? ? ? ? ? ? 'Marker', 'o',... % % ? ? ? ? ? ? ? ? ? ? 'MarkerFaceColor', 'y',... % % ? ? ? ? ? ? ? ? ? ? 'HandleVisibility', 'off',... % % ? ? ? ? ? ? ? ? ? ? 'Visible', 'on'); % Create three check boxes to toggle plots for columns % uicontrol('Style', 'checkbox',... % ? ? ? ? ? 'Units', 'normalized',... % ? ? ? ? ? 'Position', [.10 .96 .09 .035],... % ? ? ? ? ? 'TooltipString', 'Check to plot column 1',... % ? ? ? ? ? 'String', 'Col 1',... % ? ? ? ? ? 'Value', 0,... % ? ? ? ? ? 'Callback', {@plot_callback,1}); % % % Create a text label to say what the checkboxes do % uicontrol('Style', 'text',... % ? ? ? ? ? 'Units', 'normalized',... % ? ? ? ? ? 'Position', [.025 .955 .06 .035],... % ? ? ? ? ? 'String', 'Plot',... % ? ? ? ? ? 'FontWeight', 'bold');

三、運(yùn)行結(jié)果

在這里插入圖片描述


在這里插入圖片描述


【路徑規(guī)劃】基于改進(jìn)動(dòng)態(tài)窗口法DWA實(shí)現(xiàn)機(jī)器人動(dòng)態(tài)避障matlab源碼含 GUI的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國(guó)家法律
汶川县| 鄂尔多斯市| 上林县| 垫江县| 万载县| 嘉义市| 普宁市| 耒阳市| 静安区| 黄石市| 于田县| 柘荣县| 舟山市| 清水河县| 青河县| 伊春市| 梓潼县| 外汇| 高雄市| 同德县| 宜兴市| 阳山县| 佛冈县| 孝义市| 叙永县| 屯门区| 长葛市| 平定县| 博客| 瑞金市| 普兰店市| 宝坻区| 谷城县| 鹿泉市| 漳浦县| 兴隆县| 安乡县| 黄龙县| 安西县| 康平县| 盐源县|