- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在极坐标图中可视化环空中测量的压力。问题是我只有 6 个测量点,因此绘图是星形的,而由于液体中的垂直压力梯度,它应该是椭圆形的。请注意,它不必是圆形,因为左右注入(inject)压力可能不同。
首先,我尝试使用 matplotlib 的极坐标函数绘制图,结果得到了星形图。然后我尝试分散数据,但现在我无法通过数据点拟合椭圆。
loc_deg =(71, 11, 306, 234, 169, 109, 71) # location of sensors 1, 2, 3, 4, 5, 6, 1 1 is repeated to complete the star/circle
loc_rad = np.radians(loc_deg) # use radians
P = (2.7269999999999999, 3.0019999999999998, 0.39800000000000002, 2.9729999999999999, 2.5099999999999998, 2.5609999999999999, 2.7269999999999999)
fig = plt.figure()
ax = fig.add_subplot(111,projection = 'polar')
ax.set_ylim(0,10)
ax.set_xticks(loc_rad)
tv = ax.plot(loc_rad, P)# create star
lis = ax.scatter(loc_rad, P, color = '#ff7f00', marker = '.') # create scatter
现在我试图通过散点图拟合一个椭圆,或者星形应该在椭圆中变化。
编辑 This is a plot of the three solutions, including the one proposed by Ardweaden
在尝试 Ardweadens 解决方案后,我意识到合适的东西并不完全是我想要的,因此我的问题不清楚。我正在寻找一种方法来连接极面上的点,而不仅仅是一条直线。
例如:如果有 2 个测量点:1 个在 1 度上,1 个在 179 度上,这两个测量值都是值 10。通过使用绘图函数,一条直线将在 90 度处显示几乎为 0 的值,在 10 和 10 之间进行插值时,您会期望那里的值也为 10。所以更像是一个半圆。
最佳答案
只是拟合一个椭圆。
from scipy.optimize import curve_fit
def ellipse(phi,b,e,f):
return b/(np.sqrt(1 - e * np.cos(phi + f)**2))
popt, pcov = curve_fit(ellipse, loc_rad, P)
x = np.arange(0,2*np.pi,0.01)
ax = fig.add_subplot(111,projection = 'polar')
ax.plot(x,ellipse(x,popt[0],popt[1],popt[2]))
对数据进行硬编码并绘制梯度:
loc_deg =(306, 234, 169, 109,71,11) # location of sensors 1, 2, 3, 4, 5, 6, 1 1 is repeated to complete the star/circle
loc_rad = np.radians(loc_deg) # use radians
P = (0.39800000000000002, 2.9729999999999999, 2.5099999999999998, 2.5609999999999999,3.0019999999999998,2.7269999999999999)
fig = plt.figure()
ax = fig.add_subplot(111,projection = 'polar')
ax.set_ylim(0,10)
ax.set_xticks(loc_rad)
def generate_fit(deg,P,deg_f=1):
x,y = [],[]
for i in range(1,len(P)):
x.extend(np.arange(deg[i-1],deg[i],-1))
incy = abs(deg[i]-deg[i-1])
y.extend(np.linspace(P[i-1],P[i],incy))
x.extend(np.arange(11,0,-1))
x.extend(np.arange(360,306,-1))
y.extend(np.linspace(P[-1],P[0],360-306 + 11))
return np.radians(x),y
x,y = generate_fit(loc_deg,P)
ax.plot(x,y)
ax.scatter(loc_rad, P, color = '#ff7f00', marker = '.')
关于python - 尝试将标准的北极星改为更优雅的椭圆形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57287948/
我试图理解基数排序,但在理解实现实际代码时改 rebase 数时遇到问题。这是我用来学习基数排序的代码,我会尝试解释我不明白的地方。 此代码由 GeeksForGeeks 提供: // C++ imp
话不多说,请看代码: ? 1
本文实例讲述了mysql语句实现简单的增、删、改、查操作。分享给大家供大家参考,具体如下: 1、创建db_shop数据库,如果该数据库不存在则创建 ?
使用oracle触发器 实现对某个表的增改删的监控操作,并记录到另一个表中。 代码: 复制代码代码如下: create or replace trigger test_trigge
java连接数据库增、删、改、查工具类 数据库操作工具类,因为各厂家数据库的分页条件不同,目前支持Mysql、Oracle、Postgresql的分页查询 在Postgresql环境测试过了,其他
1、修改数据 复制代码代码如下: DataRow dr =
注册表可以用来进行存储一些程序的信息,例如用户的权限、或者某些值等,可以根据个人需要进行存储和删减。 当前注册表主目录: 引用包 Wesky.Net.OpenTools 1.0.5或
是否可以将 pdf 页面的页眉更改为与当前所选书签同名的名称?我正在为我的 pdf 生成使用 Flying Saucer 。你能举个例子吗?提前致谢。 最佳答案 这对我适用于 flyingsaucer
好家伙,写后端,这多是一件美逝. 关于这个项目的代码前面的博客有写 我的第一个独立项目 - 随笔分类 - 养肥胖虎 - 博客园 (cnblogs.com
准备工作: 增、删、改、查的方法有很多很多种,这里只展示出常用的几种。 ?
需要5个类: 1.实体类:Person.java 2.抽象类:SQLOperate.java(封装了对数据库的操作) 3.助手类:DBOpenHelper.java(继承SQLiteOpenH
首先是是一个简单的例子,单链表的建立和输出。 程序1.1 复制代码 代码如下: #include<iostream> #include<string> using na
数据库操纵基本流程为: 1、连接数据库服务器 2、选择数据库 3、执行SQL语句 4、处理结果集 5、打印操作信息 其中用到的相关函数有 •resource m
我需要为 iPad 和 iPhone 设置不同颜色的标签,我知道我们可以为不同的尺寸类别更改字体大小,但是有什么方法可以根据尺寸类别的值设置不同的颜色 我知道有可用的代码解决方案,但我想知道 size
假设我有一个物体相对于相机的坐标 X、Y、Z 和方向 Rx、Ry、Rz。此外,我有这个相机在世界上的坐标 U、V、W 和方向 Ru、Rv、Rw。 如何将对象的位置(位置和旋转)转换为其在世界中的位置?
CRUD是Create(创建)、Read(读取)、Update(更新)和Delete(删除)的缩写,它是普通应用程序的缩影。如果您掌握了某框架的CRUD编写,那么意味可以使用该框架创建普通应用程序了
项目结构: 添加页面: &
本文实例讲述了android操作sqlite数据库(增、删、改、查、分页等)及listview显示数据的方法。分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识
总括 pandas的索引函数主要有三种: loc 标签索引,行和列的名称 iloc 整型索引(绝对位置索引),绝对意义上的几行几列,起始索引为0 ix 是 iloc 和 loc的合体 at
我是一名优秀的程序员,十分优秀!