亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ekfslam.m

?? 采用EKF實現(xiàn)移動機器人在全局地圖中的自定位
?? M
字號:
function EKFSLAM
close all; clear all;
global xVehicleTrue;global Map;global RTrue;global UTrue;global nSteps;
global SensorSettings;

%change these to alter sensor behaviour
SensorSettings.FieldOfView = 45;
SensorSettings.Range = 100;

%how often shall we draw?
DrawEveryNFrames = 50;

%length of experiment
nSteps = 8000;


%when to take pictures?
SnapShots = ceil(linspace(2,nSteps,25));


%size of problem
nFeatures = 40;
MapSize = 200;
Map = MapSize*rand(2,nFeatures)-MapSize/2;

UTrue = diag([0.01,0.01,1.5*pi/180]).^2;
RTrue = diag([1.1,5*pi/180]).^2;

UEst = 2.0*UTrue;
REst = 2.0*RTrue;

xVehicleTrue = [0;0;-pi/2];

%initial conditions - no map:
xEst =[xVehicleTrue];
PEst = diag([1,1,0.01]);
MappedFeatures = NaN*zeros(nFeatures,2);

%storage:
PStore = NaN*zeros(nFeatures,nSteps);
XErrStore = NaN*zeros(nFeatures,nSteps);


%initial graphics - plot true map
figure(1); hold on; grid off; axis equal;
plot(Map(1,:),Map(2,:),'g*');hold on;
set(gcf,'doublebuffer','on');
hObsLine = line([0,0],[0,0]);
set(hObsLine,'linestyle',':');
a = axis; axis(a*1.1);


xOdomLast = GetOdometry(1);

for k = 2:nSteps
    
    %do world iteration
    SimulateWorld(k);
    
    %figure out control
    xOdomNow = GetOdometry(k);
    u = tcomp(tinv(xOdomLast),xOdomNow);
    xOdomLast = xOdomNow;
    
    %we'll need this lots...
    xVehicle = xEst(1:3);
    xMap = xEst(4:end);
    
    %do prediction (the following is simply the result of multiplying 
    %out block form of jacobians)     
    xVehiclePred = tcomp(xVehicle,u);
    PPredvv = J1(xVehicle,u)* PEst(1:3,1:3) *J1(xVehicle,u)' + J2(xVehicle,u)* UEst * J2(xVehicle,u)';
    PPredvm = J1(xVehicle,u)*PEst(1:3,4:end);
    PPredmm = PEst(4:end,4:end);
    
    xPred = [xVehiclePred;xMap];
    PPred = [PPredvv PPredvm;
        PPredvm' PPredmm];
    
    %observe a randomn feature
    [z,iFeature] = GetObservation(k);
    
    if(~isempty(z))
        %have we seen this feature before?
        if( ~isnan(MappedFeatures(iFeature,1)))
            
            %predict observation: find out where it is in state vector
            FeatureIndex = MappedFeatures(iFeature,1);
            xFeature = xPred(FeatureIndex:FeatureIndex+1);
            
            zPred = DoObservationModel(xVehicle,xFeature);
            
            % get observation Jacobians
            [jHxv,jHxf] = GetObsJacs(xVehicle,xFeature);
            
            % fill in state jacobian
            jH = zeros(2,length(xEst));
            jH(:,FeatureIndex:FeatureIndex+1) = jHxf;
            jH(:,1:3) = jHxv;
            
            %do Kalman update:
            Innov = z-zPred;
            Innov(2) = AngleWrap(Innov(2));
            
            S = jH*PPred*jH'+REst;
            W = PPred*jH'*inv(S);
            xEst = xPred+ W*Innov;
            
            PEst = PPred-W*S*W';
            
            %ensure P remains symmetric
            PEst = 0.5*(PEst+PEst');
        else
            % this is a new feature add it to the map....            
            nStates = length(xEst); 
            
            xFeature = xVehicle(1:2)+ [z(1)*cos(z(2)+xVehicle(3));z(1)*sin(z(2)+xVehicle(3))];
            xEst = [xEst;xFeature]; %augmenting state vector
            [jGxv, jGz] = GetNewFeatureJacs(xVehicle,z);
            
            M = [eye(nStates), zeros(nStates,2);% note we don't use jacobian w.r.t vehicle
                jGxv zeros(2,nStates-3)  , jGz];
            
            PEst = M*blkdiag(PEst,REst)*M';
            
            %remember this feature as being mapped we store its ID and position in the state vector
            MappedFeatures(iFeature,:) = [length(xEst)-1, length(xEst)];
            
        end;
    else
        xEst = xPred;
        PESt = PPred;
    end;
    
    
    if(mod(k-2,DrawEveryNFrames)==0)
        a = axis;
        clf;
        axis(a);hold on;
        n  = length(xEst);
        nF = (n-3)/2;
        DoVehicleGraphics(xEst(1:3),PEst(1:3,1:3),3,[0 1]);
        
        if(~isnan(z))
            h = line([xEst(1),xFeature(1)],[xEst(2),xFeature(2)]);
            set(h,'linestyle',':');
        end;               
        for(i = 1:nF)
            iF = 3+2*i-1;
            plot(xEst(iF),xEst(iF+1),'b*');
            PlotEllipse(xEst(iF:iF+1),PEst(iF:iF+1,iF:iF+1),3);
        end;        
        fprintf('k = %d\n',k);        
        drawnow;                
    end;            
    
    if(ismember(k,SnapShots))
        iPic = find(SnapShots==k);
        print(gcf,'-depsc',sprintf('EKFSLAM%d.eps',iPic));    
    end;
    
    
end;

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [z,iFeature] = GetObservation(k)
global Map;global xVehicleTrue;global RTrue;global nSteps;global SensorSettings
done = 0;
Trys = 1;
z =[];iFeature = -1;
while(~done & Trys <0.5*size(Map,2))
  
    %choose a random feature to see from True Map
    iFeature = ceil(size(Map,2)*rand(1));
    z = DoObservationModel(xVehicleTrue,Map(:,iFeature))+sqrt(RTrue)*randn(2,1);
    z(2) = AngleWrap(z(2));
    %look forward...and only up to 40m
    if(abs(pi/2-z(2))<SensorSettings.FieldOfView*pi/180 & z(1) < SensorSettings.Range)
        done =1 ;
    else
        Trys =Trys+1;
        z =[];iFeature = -1;
    end;
end;
    
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [z] = DoObservationModel(xVeh, xFeature)
Delta = xFeature-xVeh(1:2);
z = [norm(Delta);
    atan2(Delta(2),Delta(1))-xVeh(3)];
z(2) = AngleWrap(z(2));

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function SimulateWorld(k)
global xVehicleTrue;
u = GetRobotControl(k);
xVehicleTrue = tcomp(xVehicleTrue,u);

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [jHxv,jHxf] = GetObsJacs(xPred, xFeature)
jHxv = zeros(2,3);jHxf = zeros(2,2);
Delta = (xFeature-xPred(1:2));
r = norm(Delta);
jHxv(1,1) = -Delta(1) / r;
jHxv(1,2) = -Delta(2) / r;
jHxv(2,1) = Delta(2) / (r^2);
jHxv(2,2) = -Delta(1) / (r^2);
jHxv(2,3) = -1;
jHxf(1:2,1:2) = -jHxv(1:2,1:2);

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [jGx,jGz] = GetNewFeatureJacs(Xv, z);
x = Xv(1,1);
y = Xv(2,1);
theta = Xv(3,1);
r = z(1);
bearing = z(2);
jGx = [ 1   0   -r*sin(theta + bearing);
    0   1   r*cos(theta + bearing)];
jGz = [ cos(theta + bearing) -r*sin(theta + bearing);
    sin(theta + bearing) r*cos(theta + bearing)];


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [xnow] = GetOdometry(k)
persistent LastOdom; %internal to robot low-level controller
global UTrue;
if(isempty(LastOdom))
    global xVehicleTrue;
    LastOdom = xVehicleTrue;
end;
u = GetRobotControl(k);
xnow =tcomp(LastOdom,u);
uNoise = sqrt(UTrue)*randn(3,1);
xnow = tcomp(xnow,uNoise);
LastOdom = xnow;    

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function u = GetRobotControl(k)
global nSteps;
%u = [0; 0.25 ; 0.3*pi/180*sin(3*pi*k/nSteps)];
u = [0; 0.15 ; 0.2*pi/180];

%-------- Drawing Covariance -----%
function eH = PlotEllipse(x,P,nSigma)
eH = [];
P = P(1:2,1:2); % only plot x-y part
x = x(1:2);
if(~any(diag(P)==0))
    [V,D] = eig(P);
    y = nSigma*[cos(0:0.1:2*pi);sin(0:0.1:2*pi)];
    el = V*sqrtm(D)*y;
    el = [el el(:,1)]+repmat(x,1,size(el,2)+1);
    eH = line(el(1,:),el(2,:) );
end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区精美| 日本一区二区成人| 亚洲电影一区二区三区| 在线看日本不卡| 亚洲福利一区二区三区| 欧美性受xxxx| 天堂va蜜桃一区二区三区漫画版 | 一区二区三区中文字幕| 色呦呦日韩精品| 日韩av午夜在线观看| 精品日韩一区二区三区免费视频| 精品一区二区免费看| 国产欧美在线观看一区| 91麻豆免费在线观看| 亚洲最新在线观看| 3d动漫精品啪啪一区二区竹菊| 麻豆专区一区二区三区四区五区| 久久久亚洲高清| 色综合久久久久| 久久不见久久见免费视频7| 欧美国产精品中文字幕| 欧美性色黄大片| 国产乱码精品1区2区3区| 中文av字幕一区| 欧美区一区二区三区| 国产一区二区调教| 一区二区在线观看视频| 日韩精品一区二区三区视频| 成人午夜av电影| 日韩在线播放一区二区| 欧美国产视频在线| 91精品午夜视频| 91视频xxxx| 久久狠狠亚洲综合| 一区二区三区四区av| 日韩欧美电影在线| 99久久综合国产精品| 麻豆精品久久精品色综合| 中文字幕一区二区三| 日韩视频国产视频| 色成人在线视频| 国产成人自拍网| 亚洲韩国精品一区| 国产精品视频免费看| 日韩视频一区二区三区在线播放 | 欧美日韩一级二级三级| 国产美女久久久久| 亚洲午夜久久久久久久久久久 | 欧美日韩在线综合| 处破女av一区二区| 美女在线一区二区| 一区二区三区美女视频| 中文成人av在线| 精品国产三级a在线观看| 欧美三级电影在线观看| 91社区在线播放| 国产成人精品一区二区三区网站观看| 丝袜美腿亚洲综合| 亚洲综合区在线| 成人免费在线播放视频| 久久久久久久久久看片| 7777精品伊人久久久大香线蕉的| 欧美午夜精品久久久久久超碰| 国产福利视频一区二区三区| 久久精品999| 中文字幕一区二区在线播放| 日韩欧美一区二区免费| 91国偷自产一区二区使用方法| 国产iv一区二区三区| 国产在线精品一区在线观看麻豆| 日本中文在线一区| 午夜精品aaa| 亚洲午夜国产一区99re久久| www精品美女久久久tv| 欧美色精品天天在线观看视频| 91丨九色丨黑人外教| 成人午夜看片网址| 国产高清精品网站| 国产精品18久久久久久久网站| 精品一区二区三区视频 | 91精品麻豆日日躁夜夜躁| 色素色在线综合| 日本久久一区二区三区| 91视频xxxx| 欧美日韩精品一区二区在线播放| 欧美日韩午夜在线视频| 在线播放视频一区| 日韩免费高清视频| 精品99999| 国产亚洲欧洲997久久综合| 久久精品人人做人人爽97| 国产喂奶挤奶一区二区三区| 国产精品网站在线播放| 椎名由奈av一区二区三区| 亚洲免费观看高清| 偷拍一区二区三区四区| 日韩av在线播放中文字幕| 麻豆专区一区二区三区四区五区| 日韩亚洲电影在线| 欧美在线一二三四区| 欧美吞精做爰啪啪高潮| 日韩亚洲欧美高清| 国产精品午夜电影| 亚洲美女免费在线| 日韩av一级片| 高清久久久久久| 欧美性猛片aaaaaaa做受| 日韩视频国产视频| 中文字幕中文字幕一区| 亚洲六月丁香色婷婷综合久久 | 99久久精品免费看国产| 欧美在线观看一区二区| 欧美一二三区在线观看| 久久久不卡影院| 一区二区三区中文字幕电影| 久久超碰97中文字幕| www.亚洲国产| 91精品国产福利在线观看| 国产三级精品三级| 艳妇臀荡乳欲伦亚洲一区| 精品一区二区免费视频| 色噜噜偷拍精品综合在线| 日韩亚洲国产中文字幕欧美| 中文字幕一区二区不卡| 久88久久88久久久| 91福利国产精品| 国产调教视频一区| 午夜欧美视频在线观看 | 综合av第一页| 奇米色一区二区三区四区| 成人理论电影网| 日韩亚洲欧美一区| 最近日韩中文字幕| 国产一区二区三区精品欧美日韩一区二区三区| 国产99久久久久| 欧美一区中文字幕| 成人欧美一区二区三区1314 | 丁香网亚洲国际| 欧美一级艳片视频免费观看| 日韩伦理av电影| 国产精品一级二级三级| 欧美精品三级日韩久久| 国产精品久久国产精麻豆99网站 | 国产精品视频一二| 精品亚洲成av人在线观看| 欧美日韩中文一区| 亚洲欧美日韩综合aⅴ视频| 国产在线国偷精品产拍免费yy| 欧美日韩免费观看一区三区| 最新久久zyz资源站| 国产91在线|亚洲| 精品美女一区二区三区| 日韩影院免费视频| 欧美性猛交xxxx乱大交退制版| 国产精品成人免费在线| 国产成人亚洲精品狼色在线| 精品国产乱码久久久久久老虎 | 九九**精品视频免费播放| 欧美日韩在线播放一区| 亚洲制服丝袜av| 色狠狠桃花综合| 中文字幕日韩欧美一区二区三区| 国产一区二区在线免费观看| 欧美成人三级在线| 蜜桃视频一区二区三区在线观看 | 国产成人高清在线| 久久欧美一区二区| 韩国视频一区二区| 精品国产a毛片| 久久97超碰国产精品超碰| 欧美一级二级在线观看| 日本va欧美va瓶| 日韩欧美你懂的| 久久爱www久久做| 精品国产髙清在线看国产毛片 | 日韩美女视频一区| 91网上在线视频| 亚洲精品乱码久久久久久黑人| 91在线观看免费视频| 亚洲精品日日夜夜| 欧美视频在线一区| 婷婷久久综合九色综合伊人色| 欧美挠脚心视频网站| 日韩电影免费在线看| 日韩三级av在线播放| 国产在线看一区| 国产精品国产精品国产专区不片| 99久久精品免费看国产| 亚洲第一搞黄网站| 欧美一级视频精品观看| 国产精品乡下勾搭老头1| 欧美激情一区二区三区四区| a在线欧美一区| 亚洲成人免费电影| 日韩精品一区二区三区swag | 色综合久久天天综合网| 亚洲国产精品自拍| 精品国产自在久精品国产| 成人永久免费视频| 亚洲成国产人片在线观看|