How to compile against a specific MCR version?

6 Ansichten (letzte 30 Tage)
Neil Caithness
Neil Caithness am 24 Okt. 2013
Kommentiert: Image Analyst am 7 Nov. 2013
I have an application compiled for MCR 7.17 about a year ago. This has been in constant use by a third party. They requested a small change to address changes to an external API, which I made and recompiled, now for MCR 8.1, which is what I now have on my machine. Third party also installs MCR 8.1, but now the executable fails. The log files my application writes tell me that it fails not at the point of my new change, which generates the expected output, but fails later in (to-the-best-of-my-knowledge) non-dependent code, apparently on a 'find' statement with 'Too many input arguments'. I can't easily recreate a development environment because of a 1TB data stack on the third-party machine that I no longer have on mine. (Bad development management practice perhaps, but I still have a problem.)
So, my questions:
  1. Has the behaviour of 'find' changed between MCR 7.17 and 8.1?
  2. How can I compile against a specific MCR version? i.e. for MCR 17.7 on my R2013a installation.
  4 Kommentare
Image Analyst
Image Analyst am 5 Nov. 2013
Can you show us what the find() line of code looks like?
Neil Caithness
Neil Caithness am 7 Nov. 2013
The find call looks like this
k = find(eco_id==eco(i).ECO_ID);
inside a for loop iterating over i
Guess I have to find out the state of eco_id and eco.ECO_ID, as you suggest by saving a .mat file.

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Yatin
Yatin am 7 Nov. 2013
Bearbeitet: Yatin am 7 Nov. 2013
Hi Neil,
I do not think that the behavior of "find" has changed between the MCR versions. However, to be sure you can check the same on the documentation for MATLAB versions online. Below is the link:
As far as compiling against a new MCR is concerned, you need to install the new MCR and then add it as a first thing in your Windows PATH environment variable. Below is the link for the same.

Image Analyst
Image Analyst am 7 Nov. 2013
Assuming ECO_ID and eco_id are both integers, I see nothing wrong with that. And there is only one argument (the logical expression eco_id==eco(i).ECO_ID), which is not too many. I don't know what you're doing with k but you might want only one k, in case there are multiple matches. So in that case
k = find(eco_id==eco(i).ECO_ID, 1, 'first'); % Get only the first match.
if isempty(k)
warningMessage = sprintf('Warning, ecod_id %d not found!', eco_id);
uiwait(warndlg(warningMessage));
% Perhaps break out of the loop if you need to,
% or use continue to skip to end of loop.
end
  2 Kommentare
Neil Caithness
Neil Caithness am 7 Nov. 2013
Thanks very much for the tips. In this case I am expecting multiple matches to be returned in k - they are the WWF defined ecoregion polygons for which I then find the intersections.
I suspect the actual error message being give on the find statement is misleading, but I'd still like to find the cause because at some stage I am going to want to recompile this against the new MCR for my own use.
Image Analyst
Image Analyst am 7 Nov. 2013
Is there anyway you could obtain the source code?

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu MATLAB Compiler finden Sie in Help Center und File Exchange

Tags

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by