7

我有一个正方形,其中最近的点距离中心 1 个单位。请参阅下面的我的 ascii 图:

+-----------+
|           |
|  x        |
|-----+     |
|           |
|           |
+-----------+

因此,从原点到角点的距离是 sqrt(2)。我需要一个函数来返回从原点到正方形上任意角度点的距离。例如,对于 0 的输入,该函数将返回 1。对于 45 的输入,该函数将返回到一个角的距离,即 2 的平方根。然后对于 90,它将再次返回 1。

换句话说,当你用极坐标图绘制函数时,它会画一个正方形。

我相信这个功能会是这样的:

f(x) = sqrt(tan(x)^2+1)

唯一的问题是上面的函数不会绘制正方形的边。我需要一些能够吸引所有 4 个方面的东西。

我知道有一个与此类似的三角函数,但我将在 javascript 中使用这个函数,所以我只能使用标准的三角函数。

任何帮助将不胜感激。提前致谢。

4

4 回答 4

10

我猜这会更快:

function getLengthForDeg(phi){
    phi = ((phi+45)%90-45)/180*Math.PI;
    return 1/Math.cos(phi);
}
于 2011-01-25T01:04:23.590 回答
2

原始帖子被标记为 Javascript,但对于不能对浮点数进行模数的类型语言(例如 C),我需要它。

MonoMano 的答案是正确的,但是对于其他需要同样事情的人来说,这里是 MonoMano 为 C / ObjC / Java / 等修改的答案:

/** c.f. http://stackoverflow.com/a/4788992/153422
* M_PI_2 is a constant: "PI / 2"
* M_PI_4 is a constant: "PI / 4"
*/
double getSquarePolarRadiusForRad(double phi){
    double phiInPiBy4Range = phi;
    while( phiInPiBy4Range > M_PI_4 )
        phiInPiBy4Range -= M_PI_2;
    while( phiInPiBy4Range < - M_PI_4 )
        phiInPiBy4Range += M_PI_2;

    return 1/cos(phiInPiBy4Range);
}
于 2012-11-05T13:24:57.090 回答
2

我对 Javascript 不够熟悉,但在 Wolfram Alpha 中使用的格式中,角度半径的公式是:

min(1/abs(cos(theta)),1/abs(sin(theta))))

于 2014-03-20T00:22:25.457 回答
1

我想出了一个可以与 TI 计算器一起使用的方程,因为它们在极坐标图函数的窗口部分中具有 theta 阶跃函数。不知道对你有没有帮助。我想它只有在您能够配置 theta(或度数)步骤时才能工作。

r = (((s*sqrt(2)) - 5)/4) sin(4(x - (pi/8)) + (((s*sqrt(2)) + s)/4)

其中 s 是所需正方形的边长

将 theta 步长设置为 pi/4 以绘制创建正方形图像所需的主要点

同样,这适用于 TI 计算器。

于 2012-05-10T03:17:49.377 回答