Filter löschen
Filter löschen

Variable change over time

6 Ansichten (letzte 30 Tage)
Amaral
Amaral am 8 Okt. 2015
Kommentiert: Star Strider am 9 Okt. 2015
Hello friends!
I have three 2d points (the xx values represents time instants between [0;1] and yy represents rotation values): initial = [0 , 0]; middle = [0.5 , 1.5409]; final = [1 , 3.0817];
I'm looking to do an interpolation of the remaining points for each 0.1 in the xx axis. The easiest way is to do a linear interpolation using linspace, but in this case i dont want to use evenly spaced values. What i want to do have is to have lower yy values on the first 4 intervals ([0 ; 0.4]) and higher yy values on the last 4 ([0.6 ; 1]), like the one i represented on the image below with orange color (blue represents the linear interpolation). Any ideas? Thanks for helping! :)

Akzeptierte Antwort

Star Strider
Star Strider am 8 Okt. 2015
I would fit it with a Logistic function, simply because it looks like one.
  4 Kommentare
Amaral
Amaral am 9 Okt. 2015
Yes it is! Thanks a lot friend! :)
Star Strider
Star Strider am 9 Okt. 2015
My pleasure!

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Robert Dylans
Robert Dylans am 8 Okt. 2015
Bearbeitet: Robert Dylans am 8 Okt. 2015
If there's no particular requirement for the function's data, other than it "looks like" that kind of shape, you can use a formula similar to this:
x=0:0.01:1;
y=3.0817*(1-(1-((2*x).^3)./8).^5);
plot(x,y)
This was just a formula I happened to be using for something else, that has a similar curve fit. I'm sure there are many with similar functions. Note that this one only works for values of x in the range of [0 1]
  1 Kommentar
Amaral
Amaral am 9 Okt. 2015
That seems to be doing what i want! Thanks a lot! :)

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Interpolation finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by