一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【定位问题】基于matlab GUI RSSI无线定位【含Matlab源码 1054期】

获取代码方式2:
通过订阅紫极神光博客付费专栏,凭支付凭证,私信博主,可获得此代码。

备注:
订阅紫极神光博客付费专栏,仅只能免费获得1份代码;

二、简介













三、部分源代码

function varargout = test(varargin)
% TEST MATLAB code for test.fig
%      TEST, by itself, creates a new TEST or raises the existing
%      singleton*.
%
%      H = TEST returns the handle to a new TEST or the handle to
%      the existing singleton*.
%
%      TEST('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in TEST.M with the given input arguments.
%
%      TEST('Property','Value',...) creates a new TEST or raises the
%      existing singleton*.  Starting from the left, property value pairs are
%      applied to the GUI before test_OpeningFcn gets called.  An
%      unrecognized property name or invalid value makes property application
%      stop.  All inputs are passed to test_OpeningFcn via varargin.
%
%      *See GUI Options on GUIDE's Tools menu.  Choose "GUI allows only one
%      instance to run (singleton)".
%
% See also: GUIDE, GUIDATA, GUIHANDLES% Edit the above text to modify the response to help test% Last Modified by GUIDE v2.5 26-Jun-2021 09:51:44% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name',       mfilename, ...'gui_Singleton',  gui_Singleton, ...'gui_OpeningFcn', @test_OpeningFcn, ...'gui_OutputFcn',  @test_OutputFcn, ...'gui_LayoutFcn',  [] , ...'gui_Callback',   []);
if nargin && ischar(varargin{1})gui_State.gui_Callback = str2func(varargin{1});
endif nargout[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
elsegui_mainfcn(gui_State, varargin{:});
end
% End initialization code - DO NOT EDIT% --- Executes just before test is made visible.
function test_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
% varargin   command line arguments to test (see VARARGIN)% Choose default command line output for test
handles.output = hObject;% Update handles structure
guidata(hObject, handles);% UIWAIT makes test wait for user response (see UIRESUME)
% uiwait(handles.figure1);% --- Outputs from this function are returned to the command line.
function varargout = test_OutputFcn(hObject, eventdata, handles)
% varargout  cell array for returning output args (see VARARGOUT);
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% Get default command line output from handles structure
varargout{1} = handles.output;% --- Executes on button press in pushbutton1.
function pushbutton1_Callback(hObject, eventdata, handles)
for t = 1:5A = [0,0];B = [5*t,5*t*sqrt(3)];C = [10*t,0];nums = [A(1),A(2),B(1),B(2),C(1),C(2)];p = min(nums);q = max(nums);L = sqrt((A(1)-C(1))^2+(A(2)-C(2))^2);m = 10;syms b c;%生成在[p,q]上满足均匀分布的随机数矩阵%即生成一组m行2列的有可能落在等边三角形区域内的坐标numbox = p+(q-p)*rand(m,2);%rand函数产生由在(0, 1)之间均匀分布的随机数组成的数组%计数初值,最终根据计算将随机生成的点中落在等边三角形区域内的坐标存放于新的矩阵n = 1;for i = 1:mdA(i) = sqrt((numbox(i,1)-A(1))^2+(numbox(i,2)-A(2))^2);dB(i) = sqrt((numbox(i,1)-B(1))^2+(numbox(i,2)-B(2))^2);dC(i) = sqrt((numbox(i,1)-C(1))^2+(numbox(i,2)-C(2))^2);%将确实在等边三角形区域内的坐标存入P_position矩阵if (dA(i)<=L) & (dB(i)<=L) & (dC(i)<=L)P_position(n,1) = numbox(i,1);P_position(n,2) = numbox(i,2);b=P_position(n,1);c=P_position(n,2);n = n+1;endend%N为随机生成的点中落在等边三角形区域内的点(测试点)的个数N = n-1if N == 0disp('所取的随机坐标无一落在等边三角形内,请增大m值重新运行程序.')returnend%计算测试点离三个顶点的实际距离%dis为N行3列的矩阵,用于存放N个测试点分别到等边三角形三个顶点A,B,C的实际距离for i = 1:Ndis(i,1) = sqrt((P_position(i,1)-A(1))^2+(P_position(i,2)-A(2))^2);dis(i,2) = sqrt((P_position(i,1)-B(1))^2+(P_position(i,2)-B(2))^2);dis(i,3) = sqrt((P_position(i,1)-C(1))^2+(P_position(i,2)-C(2))^2);enda = 7; %由RSSI计算T-R距离时使用的参数for i = 1:Ndis_test(i,1) = Distance(dis(i,1),a);dis_test(i,2) = Distance(dis(i,2),a);dis_test(i,3) = Distance(dis(i,3),a);end%根据函数Triangle及求得的测试距离进行定位%P_calculate为N行2列的矩阵,用于存放定位后的N个坐标for i = 1:NP_temp = Triangle(A,B,C,dis_test(i,1),dis_test(i,2),dis_test(i,3));P_calculate(i,1) = P_temp(1);P_calculate(i,2) = P_temp(2);end%由于测试距离相比真实距离有误差,三角计算中的两圆有可能无交点,导致方程无实根.%于是P_calculate中会出现虚数.在测试中虚数无实际意义,因此取其实部存放于另一矩阵for i = 1:NP_calculate_real(i,1) = real(P_calculate(i,1));P_calculate_real(i,2) = real(P_calculate(i,2));end%对比测试点的定位坐标与实际坐标之间的误差P_position;P_calculate;P_calculate_real;%计算定位结果与真实坐标之间的距离误差平均值e_average(测试点等概率)e_sum = 0;for i = 1:Ne = sqrt((P_calculate_real(i,1)-P_position(i,1))^2+(P_calculate_real(i,2)-P_position(i,2))^2);e_sum = e_sum+e;ende_average = e_sum/N;e_average_percent = e_average/L;e_average_box(t) = e_averagee_average_percent_box(t) = e_average_percente_average_box(t) = e_average;x=e_average_percent_box(t);y = e_average_box(t);
end
% 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)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)
set(edit1,'string',2);
% 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');
endfunction edit2_Callback(hObject, eventdata, handles)
% hObject    handle to edit2 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
set(edit2,'string',y);
% Hints: get(hObject,'String') returns contents of edit2 as text
%        str2double(get(hObject,'String')) returns contents of edit2 as a double% --- Executes during object creation, after setting all properties.
function edit2_CreateFcn(hObject, eventdata, handles)
% hObject    handle to edit2 (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% --- Executes on button press in pushbutton2.
function pushbutton2_Callback(hObject, eventdata, handles)for t = 1:5A = [0,0];B = [5*t,5*t*sqrt(3)];C = [10*t,0];nums = [A(1),A(2),B(1),B(2),C(1),C(2)];p = min(nums);q = max(nums);L = sqrt((A(1)-C(1))^2+(A(2)-C(2))^2);m = 10;syms b c;%生成在[p,q]上满足均匀分布的随机数矩阵%即生成一组m行2列的有可能落在等边三角形区域内的坐标numbox = p+(q-p)*rand(m,2);%rand函数产生由在(0, 1)之间均匀分布的随机数组成的数组%计数初值,最终根据计算将随机生成的点中落在等边三角形区域内的坐标存放于新的矩阵n = 1;for i = 1:mdA(i) = sqrt((numbox(i,1)-A(1))^2+(numbox(i,2)-A(2))^2);dB(i) = sqrt((numbox(i,1)-B(1))^2+(numbox(i,2)-B(2))^2);dC(i) = sqrt((numbox(i,1)-C(1))^2+(numbox(i,2)-C(2))^2);%将确实在等边三角形区域内的坐标存入P_position矩阵if (dA(i)<=L) & (dB(i)<=L) & (dC(i)<=L)P_position(n,1) = numbox(i,1);P_position(n,2) = numbox(i,2);b=P_position(n,1);c=P_position(n,2);n = n+1;endend%N为随机生成的点中落在等边三角形区域内的点(测试点)的个数N = n-1if N == 0disp('所取的随机坐标无一落在等边三角形内,请增大m值重新运行程序.')returnend

四、运行结果

五、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 门云阁.MATLAB物理计算与可视化[M].清华大学出版社,2013.

【定位问题】基于matlab GUI RSSI无线定位【含Matlab源码 1054期】相关推荐

  1. 【光学】基于matlab GUI杨氏双缝干涉【含Matlab源码 001期】

    一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[光学]基于matlab GUI杨氏双缝干涉[含Matlab源码 001期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2: 付费 ...

  2. 【人脸识别】基于matlab GUI人数统计【含Matlab源码 2121期】

    ⛄一.人数统计简介(附课程作业报告) 1 课题背景 本课题为基于matlab的人数统计系统.近年来,很多行业对人流信息有极大的需求,如汽车公交站,地铁站台,商场出入口等.通过人数统计系统可以方便.可靠 ...

  3. 基于SSM的仓库管理系统(含完整源码+论文)

    后端框架:SSM 数据库:MySQL 开发工具:IDEA/Eclipse 系统介绍:本系统是基于SSM框架进行设计,MySQL作为底层数据库,前端采用bootstrap 模块大致介绍:包括库存管理.出 ...

  4. 【条形码识别】基于matlab GUI二维条形码识别【含Matlab源码 607期】

    ⛄一.二维条形码识别简介 采用数字图像处理技术对二维条码进行识别, 是二维条形码识别中较常用的方法, 它在处理污损的条形码方面有光电识别方法无法比拟的优势.另外图像式识别方法对识别角度的要求没有光电识 ...

  5. 【心电信号】基于matlab GUI心电信号预处理【含Matlab源码 938期】

    ⛄一.心电信号预处理方法简介 理论知识参考文献:心电信号预处理方法研究 ⛄二.部分源代码 function varargout = kaishi(varargin) gui_Singleton = 1 ...

  6. matlab svm 语音识别,【情感识别】基于matlab支持向量机(SVM)的语音情感识别【含Matlab源码 543期】...

    一.简介 支持向量机(Support Vector Machine)是Cortes和Vapnik于1995年首先提出的,它在解决小样本.非线性及高维模式识别中表现出许多特有的优势,并能够推广应用到函数 ...

  7. 【数字信号】基于matlab GUI多音双频(DTMF)拨号音频解码仿真系统【含Matlab源码 1084期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[数字信号]基于matlab GUI多音双频(DTMF)拨号音频解码仿真系统[含Matlab源码 1084期] 点击上面蓝色字体,直接付费 ...

  8. 【图像处理】基于matlab GUI多功能图像处理系统【含Matlab源码 1876期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[图像处理]基于matlab GUI多功能图像处理系统[含Matlab源码 1876期] 点击上面蓝色字体,直接付费下载,即可. 获取代码 ...

  9. 【图像去噪】基于matlab GUI butterworth+中值+维纳+小波图像去噪【含Matlab源码 520期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[图像去噪]基于matlab GUI butterworth+中值+维纳+小波图像去噪[含Matlab源码 520期] 获取代码方式2: ...

  10. 【机械仿真】基于matlab GUI曲柄摇杆机构运动仿真【含Matlab源码 1608期】

    一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[机械仿真]基于matlab GUI曲柄摇杆机构运动仿真[含Matlab源码 1608期] 点击上面蓝色字体,直接付费下载,即可. 获取代码 ...

最新文章

  1. Yarn 问题发现与解决
  2. 如何解决Contacts中的多音字排序错误问题
  3. linux进程运行队列,Linux进程调度中队列的使用
  4. Python的模块千奇百怪,居然有自动发短信的模块?
  5. cin.getline()、getline()、gets()、cin.get(),getchar()的区别
  6. Python发展的新时代—冯大辉先生谈《Python源码剖析》
  7. linux基础(一)——切换到root用户和普通用户
  8. linux文件管理ppt,Linux操作系统_文件管理2.ppt
  9. 微信小程序关于下拉刷新
  10. c#Word模板转PDF,c#word模板生成新的word
  11. 正确的做事和做正确的事
  12. jwt的token自动续约_关于JWT Token 自动续期的解决方案
  13. 彻底卸载360画报(流氓屏保软件)---亲测有效
  14. 学习之旅10-R语言介绍
  15. win10无限蓝屏修复加重置
  16. 多线程与高并发day04
  17. py使用polar绘制霍兰德职业测试雷达图
  18. 【Shiro】shiro的Session管理
  19. python教育学_我去过书声琅琅教育学Python,没想到却跟想象的不一样!
  20. java获取参数上的注解_java-如何获取带注释的方法参数及其注释

热门文章

  1. Java-Runoob-高级教程-实例-字符串:14. Java 实例 - 连接字符串
  2. nginx的学习笔记,第四记。
  3. ubuntu 安装cuda 成功
  4. BZOJ 2286 [Sdoi2011]消耗战(虚树+树形DP)
  5. 【代码笔记】iOS-手机系统版本
  6. 继续聊WPF——Expander控件(1)
  7. BDFZOI 数论小结1(筛法、欧拉phi函数)
  8. 安卓boot.img文件详细介绍-解包,编辑,打包
  9. YOLOV5学习记录
  10. Atitit ..Net Framework sdk 3.0 3.5 4.04.5 4.6 4.7  .net core版本新特性 v2 s22 1. 新特性来源于 down ms 官方网站 1