Vector ranking and transformation matrix

3 visualizaciones (últimos 30 días)
Xia
Xia el 21 de Sept. de 2016
Comentada: Xia el 22 de Sept. de 2016
Hello. Suppose we have a vector [1 4 3], here -x1+x2>0, -x1+x3>0 and also x2-x3>0. How can we transform this ranking information into a matrix like [-1 1 0; -1 0 1; 0 1 -1]? Is there a function to realize it? Thank you in advance for your time and help.
  2 comentarios
Stalin Samuel
Stalin Samuel el 21 de Sept. de 2016
  • Once you evaluate the below details you get the answer
  • What is the values of x1,x2,x3 ?
  • How do you relate the given vector with ranking information?
  • What is the logic behind the final matrix?
Xia
Xia el 21 de Sept. de 2016
Thank you Stalin and your evaluation questions are of key. I'm coding for a stochastic dominance problem and the x is productivity vector or return vector, while y is weight vector to solve for. The ranking of y should be reverse of that of x, even thought we don't know it yet and wanna a solution.
Thanks for your comment.

Iniciar sesión para comentar.

Respuesta aceptada

Matt J
Matt J el 21 de Sept. de 2016
Editada: Matt J el 21 de Sept. de 2016
n=length(x);
A=nchoosek(1:n,2);
m=size(A,1);
B=sparse(1:m, A(:,1),1,m,n) - sparse(1:m, A(:,2),1,m,n);
result=full(bsxfun(@times, sign(B*x), B))
  6 comentarios
Matt J
Matt J el 21 de Sept. de 2016
Hmmm. The discrepancy disappeared after I re-pasted the for-loop code. In any case, here is an improved version for which I see a few factors speed-up over the loops.
x=randperm(1000).';
tic
n=length(x);
[I,J]=ndgrid(1:n);
idx=J>I;
m=nnz(idx);
B=sparse(1:m,J(idx),1,m,n) - sparse(1:m, I(idx),1,m,n);
result=bsxfun(@times, sign(B*x), B);
toc
%Elapsed time is 0.685717 seconds.
tic
T=length(x);
X=[x [1:T]'];
k=sortrows(X);
V=k(:,2);
s=1;Q=zeros(T*(T-1)/2,T);
for i =1:T
for j =1:T-i
Q(s,V(i))=-1;Q(s,V(i+j))=1;s=s+1;
end
end
toc
%Elapsed time is 2.316114 seconds.
Xia
Xia el 22 de Sept. de 2016
Impressive improvement Matt, especially for high dimensional vectors.
Thank you very much, for your help!

Iniciar sesión para comentar.

Más respuestas (1)

Steven Lord
Steven Lord el 21 de Sept. de 2016
If you're asking how to convert the inequalities (like -x1 + x2 < 0) into matrix form, I don't know if there's a function to do exactly that but the equationsToMatrix function comes close. You may be able to slightly modify your inequalities so they are equations then use equationsToMatrix to generate the matrices to use as your A, b, Aeq, and beq inputs to the Optimization Toolbox solvers (which is how I'm assuming you're planning to use those matrices.)
  1 comentario
Xia
Xia el 21 de Sept. de 2016
Thanks a lot Steven, for your insight. You are absolutely right that I'm intended for the optimization. In fact, I want to maximize x'y, while I know x but the unknown y should have a reverse ranking of x. For example x=[1 4 3] so y1 should be the largest y2 the smallest. I can't get any clue on restrictions on ranking of the LP unknown, that's why I think using ranking information of x would be an alternative. Any idea on this Steven?
Thank you very much for your answer!

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by