>40 seconds waiting for Undefined function or variable error 2017b

13 vues (au cours des 30 derniers jours)
Adam Danz
Adam Danz le 30 Oct 2017
Commenté : Borja Prieto le 18 Mai 2022
I'm using matlab 2017b on a windows 7 64 bit machine and when I accidentally reference a variable or function that doesn't exist, Matlab consumes a significant amount of time in 'busy' mode before throwing the error: 'Undefined function or variable'. I've paused the execution a few times to see where the bottleneck is and it has always opened the findUnlicensedFunctions() function. To cause this error, I type in any nonsense command such as "ttt" in the command window where ttt does not refer to any function or variable. Using tic/toc just before and after the call to ttt resulted in 43 seconds waiting for the error. Is anyone else experiencing this or might it be specific to my environment? I upgraded last week from 2016a and did not have this problem before.
  3 commentaires
Adam Danz
Adam Danz le 29 Août 2018
Update: I received an email from the tech team claiming to have solved this problem in the new release which I suppose is 2018b (which hasn't been released yet).
Adam Danz
Adam Danz le 12 Avr 2019
Unforunately this is still a very frustrating problem (r2019a).
If you're connected to a wireless network and you call a function or a variable that contains a typo and therefore no longer corresponds to an existing function or variable, the delay for the error message to appear is up to a minute sometimes - just waiting for Matlab in the 'busy' state. Ctrl+c does not stop this process. Pausing it does not speed it up but eventually terminates in findUnlicensedFunctions().

Connectez-vous pour commenter.

Réponse acceptée

Adam Danz
Adam Danz le 22 Avr 2018
Modifié(e) : Adam Danz le 25 Août 2019
Apparently when a variable or function is called but not available, matlab searches network locations on the matlab path and if those connections are no longer accessible, this delay occurs. To confirm that this is what's causing the unbearably long deley, I turned off/on my internet connection(s) and the problem vanished when there wasn't a connection but immediately returned when there was a connection. The link below contains suggestions on how to troubleshoot this issue but doesn't fix it for good.
[UPDATE]
After dealing with the same problem off and on for years, I wrote a function that fixes it. The function below creates a GUI that lists all network drives that appear in your Matlab history. You can select any (or all) of the drives that you no longer have access to and it will remove those from your history. The effect was immediate for me and I no longer had to deal with the wait time. Other options in the GUI allow you to restore the history from a backup if needed. It's a pretty simple.
If you're interested (and if you're a PC user) please give it a shot and let me know if it works for you, too.
  1 commentaire
Borja Prieto
Borja Prieto le 18 Mai 2022
Hi there,
I am a PC, R2020a user, and your function/GUI worked like a charm for me!
Thanks a million!

Connectez-vous pour commenter.

Plus de réponses (6)

Jakub Krizan
Jakub Krizan le 3 Avr 2018
I have never experienced this issue in Matlab 2017b, but it started to happen since I have upgraded to Matlab 2018a. The behavior is the same as Adam Danz describes. I am using Windows 10 64bit (build 1709)
  1 commentaire
Adam Danz
Adam Danz le 13 Avr 2018
I've also upgraded to 2018a and am disappointed that this is still an issue. Often times the delay is unbearable. (Windows 7, 64bit)

Connectez-vous pour commenter.


Mary Abbott
Mary Abbott le 2 Nov 2017
Thank you for reporting this. We have been able to reproduce this on our end, and I have forwarded the details to our development team so that they can investigate it further.

Jose
Jose le 9 Sep 2018
Modifié(e) : Jose le 9 Sep 2018
Hello I am getting the same problem and I am getting crazy. In my case are not 40 seconds. Sometimes it takes 10 minutes. And turnning off the net connections dont solve anything. It happens anyway. I am desperate

Jose
Jose le 27 Sep 2018
Modifié(e) : Jose le 27 Sep 2018
Today I installed the 2018b version and the problem is still there. So, I installed it, I ran it and I typed in the command line a variable that I didn t declare before, >> r and enter and it took 1 minute almost 2 to answer: Undefined function or variable 'r'.
Someone in Matlab is taking actions? I am really fed up of it.
ElCapitan OS
  2 commentaires
William Babbitt
William Babbitt le 13 Jan 2019
Modifié(e) : William Babbitt le 13 Jan 2019
I am also experiencing this problem - Long (~ 1 minute) wait for error of undefinted variables/funtions. This started after I installed 2018b. It also may be related to running a script from our server (though the server is not in my path anymore). The problem goes away if I disconnect from the internet, but that is not a practical solution.
EDITED COMMENT
It was not my path, but my history. Running these commands solved it:
s = settings;
s.matlab.desktop.currentfolder.History.PersonalValue = {''}
Zachary Eilon
Zachary Eilon le 28 Août 2019
This solution did not fix it for me - I think the history is saved somewhere else, so as soon as one navigates to a new directory, it repopulates even having cleared it with the above code. However, selecting "Clear History" under the "Current Folder" tab of the MATLAB preferences did the trick for permanently clearing the history.

Connectez-vous pour commenter.


Jose
Jose le 15 Oct 2018
In my case is solved. I was using external hard drives (usb connected). It turns out that by accident the power supply was off and I noticed that I was not having latencies anymore. I connected them and the latencies were there again. I am happy because I am not dealing with that delays anymore but in the other hand I can not use my hard drives during my working day with Matlab which is not nice.

Ryan Santos
Ryan Santos le 30 Août 2019
Hey all,
First off, sorry for the problems everyone has been facing with the error recovery system. We added the feature in 2017b where upon encountering an unknown function or identifier, MATLAB will search through a users "current working directory" history and make suggestions based on that. Unfortunately what could sometimes happen is that some items in that history could no longer be accessable, causing the delay you're seeing here.
The workaround, as you already know, is to remove those problematic directories from your history. Though we understand that it is still frustrating and not always realistic since some directories could become innaccessable as your working and still cause an initial delay. We've been seeing more and more of this feedback from customers, so we are going to take some steps to try to alleviate this problem in a future release. We're working on it!
Thanks,
Ryan Santos

Catégories

En savoir plus sur Entering Commands dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by