w

import random
import pprint
import math
import matplotlib.pyplot as plt def gen_random(magnify_=1000, round_=2):
dd = round(random.random() * magnify_, round_)
return dd def float_format(d, not_float=0.0):
if d is float:
print(232)
else:
try:
d = float(d)
except Exception:
d = not_float
return d def gen_atob_dis(a, b):
a, b = float_format(a), float_format(b)
return ((a ** 2 + b ** 2) * 0.5) ** 0.5 def chk_triangle(a, b, c):
a, b, c = float_format(a), float_format(b), float_format(c)
if a + b > c and a + c > b and b + c > a:
return 1
else:
return 0 def compute_triangle_angle(a, b, c):
a, b, c = float_format(a), float_format(b), float_format(c)
cos = (a ** 2 + b ** 2 - c ** 2) / (2 * a * b)
return math.acos(cos) def radius_coordinates_to_perpendicular_coordinates(dic_):
polar_radius, polar_angle = dic_['polar_radius'], dic_['polar_angle']
res_ = {}
res_['y'], res_['x'] = polar_radius * math.sin(polar_angle), polar_radius * math.cos(polar_angle)
return res_ PI = math.pi
uuid_num = 5
uuid_num_plus = uuid_num + 1
str_ = '-86 -83 -71 -69 -73 -60 -72 -84 -82 -56 -82 -75 -71 -89 -83 -79 -67 -87 -77 -79' l_row = str_.split('\t\t\t')
rssi_matrix = {}
for i in range(0, uuid_num, 1):
i_ = i + 1
rssi_matrix[i_] = {}
l_one = l_row[i].split('\t')
step_ = 0
for ii in range(0, uuid_num, 1):
ii_ = ii + 1
if i == ii:
rssi_matrix[i_][ii_] = 0
else:
rssi_matrix[i_][ii_] = l_one[step_]
step_ += 1 rssi_distance_matrix = {}
for i in range(0, uuid_num, 1):
i_ = i + 1
rssi_distance_matrix[i_] = {}
for ii in range(0, uuid_num, 1):
ii_ = ii + 1
a = rssi_matrix[i_][ii_]
b = rssi_matrix[ii_][i_]
rssi_distance_matrix[i_][ii_] = gen_atob_dis(a, b)
pprint.pprint(str_)
pprint.pprint(rssi_matrix)
pprint.pprint(rssi_distance_matrix) triangle_dic = {}
triangle_side_list = []
for i in range(1, uuid_num_plus, 1):
for ii in range(1, uuid_num_plus, 1):
for iii in range(1, uuid_num_plus, 1):
if i != ii and i != iii and ii != iii:
triangle_id = '%s%s%s' % (i, ii, iii)
chk_unique_triangle_id_list = sorted(list(triangle_id))
if chk_unique_triangle_id_list in triangle_side_list:
continue
triangle_side_list.append(chk_unique_triangle_id_list)
triangle_dic[triangle_id] = {}
triangle_dic[triangle_id]['length_of_side_dic'] = []
triangle_dic[triangle_id]['is_triangle'] = 0
c = rssi_distance_matrix[i][ii]
b = rssi_distance_matrix[i][iii]
a = rssi_distance_matrix[ii][iii]
is_triangle = chk_triangle(a, b, c)
triangle_dic[triangle_id]['is_triangle'] = is_triangle
if is_triangle == 1:
triangle_dic[triangle_id]['length_of_side_dic'] = {}
triangle_dic[triangle_id]['angle_of_side_dic'] = {}
k12 = '%s%s' % (i, ii)
k13 = '%s%s' % (i, iii)
k23 = '%s%s' % (ii, iii)
triangle_dic[triangle_id]['length_of_side_dic'][k12] = a
triangle_dic[triangle_id]['length_of_side_dic'][k13] = b
triangle_dic[triangle_id]['length_of_side_dic'][k23] = c # filter_ triangle rebuild
radius_coordinates = {}
radius_coordinates[1] = {}
radius_coordinates[1]['polar_angle'] = 0
radius_coordinates[1]['polar_radius'] = 0
radius_coordinates[2] = {}
radius_coordinates[2]['polar_radius'] = rssi_distance_matrix[1][2]
radius_coordinates[2]['polar_angle'] = 0
radius_coordinates[3] = {}
radius_coordinates[3]['polar_radius'] = rssi_distance_matrix[1][3]
a = rssi_distance_matrix[1][2]
b = rssi_distance_matrix[1][3]
c = rssi_distance_matrix[2][3]
radius_coordinates[3]['polar_angle'] = abs(compute_triangle_angle(a, b, c)) for i in range(4, uuid_num_plus, 1):
radius_coordinates[i] = {}
radius_coordinates[i]['polar_radius'] = 0
radius_coordinates[i]['polar_angle'] = 0 polar_radius_i = rssi_distance_matrix[1][i] a = rssi_distance_matrix[1][2]
c = rssi_distance_matrix[2][i]
angle_radius_from12 = compute_triangle_angle(a, polar_radius_i, c) a = rssi_distance_matrix[1][3]
c = rssi_distance_matrix[3][i]
angle_radius_from13 = compute_triangle_angle(a, polar_radius_i, c) polar_angle_i = angle_radius_from12
if abs(angle_radius_from12) + radius_coordinates[3]['polar_angle'] == angle_radius_from13:
polar_angle_i = 2 * PI - angle_radius_from12
radius_coordinates[i]['polar_radius'] = polar_radius_i
radius_coordinates[i]['polar_angle'] = polar_angle_i perpendicular_coordinates = {}
for i in range(1, uuid_num_plus, 1):
dic_ = radius_coordinates[i]
res_ = radius_coordinates_to_perpendicular_coordinates(dic_)
perpendicular_coordinates[i] = {}
perpendicular_coordinates[i]['x'], perpendicular_coordinates[i]['y'] = res_['x'], res_['y'] x = [perpendicular_coordinates[i]['x'] for i in range(1, uuid_num_plus, 1)]
y = [perpendicular_coordinates[i]['y'] for i in range(1, uuid_num_plus, 1)] for i in range(1, 4, 1):
pprint.pprint(perpendicular_coordinates[i])
plt.plot(x, y)
plt.show()

science_action的更多相关文章

随机推荐

  1. JavaScript FSO属性大全

    什么是FSO? FSO 即 File System Object 文件系统对象,是一种列表 Windows 磁盘目录和文件,对目录和文件进行删除.新建.复制.剪切.移动等操作的技术.使用 FSO 网站 ...

  2. 解决:”ssh-keygen 不是内部或外部命令“ 的问题

    相信大家在 码云生成/添加SSH公钥的过程中遇到一个比较常见的问题, 在cmd,命令行输入 ssh-keygen -t rsa -C "xxxxx@xxxxx.com" ; xxx ...

  3. checkbox radio 多次操作失效

    checkbox radio 多次操作失效 , 将attr替换为prop $(this).attr('checked',true); $(this).attr('checked',false); $( ...

  4. Spring IoC,IoC原理

    一.IoC概念及原理 IOC的别名:依赖注入(DI) 2004年,Martin Fowler探讨了同一个问题,既然IOC是控制反转,那么到底是“哪些方面的控制被反转了呢?”,经过详细地分析和论证后,他 ...

  5. 微信小程序 Mustache语法详解

    最近微信小程序非常火,对于前端开发的程序员是个利好的消息,这里主要记录下微信小程序  Mustache语法. 小程序开发的wxml里,用到了Mustache语法.所以,非常有必要把Mustache研究 ...

  6. ARM汇编1

    一. 指令和伪指令 1.1. 指令 a. (汇编)指令是CPU机器指令的助记符,经过编译后会得到一串10组成的机器码,可以由CPU读取执行. 1.2. 伪指令 b. (汇编)伪指令本质上不是指令(只是 ...

  7. HDU2094 考新郎

    不容易系列之(4)--考新郎 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

  8. HCL AppScan Standard 9.0.3.13

    https://pan.baidu.com/s/1mh97vyJdWy1CmF589jZJhQ 网盘密码: q31g / 压缩密码:shungg.cn http://www.shungg.cn/pos ...

  9. A.Equivalent Prefixes

    题目大意:等价数组定义为(1≤l≤r≤m)中,所有的子区间都满足最小值下标相等,找出最大的m. 题解:我们要找到最大的m,就要保证两个数组的所有子区间最小值下标相等 所以用一个单调栈来维护一个单调递增 ...

  10. let,const

    - 让webstorm支持ES6语法:file-setting-languages&frameworks-javascript-右侧选择ES6 - let定义变量没有预解释且不能重复定义,在定 ...