Undefined function 'plus' for input arguments of type 'matlab.ui.Figure'.

조회 수: 14 (최근 30일)
Daisy
Daisy 2014년 10월 7일
편집: Matthew 2015년 5월 5일
I get this error message when I run a script that was given to me on my data and may well have been written in an earlier version - I am working 2014b.
Any ideas? This is the full error message, but I haven't copied the script in as it's really quite long.
Undefined function 'plus' for input arguments of type 'matlab.ui.Figure'.
Error in PRL_analyseData>getNewFig (line 538) hfig = varargin{1}+1;
Error in PRL_analyseData (line 160) hfig = getNewFig(hfig,cmap);
  댓글 수: 1
Adam
Adam 2014년 10월 7일
You probably need to rework the script to use an array of figure objects rather than doing maths on the old handles to refer to presumably the next figure.

댓글을 달려면 로그인하십시오.

채택된 답변

Guillaume
Guillaume 2014년 10월 7일
The reason it does not work in 2014b is because figures handles are no longer numbers. Thus you can't add 1 to them anymore.
Without seeing anymore of the code, it's difficult to give you any advice on how to solve this.
  댓글 수: 6
Daisy
Daisy 2014년 10월 8일
Thank you, that's most helpful
Guillaume
Guillaume 2014년 10월 8일
If you're happy with the solution provided, you should accept it.

댓글을 달려면 로그인하십시오.

추가 답변 (2개)

Daisy
Daisy 2014년 10월 8일
Many thanks, that has definitely helped. However I now have a different error message:
Undefined function 'vline' for input arguments of type 'double'.
Error in PRL_analyseData (line 266)
vline(40.5,'k:');
This is the section of the code it relates to. Is it to do with 2014b changes again?
% average and smoothed average probability of chosing correctly on each
% trial
choiceBinary = choice;
choiceBinary(choice==2)=0;
plotdata{1} = choiceBinary;
plotdata{2}= mySmooth(choiceBinary,span,2);
for n = 2 % can also plot the raw data, then n=1
hfig = getNewFig(hfig,cmap);
mu = []; sem = [];
for t = cond
mu(:,t) = mean(plotdata{n}(groupMember==t,:));
switch n
case 1
plot(mu(:,t),'linewidth',2,'color',cmap(t,:))
case 2
sem(:,t) = std(plotdata{n}(groupMember==t,:),[],1)/sqrt(nsgroup(t)); end
end
if n==2
b = nan(nt,1,max(cond));
b(:,1,:) = sem;
x = repmat(1:nt,max(cond),1)';
boundedline(x,mu,b,'alpha','cmap',cmap)
end
legend(groupLabel,'location','Best')
vline(40.5,'k:');
xlabel('trial');
ylabel('p(stimulus1)')
ylim([0 1])
end
  댓글 수: 4
Daisy
Daisy 2014년 10월 8일
My apologies. Yes, I worked out that vline came from the file exchange. Thanks. I now have an issue with:
No method 'colon' with matching signature found.
Error in PRL_analyseData (line 303)
for t = 1:hfig
This relates to this section of the script:
hfig = getNewFig(hfig,cmap);
mu = []; sem = [];
for t = cond
mu(1,t) = mean(WS(groupMember==t));
mu(2,t) = mean(LS(groupMember==t));
sem(1,t) = mean(WS(groupMember==t))/sqrt(nsgroup(t));
sem(2,t) = mean(LS(groupMember==t))/sqrt(nsgroup(t));
end
barweb(mu,sem,groupLabel,{'WStay','LShift'},'Best',0.8,cmap);
set(gca,'xtick',1:2);
for t = 1:hfig
print(t,'-depsc','-tiff','-r300',sprintf('Figure%d',t));
end
end
I am reading about signatures in order to try and resolve this, but would appreciate any help
Guillaume
Guillaume 2014년 10월 8일
Please, find the reply as a comment to my answer rather than here.

댓글을 달려면 로그인하십시오.


Matthew
Matthew 2015년 5월 5일
편집: Matthew 2015년 5월 5일
An updated answer to this is to overload the 'plus' function. It seems that matlab calls the builtin for inline operators by default, even if the overload doesn't pay any attention to the rules for overloading a function. I have no idea why this is though, as overloading other critical functions like sprintf seems to cause a world of pain.
Regardless of the reason, this oddity means the following function can be placed anywhere in your path, and it will only be called if the regular plus function can't handle the inputs, so it doesn't impact normal behavior or performance.
function out = plus(A,B)
try
out = double(A) + double(B)
catch
%Fail with the built-in
builtin('plus',A,B)
end

카테고리

Help CenterFile Exchange에서 Graphics Object Programming에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by