- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一些功能映射一些输入 到输出 .输出是一个复数。我真正感兴趣的是反函数 .但由于这种反演不能以解析的方式完成,我需要用数值近似来完成。
自 在计算上很昂贵我的想法是使用查找表方法。我可以生成维度为 的二维查找表(正向查找表),但我真正需要的是这个查找表的逆向——产生 基于给定的 .
对于查找表的反转,我能想到的最简单的方法是使用正向查找表的条目作为顶点,并在规则网格中在它们之间进行插值,从而产生反向查找表。如果反向查找表对于所需的精度来说太大了,我会生成粗表并将这些值用作优化算法的起始值。我是否缺少任何更简单的方法?
在哪里 , 是常数并且 , 是 .
最佳答案
对于f(x,y)
,您可以使用f(x,y)->(a,b)
2D LUT(看上表)
但存储的网格点必须选择得非常密集,以便每个网格矩形最多有一个凹凸,否则插值将无法正常工作。
如果要使用线性插值,则局部最小值/最大值必须是 LUT 内的点,因为并不总是需要更高阶的多项式插值。我会用 4 point cubic interpolation
如何计算g(a,b)->(x,y)
(x,y)
点返回相同的 (a,b)=f(x,y)
?f
是否有函数?如果 f
不起作用,那么您遇到了问题,您无法解决这个问题,除非以某种方式将范围分割为 f
起作用的子范围,然后您将必须根据一些规则选择适当的范围,具体取决于您要做什么。所以假设 f
是函数
那么如何计算 (x,y)=g(a,b)
即 f(x,y)=(a,b)
?
我将从结果的近似值开始。因此,在整个范围内尝试足够的 (x,y)
值并存储最接近所需输出的点,以便 |f(x,y)-(a,b)|
是最小的。
然后再次开始,但不是全范围而是围绕这一点
(a(t),y(t))
并且需要逆 3D 点 (a0,y0,z0)
你可以在那里使用我的近似类近似值的嵌套是这样完成的:
int n=5; // recursions
double e; // Error Of Solution Variable
approx ax,ay;
// min max step
for (ax.init(-100.0,+100.0,10.0,n,&e);!ax.done;ax.step())
for (ay.init(-100.0,+100.0,10.0,n,&e);!ay.done;ay.step())
{
e=|f(ax.a,ay.a)-(a,b)|;
}
// here (ax.a,ay.a) should hold your solution for input point `(a,b)`
g(a,b)
形状太复杂,那么这可能无法正常工作由此您可以计算出反 LUT 表......
10
,因此明智地选择 n
。对于 2D 和奇异点来说,性能还不错 O((log(N))^2)
。我在 3D O((log(N))^3)
上执行此操作,每个 e
计算有 100
点,速度非常慢(大约 35 秒)
N=(10^n)*(max-min)/step
,n
是递归的次数step/(10^n)
关于algorithm - 反向复数二维查找表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29207270/
我有一个包含两列的文件,第一列包含纯实数,第二列包含 GNUPLOT 可接受的形式的复数,{a,b}(GNUPLOT 等同于 a + bi)。我想用第二列的绝对值绘制第一列,所以我尝试了这个: 使用
我正在使用 pandas,它可以非常有效地按照我需要的方式对数据进行排序/过滤。 此代码运行良好,直到我将最后一列更改为复数;现在我得到一个错误。 return self._cython_agg_ge
我如何让 Django 意识到 countries 的单数形式是 country 而不是 countrie 最佳答案 来自docs ,如果你有一个名为 num_countries 的模板变量,你可以这
我正在从事一个项目,该项目要求我获取输入、执行 DFT(离散傅立叶变换),然后从这些值中获取过零次数。 我编写了一个算法,但它使用复数,我不知道如何操作/执行计算。这是代码: #include #i
我如何在 C 中动态定义复数的三维数组,以便我可以在访问数组时方便的 [i] [j] [k] 符号中访问? 最佳答案 扩展 Bob__ 的 example将数组分配到堆上而不是堆栈上: #includ
我想在我的 Android 项目中使用复数形式。但是,我提供的值可以是浮点值。 例如,当设置 1.5 星时,我希望这个理解,它不是 1 星而是 1.5 星s。 %d star %d star
问题:这是我的虚数正则表达式: [0-9]{0,}\d\.[0-9]{0,}\d[i]|[0-9]{0,}\d[i] 它只取一个纯复数部分的虚数。 当我的解析器遇到例如String im = "2i"
我知道关键,现在我需要搜索 5000 多个用户数据库时产生的所有 结果。任何用户可能没有一个或多个位置,由 id 和 name 字段标识。因此,我需要一个数组中的结果,不仅仅是第一个/最后一个,而是所
Gidday cobbers/尊敬的同事们, 通过实现卡尔曼预测/校正的多目标跟踪,我在其他 SO 线程中看到建议的一般方法是简单地为每个目标提供一个卡尔曼滤波器 vector/数组。 即'多单目标卡
尽管在 C# naming convention for enum and matching property 上阅读了类似但不完全是我想要的内容,但我还是在问这个问题 我发现我倾向于以复数命名枚举,
我正在尝试使用 getQuantityString基于 Android 开发人员指南检索数量字符串(复数)的资源中的方法 Quantity string (plurals) 我得到的错误是 Error
我想用 C++ 处理复数。因此我包括了#include .现在我的问题是:我如何声明一个变量?(那么我们说的格式是什么:1 + i?) 提前致谢:-) 最佳答案 // 1 + 2i std::com
我有一个名为 agency_persons 的表,其中已有一些数据。我使用 php artisan 创建了一个模型: php artisan make:model AgencyPerson 现在,当我
在 C++ 中,复数 double 的一维数组的最大大小是多少(即 std::complex array[dimension] )? 如果我在 main 和 global 中声明数组,最大大小是否有区
我使用 Mustache 来模板化我的 javascript ajax 调用,这是我的数据和模板: {'joined':1} // ajax responde data json. var myTem
我有这么大的问题。我写了一个关于复数的程序。该程序读取和写入复数,将它们相加等。 他说我应该读一下 Why should I overload a C++ operator as a global f
我将在 java 中重复我必须做的事情,以我认为我需要思考的方式来完成这个任务。 (抱歉,我是编程新手)。 头等舱;为复数定义类。我发现这很容易,我的答案如下。 public class Comple
如何在新的 dev django 版本的管理站点上将某些模型名称从“Categorys”更改为“Categories”?在旧版本中(没有管理站点和管理模型)你可以这样做; http://www.the
我最近才发现一种通过 this video 生成毕达哥拉斯三元组的方法解释它,涉及使用高斯(复杂)整数。到目前为止,我已经设法编写了一个函数,该函数返回由每个高斯整数生成的勾股三元组列表,其中虚部小于
我决定尝试一下 complex.h,然后遇到了一个我认为非常奇怪的问题。 int mandelbrot(long double complex c, int lim) { long doubl
我是一名优秀的程序员,十分优秀!