Concatenate matrix numbers linspace

6 ビュー (過去 30 日間)
Amazing Trans
Amazing Trans 2012 年 8 月 13 日
Hi there,
I have a matrix variable x = [0 1 2 3]
I want to generates linearly spaced vectors in between the numbers into a variable. My problem here is concatenate the numbers into p the next time n increases.
I know i should be using linspace to generate number for eg:
for i = 1:(length(x)-1)
p = linspace(x(i),x(i+1),0.5)
end
the results i want is:
p = 0 0.5 1 1.5 2 2.5 3
Hope someone can shed some light here.
  1 件のコメント
Azzi Abdelmalek
Azzi Abdelmalek 2012 年 8 月 13 日
what do you mean by
p = linspace(x(i),x(i+1),0.5)

サインインしてコメントする。

採用された回答

Azzi Abdelmalek
Azzi Abdelmalek 2012 年 8 月 13 日
編集済み: Azzi Abdelmalek 2012 年 8 月 29 日
try this
x = [0.25 1 1.5 2 2.4 2.6]
x=unique(sort([x x(1:length(x)-1)+diff(x)/2]) )
if you want put 2^n-1 samples between each value use this function
function y=linspace_n(x,n)
for k=1:n
x=unique(sort([x x(1:length(x)-1)+diff(x)/2]) )
end
y=x
  6 件のコメント
Matt Fig
Matt Fig 2012 年 8 月 14 日
編集済み: Matt Fig 2012 年 8 月 14 日
Better to use one of these. First a vectorized version:
function y = linspace_n2(x,N)
% Puts N values linear interpolated between each element of x.
% Author - Matt Fig
L = length(x);
y = bsxfun(@plus,bsxfun(@times,(0:N)',diff(x)/(N+1)),x(1:L-1));
y = [reshape(y,1,(L-1)*(N+1)),x(L)];
Or one could even go with a simplistic:
function y = linspace_n3(x,N)
% Puts N values linear interpolated between each element of x.
% Author - Matt Fig
y = [];
R = (0:N);
D = diff(x)/(N+1);
for ii = 1:length(x)-1
y = [y x(ii) + R.*D(ii)];
end
y = [y x(end)];
Azzi Abdelmalek
Azzi Abdelmalek 2012 年 8 月 29 日
sorry, did'nt read your comment, yes what it does is puting 2^n-1 points instead of n

サインインしてコメントする。

その他の回答 (5 件)

Matt Fig
Matt Fig 2012 年 8 月 13 日
編集済み: Matt Fig 2012 年 8 月 13 日
p = 0:.5:3;
or
p = linspace(0,3,7)
EDIT.
I think I misunderstood your problem. Do you mean like this:
x = [0.25 1 1.5 2 2.4 2.6]
x(2,1:end-1) = diff(x)/2+x(1:end-1);
x = reshape(x(1:end-1),1,[])

Amazing Trans
Amazing Trans 2012 年 8 月 13 日
Sorry, i had to be more clear. x is not linearly equal, which means x can be this as well
x = [0.25 1 1.5 2 2.4 2.6]
Thanks!

Sean de Wolski
Sean de Wolski 2012 年 8 月 13 日
編集済み: Sean de Wolski 2012 年 8 月 13 日
Here is a terrible solution:
x = 0:3; %sample x
x = [x(1:end-1); x(2:end)]; %each start/end pair
nAdd = 2; %add two elements between
xnew = interp1((1:2)',x,linspace(1,2,2+nAdd)); %interpolate (2d linspace)
xnew = vertcat(reshape(xnew(1:end-1,:),[],1),x(end)) %keep non-duplicate parts

Amazing Trans
Amazing Trans 2012 年 8 月 14 日
編集済み: Amazing Trans 2012 年 8 月 14 日
Alright here is something more challenging:
If i have x = [0 1 2 4 1]
I want x to be spaced equally n time. n = 2 therefore results = [0 0.25 0.5 1 1.25 1.5 2 2.6667 3.3333 4 3 2 1]
the other function i would like is increase by 0.1 or n where: x = [ 0 1 2] results = [0 0.1 0.2 0.3...0.9 1 1.1 1.2 1.3...1.9 2]
My first initial thought was to use linspace with for loop. and then results is a matrix where when the i increase it will concatenate into the results matrix... I'm not sure on the ??? part. The easier the code the better as I am transferring the matlab code to VB later as well. Of course this code below does not work for results(start).the error i get is: "Subscript indices must either be real positive integers or logicals." Any idea what to modify here?
for eg:
x = [0 3 1]
start = 0;
for i = 1:(length(x)-1)
y = linspace(x(i), x(i+1),points);
results(start) = y
start = start + points + 2;
end
  3 件のコメント
Matt Fig
Matt Fig 2012 年 8 月 14 日
Please close out this question by selecting a best answer then post a new question and link back to this one.
Sean de Wolski
Sean de Wolski 2012 年 8 月 14 日
My answer handles your first scenario!

サインインしてコメントする。


Amazing Trans
Amazing Trans 2012 年 8 月 14 日
Thanks very much everybody. Problem solved.

カテゴリ

Help Center および File ExchangeLoops and Conditional Statements についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by