Syntax bug R2011a: x ==y

In coming up with an answer to another question I was playing around and think I found a bug in R2011a in Linux. Can anyone explain
>> x = randi(2, 10, 1)-1; % Dummy data
>> x == 0;
>> x ==0;
??? Error: "x" was previously used as a variable,
conflicting with its use here as the name of a function or command.
See MATLAB Programming, "How MATLAB Recognizes Function Calls That Use
Command Syntax" for details.
The 2nd and 3rd line differ in the presence (works) and absence (errors) of a space after ==. I cannot think of why the space matters. The error message also doesn't make sense to me. Is this reproducible? Is it a bug?

3 Kommentare

Thomas
Thomas am 20 Sep. 2012
Same error on the Mac as well.. R2012b.
I think the space (absence or presence of which causes it to identified as a variable or a function as is described in the help section 'How MATLAB Recognizes Command Syntax'
Javier
Javier am 20 Sep. 2012
Bearbeitet: Javier am 20 Sep. 2012
Hello Tom
You have to give an additional space in the second x definition. No error in Matlab R2012a for Mac
>> x = randi(2, 10, 1)-1; % Dummy data
>> x == 0;
>> x == 0; %differs from x ==0; or
>> x=randi(2, 10, 1)-1; % Dummy data
>> x==0;
>> x==0;
Daniel Shub
Daniel Shub am 20 Sep. 2012
@Javier, but I am specifically asking about the odd case of x ==0 (with a space before, but not after, ==). I think of MATLAB as being generous about the usage of white space. This is a case where you need to follow a few rules.

Melden Sie sich an, um zu kommentieren.

 Akzeptierte Antwort

Sean de Wolski
Sean de Wolski am 20 Sep. 2012
Bearbeitet: Sean de Wolski am 20 Sep. 2012

4 Stimmen

It is seeing ==0 as a string and x as a function. I.e. equivalent to:
x '==0';
This is not a bug. From the doc:
Space after an identifier, but not after a potential operator, implies a function call using command syntax. For example:
ls ./d

4 Kommentare

Daniel Shub
Daniel Shub am 20 Sep. 2012
To be exact, I think it is really seeing it as x('==0'). The link in the error message provides some clues. For whatever reason it is calling x as a function with the "command" syntax (i.e., how functions like help, doc and edit are often used and how load should never be used). The documentation, however, I cannot make heads or tails of the documentation.
Daniel Shub
Daniel Shub am 20 Sep. 2012
But the reference says "If you issue such a statement at the command line, MATLAB can access the current workspace and path to determine whether ls and d are functions or variables."
Sean de Wolski
Sean de Wolski am 20 Sep. 2012
Bearbeitet: Sean de Wolski am 20 Sep. 2012
Hence it throws the error for the conflict (it wants to call x as a function but can't because it's a variable)
Also:
x('==0') is equivalent to >>x '==0' and apparently >>x ==0
Jan
Jan am 5 Mär. 2013
The different behavior between "x == 0" and "x ==0" might be a documented bug. The smartness of Matlab intelligent auto-parsing of the non-functional form exceeds the intuition of programmers. Now I'm unsure avour "x>0" and "x >=0" also.
The number of forum users struggeling with save(FileName) compared to save FileName decreases. I assume the newer documentation is better.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Community Treasure Hunt

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

Start Hunting!

Translated by