Bug in matlab's builtin sort routine

3 visualizaciones (últimos 30 días)
Leo Simon
Leo Simon el 25 de En. de 2013
Matlab's 2012b has introduced all sorts of bugs in its sort routine. Consider the following
syms d1_X1_f1 d1_X1_f2 d1_X2_f1 d1_X2_f2 d1_b1_f1 real
A = sort([d1_X1_f1, d1_X1_f2, d1_X2_f1, d1_X2_f2, d1_b1_f1 ])
A'
In R2011a, this is correctly sorted as
d1_X1_f1
d1_X1_f2
d1_X2_f1
d1_X2_f2
d1_b1_f1
But in R2012b, we get
d1_X1_f1
d1_X1_f2
d1_X2_f1
d1_b1_f1
d1_X2_f2
There is at least one other bug that I've discovered, which I've been able to work around, but this one is really nasty. Does anybody have out there a sort algorithm that works properly? Since sort is a builtin, I can't just pull in the file from my 2011a distribution.
Any advice would be appreciated!
  3 comentarios
Leo Simon
Leo Simon el 25 de En. de 2013
I did report this, and a related one due to symbolic sorting. Hopefully they'll do something about it.
Andreas Goser
Andreas Goser el 25 de En. de 2013
Hope is not a strategy ;-) I researched and the bugs are fixed. I will contact you by email for additional information.

Iniciar sesión para comentar.

Respuestas (2)

Walter Roberson
Walter Roberson el 25 de En. de 2013
If you use
T = [d1_X1_f1, d1_X1_f2, d1_X2_f1, d1_X2_f2, d1_b1_f1 ];
which sort(T)
I suspect you will find that a symbolic toolbox sort.m is used (but that file might call into MuPAD)

Leo Simon
Leo Simon el 25 de En. de 2013
I guess I've found my own workaround, which is incredibly unsatisfactory, but does seem to work. Convert the symbolic array to a cell array of strings, then sort, then convert back to syms. Uggh, I feel ill just typing this....
  1 comentario
Andreas Goser
Andreas Goser el 28 de En. de 2013
Worked with the customer offline. If another customer runs into this and calls Technical Support, refer to "G906530"

Iniciar sesión para comentar.

Community Treasure Hunt

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

Start Hunting!

Translated by