science_action
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的更多相关文章
随机推荐
- java 泛型深入
1.<? extends E> <? extends E> 是 Upper Bound(上限) 的通配符,用来限制元素的类型的上限. 赋值 List<? extend ...
- Oracle的substr函数简单用法(转)
转:http://www.cnblogs.com/nicholas_f/articles/1526063.html substr(字符串,截取开始位置,截取长度) //返回截取的字 substr('H ...
- Bootstrap selectpicker 强制向下
selectpicker的方向是自适应的,但是有些界面,我们需要强制向下,可以使用属性data-dropup-auto data-dropup-auto="false" 官网上的o ...
- CENTOS6.5 编译安装MySQL5.7.14
前言 mysql5.7.14 编译安装在自定义文件路径下 下载安装包 配置安装环境 编译安装 cmake \ -DCMAKE_INSTALL_PREFIX=/data/db5714 \ -DMYSQL ...
- python基础循环语句练习
1.使用while循环输入 1 2 3 4 5 6 8 9 10 n = 1 while n < 11: if n == 7: pass else: print(n) n = n + 1 ...
- SpringBoot-Vue实现增删改查及分页小DEMO
前言 主要通过后端 Spring Boot 技术和前端 Vue 技术来简单开发一个demo,实现增删改查.分页功能以及了解Springboot搭配vue完成前后端分离项目的开发流程. 开发栈 前端 开 ...
- Codeforces - 1198C - Matching vs Independent Set - 贪心
https://codeforces.com/contest/1198/problem/C 要选取一个大小大于等于n的匹配或者选取一个大小大于等于n的独立集. 考虑不断加入匹配集,最终加入了x条边. ...
- NGUI的HUD Text的扩展插件学习--(UIFollowTarget)的使用
一,我们先导入NGUI_HUD_Text_v1.11包,导入包后会在项目生成一个这样的文件夹 二,我们添加一个cube,给cube添加一个空的游戏对象 二,我们使添加一个label,然后给label添 ...
- js的事件流理解
面试问到js的事件流,当时说的不是很清楚,现在觉得有必要把这个弄清楚. 事件捕获和事件冒泡 事件流描述的是从页面中接收事件的顺序,也可理解为事件在页面中传播的顺序. 事件流主要分为两种,即事件捕获和事 ...
- ES6——面向对象-基础
面向对象原来写法 类和构造函数一样 属性和方法分开写的 // 老版本 function User(name, pass) { this.name = name this.pass = pass } U ...