鉴于曲线,我仅具有曲线的(X,Y)坐标,所以我想找到该曲线的最陡点或弧长(弧的起点和终点)
答案 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);
如果您使用除直线以外的其他东西来连接点,例如样条曲线,则这些点的确具有曲率,并且数学运算更加复杂。