Azzera filtri
Azzera filtri

Is there any way to set function (or method) output as comma separated list?

2 visualizzazioni (ultimi 30 giorni)
If we have an array of struct, like this:
s(1).a = 1;
s(2).a = 2;
s(3).a = 3;
and then if we get the field of this array, then the result would be like:
s.a
ans =
1
ans =
2
ans =
3
As I know, this output is comma separated list.
I want to have this behavior in my method output too, so that I can use my object just as how I use structs. Something like this:
classdef myObject
properties
myProp
end
methods
function this = myObject(input)
%constructor
this.myProp = input;
end
function output = myMethod(this)
% this function should return myProp as comma separated list
% when myObj array 'this' is given
% I don't know what to do here
% My best try:
% anyway the code below here obviously doesn't work...
output = {this(:).myProp}
end
end
and
myObj(1) = myObject('A');
myObj(2) = myObject('B');
myObj(3) = myObject('C');
myObj.myMethod
ans =
A
ans =
B
ans =
C
It would be cool, isn't it?
I tried varargout, but it only outputs explicit number of nargout, so if the output argument is not specified, it will give only one output, which is varargout{1}.
Is there any good way to do this?
  2 Commenti
KSSV
KSSV il 24 Ott 2018
YOu make your output a structure and take it out..what issue you have?
Hyeokjin Jho
Hyeokjin Jho il 24 Ott 2018
So the best way here is something like this? :
someStruct = myObj.myMethod;
someStruct.output
ans =
A
ans =
B
ans =
C
and there is no direct way to output a comma separated list?

Accedi per commentare.

Risposta accettata

Matt J
Matt J il 24 Ott 2018
Modificato: Matt J il 24 Ott 2018
You should be able to do it by overloading numArgumentsFromSubscript. In other words, tell the class to interpret
>> myObj.myMethod(arg)
as a dot-indexing expression rather than a function call.
The hassle with this is that, similar to overloading subsref, you now have to explicitly implement code in the method to distinguish which dot-indexing expressions are function calls and which are actual indexings.

Più risposte (1)

Hyeokjin Jho
Hyeokjin Jho il 12 Gen 2022
I found a workaround by using properties with custom get method.
classdef myObject
properties
myProp
end
properties (Dependent,SetAccess = private)
myDepProp
end
methods
function this = myObject(input)
%constructor
this.myProp = input;
end
end
methods
function output = get.myDepProp(this)
output = this.myProp; % operates as singleton
end
end
end
Test:
myObj(1) = myObject('A');
myObj(2) = myObject('B');
myObj(3) = myObject('C');
myObj.myDepProp
ans =
'A'
ans =
'B'
ans =
'C'
  2 Commenti
Matt J
Matt J il 12 Gen 2022
Modificato: Matt J il 12 Gen 2022
Yes, although I think the example would be clearer if MyDepProp performs some additional work that a class method might, e.g.,
methods
function output = get.myDepProp(this)
output = lower(this.myProp); % operates as singleton
end
end
>>myObj(1) = myObject('A');
>>myObj(2) = myObject('B');
>>myObj(3) = myObject('C');
>> myObj.myDepProp
ans =
'a'
ans =
'b'
ans =
'c'
Matt J
Matt J il 12 Gen 2022
A limitation of this approach, of course, is that it does not allow the "method" to take additional input arguments.

Accedi per commentare.

Community Treasure Hunt

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

Start Hunting!

Translated by