如何找到曲线的最陡点或曲率的弧度?

时间:2019-02-06 10:38:30

标签: geometry geometry-surface geometric-arc

鉴于曲线,我仅具有曲线的(X,Y)坐标,所以我想找到该曲线的最陡点或弧长(弧的起点和终点)

1 个答案:

答案 0 :(得分:0)

如果您有一组要在其间绘制直线的点,则该点为多边形,而Polyon的点则没有坡度,因为该点一侧的线的坡度通常不是与该点另一侧的线的斜率相同。您可以得到两点之间的斜率,这是下面的代码所做的。 (这是JavaScript,因为您没有指定语言)

var pointsArray = [[0,0],[5,13],[10,19],[15,14],[20,-3]];

function findSlopes(points) {
    var result = [];
    for (i = 0; i < points.length - 1; i++) {
        var rise = points[i+1][1] - points[i][1];
        var run = points[i+1][0] - points[i][0];
        result.push(rise / run);
    }
    return result;
}

var slopesArray = findSlopes(pointsArray);

console.log("slopes " + slopesArray);

要找到最陡峭的斜率,请逐步遍历lopes数组以找到最高的绝对值。

function steepestSlope(slopes) {
    var steepestValue = 0;
    var steepestIndex = -1;
    for (var i = 0; i < slopes.length; i++) {
        if (Math.abs(slopes[i]) > Math.abs(steepestValue)) {
            steepestValue = slopes[i];
            steepestIndex = i;
        }
    }
    return steepestIndex;
}

var steepest = steepestSlope(slopesArray);

console.log("steepest " + steepest);

下面的代码查找由点表示的多边形的总长度。

function findLength(points) {
    var result = 0;
    for (i = 0; i < points.length - 1; i++) {
        var dx = points[i+1][0] - points[i][0];
        var dy = points[i+1][1] - points[i][1];
        result += Math.sqrt(dx * dx + dy * dy);
    }
    return result;
}
var length = findLength(pointsArray);

console.log("length " + length);

如果您使用除直线以外的其他东西来连接点,例如样条曲线,则这些点的确具有曲率,并且数学运算更加复杂。