Curve interpolation - creating a path from control points (interp1 can't reflect a circle)
    조회 수: 6 (최근 30일)
  
       이전 댓글 표시
    
Hello,
I try to create a smooth path through a set of control points. It is a part of optimisation procedure at path planning algorithm, so it can't be too slow and the result must be feasible. What are the methods to achieve this?
Currently I am using interp1() function. As the path may have vertical segments (various y values for a single x coordinate), I am interpolating x and y axis separately, like this:
xPoints = interp1( 1:PointsNumber, Points(:,1), 1:1/Resolution:PointsNumber, Method );
yPoints = interp1( 1:PointsNumber, Points(:,2), 1:1/Resolution:PointsNumber, Method );
Testing it on a quater-circle path, I would expect the interpolated curve to have a constant radius throughout the whole section. However it doesn't work so! Spline has a smooth radius changes, but does a 'snake-run' all the time. Pchip seems to keep the right shape, but numerical analysis shown huge jumps in local radii (ex. from 500 to 20), what is unacceptable in my case (makes a bottleneck for maximum speed allowed). V5cubic is somewhere between those two.
What are the other ways I could use? Especially, how would you interpolate a circle to reflect the constant radius?
This an example of what I want to do, control points marked with asterix symbol. You won't notice a difference between various interpolation methods without a zoom-in, but it is huge in terms of overall time calculation, basing on speed profile restricted by local radius and acceleration limits.

댓글 수: 2
  dpb
      
      
 2016년 5월 25일
				Is the locus of the circle constant with just varying radius or do both change during the process?
답변 (1개)
  John D'Errico
      
      
 2016년 5월 26일
        
      편집: John D'Errico
      
      
 2016년 5월 26일
  
      I would suggest those interpolations did remarkably well. Did you expect some spline interpolant to magically intuit that this is a circular arc, and then a direct transition into a straight line? You have knowledge of the process that created those points. A spline interpolant sees nothing but a set of numbers, in x and y independently.
Even worse, then you fit those points as a function of point index, as the "independent" variable. I would point out that they are not even equally spaced in the (x,y) plane, but that you have chosen an equally spaced index as the parameter t. In effect, that introduces a potential problem because you introduced an artificial derivative singularity.
So, not only do you expect magical intuition on the part of a computer program, but you want it to be fast too. Sorry for the sarcasm, but if the shoe fits...
Splines are not perfect. They did a decent job as far as I can see. Splines tend to have problems at the end points, because less information is essentially available to them. Splines have problems at transitions from non-flat regions into perfectly flat regions. In fact, splines can be thought of as what I call a metaphorical model. A classical interpolating spline is actually a mathematical model of a physical system, that you are then applying as a model to your own system without any good reason, except that the spline will do a decent job in general. So, a metaphor in mathematics. As well, splines are at least reasonably fast to compute. (Yes, they are, compared to some random scheme.)
So splines tend to produce oscillations in flat regions, because of their nature. (Pchip is not a classical spline, but a close cousin thereof. It does handle those transitions to flat regions better, is fast, but is effectively a little less accurate in general.) Splines abhor singularities since they are based on polynomial segments, so you need to do the trick with a parametric fit, so (x(t),y(t)), but that too has issues.
An interpolation tool (such as a spline) is designed to produce a fit that is as acceptably smooth as possible to some set of data where it does not know the underlying model. Just some arbitrary set of points. Another day, another curve. Millions of curves - its a living. :)
If you demand better results on circular arcs as well as purely linear segments, you would need to use a tool that can recognize them as such. No, I'm not going to offer such a tool, as I don't have one on hand. I'd need to write such a code, and it would then surely fail to perform perfectly when you threw some other simple shape at it, a parabolic arc for example. (How could I know what you might do?)
And, no, a higher order spline is not a terribly good choice here. (I expect you might ask that question next.) The curve you have shown has an internal singularity, at the transition from a curved region into a flat line. A higher order spline will hit a spot like that, and do nasty (oscillatory) things between the points.
Don't even think of throwing some interpolating polynomial at this either. Polynomials abhor singularities too, and they do very nasty things to you, even on non-singular problems.
Could you write some code that would use locally circular arcs to fit to your curve? Of course, but making that code intelligent, producing smoothly varying circular arcs will be an interesting task, especially when those circular arcs sometimes transition into a region with an effectively infinite radius of curvature.
Anyway, to achieve something closer to perfection, you need to decide what set of shapes you expect to fit. Essentially, you need to provide a model for the system. You need to provide the advance intelligence, in the form of a viable description of the curve. And then you need to provide the code, since your problem is not anything that is fit by any standard tools. Of course, custom code may not be that fast either, depending on what it does, how much intelligence you try to put into the code.
Or, you may need to accept that a spline fit is not perfect, but does a decent job, SOMETIMES.
댓글 수: 4
  John D'Errico
      
      
 2016년 5월 26일
				There are other options of course. For example, you might consider tools like tension splines - there are multiple variations thereof. But expect that code to run somewhat more slowly, and you also tell of the need for speed. And of course, you would need to write a tension spline code yourself, or find one someplace.
참고 항목
카테고리
				Help Center 및 File Exchange에서 Spline Postprocessing에 대해 자세히 알아보기
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!





