function x_est = CAB(A, r, R)
B = A(:, r~=0);%filter the pseudo-circles with radius of 0
r1 = r(r~=0);
center = [B A];
radius = [r1; R];
n = length(radius);
tolerance = 1e-5; % this parameter is used to cancel the impact of numerical accuracy.
intersect_point = [];
for i = 1:n-1
for j = i+1:n
a1 = center(:,i);
a2 = center(:,j);
if norm(a1-a2)==0
continue;
end
r1 = radius(i);
r2 = radius(j);
pp = intersect(a1, a2, r1, r2);
intersect_point = [intersect_point pp];
end
end
if length(intersect_point)==0
error('all circles do not intersect each other', '%s', 'exceptional case');
end
m = length(r);
n = size(intersect_point, 2);
degree = zeros(n, 1);
for i=1:n
pp = intersect_point(:,i);
for j=1:m
dist = norm(pp-A(:,j));
if dist<=R(j)+tolerance & dist>=r(j)-tolerance
degree(i) = degree(i)+1;
end
end
end
%degree
valid_intersect_point = [];
if max(degree)==m %the feasible case
valid_intersect_point = intersect_point(:, degree==m);
x_est = mean(valid_intersect_point, 2);
else
%TPDS method in random walk case
%%select k points with highest degree in the infeasible case
%[deg, index] = sort(degree, 'descend');
%k = 3;%assume k=3, that is, the first three points are selected to estimate the position of unknown node, but you can vary k to obtain different estimation performance
%x_est = mean(intersect_point(:, index(1:k)), 2);
%variant of TPDS method
%select all points with highest degree in the feasible case
valid_intersect_point = intersect_point(:, degree==max(degree));
x_est = mean(valid_intersect_point, 2);
end
return
function pp = intersect(a1, a2, r1, r2)
x1 = a1(1); y1 = a1(2);
x2 = a2(1); y2 = a2(2);
t = (x1^2+y1^2)-(x2^2+y2^2)-r1^2+r2^2;
bx = 2*(x1-x2); by = 2*(y1-y2);
d = r1^2-x1^2-y1^2;
if bx==0%the exceptional case
y = t/by;
a = 1;
b = -2*x1;
c = -d+y^2-2*y*y1;
temp = b^2-4*a*c;
if temp==0
x = -b/(2*a);
pp = [x; y];
elseif temp>0
x = (-b+sqrt(temp))/(2*a);
p1 = [x; y];
x = (-b-sqrt(temp))/(2*a);
p2 = [x; y];
pp = [p1 p2];
else
pp = [];
end
return;
end
a = (by/bx)^2+1;
b = -2*by*t/bx^2+2*x1*by/bx-2*y1;
c = (t/bx)^2-2*x1*t/bx-d;
temp = b^2-4*a*c;
if temp==0%only one intersection point
y = -b/(2*a);
x = (t-by*y)/bx;
pp = [x; y];
elseif temp>0%two intersection points
y = (-b+sqrt(temp))/(2*a);
x = (t-by*y)/bx;
p1 = [x; y];
y = (-b-sqrt(temp))/(2*a);
x = (t-by*y)/bx;
p2 = [x; y];
pp = [p1 p2];
else
pp = [];
%error('exception', '%s', 'there exists exception');
end
return;
data:image/s3,"s3://crabby-images/1f29a/1f29a3a90a69a8f1d40639a790f01f1784ccdc55" alt="avatar"
IT狂飙
- 粉丝: 4849
- 资源: 2649
最新资源
- C语言函数设计秘籍:参数传递、返回值与作用域全解析.pdf
- C语言函数精讲:参数传递、作用域与递归的终极实践手册.pdf
- C语言核心语法精讲:变量、循环、函数三大结构深度拆解.pdf
- C语言核心语法速成:10天掌握变量、循环、函数与指针.pdf
- C语言结构体与联合体:嵌入式开发必备的5个设计模式.pdf
- C语言核心知识树:一张思维导图搞定数据类型+运算符优先级.pdf
- C语言经典案例:282个代码示例从HelloWorld到算法优化.pdf
- C语言竟能写游戏?EasyX图形库入门秘籍.pdf
- C语言开发2048游戏:200行代码实现经典逻辑.pdf
- C语言控制台小游戏开发:贪吃蛇完整代码+设计思路.pdf
- C语言可视化编程:用EasyX图形库开发小游戏.pdf
- C语言开发者必备工具链:VSCode配置+GDB调试+Valgrind内存检测.pdf
- C语言内存管理终极教程:malloc、free原理+5个防泄漏技巧.pdf
- C语言跨平台开发技巧:Windows、Linux兼容性解决方案.pdf
- C语言命令行工具开发:argparse库实战教程.pdf
- C语言内存管理终极教程:malloc、free原理与避坑指南.pdf
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
data:image/s3,"s3://crabby-images/64800/6480089faebe1b575565428f4b0911ff02baa1fa" alt="feedback"
data:image/s3,"s3://crabby-images/64800/6480089faebe1b575565428f4b0911ff02baa1fa" alt="feedback"
data:image/s3,"s3://crabby-images/8dc5d/8dc5db4e32f7fe0e912caf189022aff37cbe3642" alt="feedback-tip"