WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Problem mit "load" unter R2012a

 

caprice82
Forum-Anfänger

Forum-Anfänger


Beiträge: 12
Anmeldedatum: 25.07.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 05.09.2012, 23:33     Titel: Problem mit "load" unter R2012a
  Antworten mit Zitat      
Hallo Forum,
ich habe eine Menge programmiert und stelle fest, dass seit R2012a nichts mehr läuft. Es liegt daran, dass txt files nicht mehr richtig gelesen werden. Ich schreibe unter R2011b

Code:
dataset=load(dataset);
var1=dataset(:,1);
var2=dataset(:,2);
var3=dataset(:,3);


und erhalte dataset <20x3 double> und kann die drei Spalten einfach auslesen.

Unter R2012a erhalte ich mit demselben code dataset <1x60 double> und kann die Spalten nicht einfach auslesen.

Das ist sicher nicht sehr dramatisch, aber doch ärgerlich. Weiss jemand woran das liegt und wie ich es beheben kann ohne meine codes alle zu ändern?
Private Nachricht senden Benutzer-Profile anzeigen


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.484
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 05.09.2012, 23:43     Titel:
  Antworten mit Zitat      
Hallo,

und in welchem Format liegt die Textdatei vor? Eine Beispieldatei würde helfen.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
caprice82
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 12
Anmeldedatum: 25.07.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 06.09.2012, 00:04     Titel:
  Antworten mit Zitat      
Harald hat Folgendes geschrieben:
Hallo,

und in welchem Format liegt die Textdatei vor? Eine Beispieldatei würde helfen.

Grüße,
Harald


Hallo Harald
Es hängt eine Datei an. Im gegebenen code fehlen die Anführungsstriche: dataset=load('dataset.txt'), sorry. Ach ja: Ich nutze Macs mit OS10.6.8. Am Ende liegt es wieder daran ...
Beste Grüße,
Christian

dataset.txt
 Beschreibung:

Download
 Dateiname:  dataset.txt
 Dateigröße:  714 Bytes
 Heruntergeladen:  960 mal
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.484
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 06.09.2012, 09:52     Titel:
  Antworten mit Zitat      
Hallo,

dies ist leider (auch unter Windows) ein Bug:
http://www.mathworks.com/support/bugreports/794792

Unter anderem steht dort, dass das Problem in der in Kürze erscheinenden Version 2012b behoben sein wird.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 06.09.2012, 11:09     Titel:
  Antworten mit Zitat      
Hallo Harald,

Zitat:
http://www.mathworks.com/support/bugreports/794792

Wow! Das nenne ich mal einen peinlichen Bug. Das Zeilen-Enden-Drama zieht sich ja immerhin schon seit DOS 1.0-Zeiten auf dem IBM-PC (1981!) hin. In diesen 33 Jahren sind tausende Programme an den \r\n-Tücken gescheitert. TMW sollte dringend solche Standard-Probleme in den Unit-Tests prüfen, bevor eine Version released wird. Andernfalls wird der Eindruck provoziert, Matlab würde gar nicht mit Unit-Tests geprüft...

Was ich von einem Bug-Fix per Upgrade halte, habe ich in diesem Forum wiederholt betont. Neue Versionen enthalten offensichtlich(!) immer auch neue Bugs. Wenn man ein größeres Programm für ernsthafte Zwecke benutzt, ist ein Matlab-Version-Upgrade also keine Methode, um die Gesamt-Qualität zu steigern oder auch nur zu erhalten.
Zudem kann sich ja nicht jeder Kunde ein Upgrade leisten. Die Workarounds sind zwar meistens sehr hilfreich (hier ein großes Lob!), aber wenn man z.B. ein Programm veröffentlicht, muss man bisweilen einen Rattenschwanz mit Ausnahmen abfangen, weil Release A bei diesen Befehl scheitert, B bei einem anderen, etc...

Ich bitte den Technischen Support, den Entwicklern kräftig auf die Füße zu treten. Schwächliche oder fehlende Unit-Tests kosten die Benutzer und den Support viel Zeit und Geld.

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
caprice82
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 12
Anmeldedatum: 25.07.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 06.09.2012, 11:11     Titel:
  Antworten mit Zitat      
Hallo Harald,
vielen Dank für die Information!!! Blöd, dass es da keinen patch für gibt. Ich habe jetzt den R2012b prerelease installiert und es funktioniert tatsächlich. Das offizielle R2012b release steht aber auch in 2 Wochen oder so an (wenn man warten kann).
Viele Grüße,
Christian
Private Nachricht senden Benutzer-Profile anzeigen
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 06.09.2012, 13:53     Titel:
  Antworten mit Zitat      
Hallo caprice82,
Zitat:
Blöd, dass es da keinen patch für gibt.

Ich hatte so sehr versucht um das Wort "blöd" herum zu kommen... Du hast aber ganz recht. Leider scheint Patchs einzelner Funktionen nicht ohne weiteres Möglich zu sein.

Man kann natürlich auch in den Files \r durch \n ersetzen, also CHAR(13) durch CHAR(10):
Code:
fid = fopen(FileName, 'r');
Data = fread(fid, Inf, '*char');
fclose(fid);
Data = strrep(Data, char([13, 10]), char(10));  % DOS -> Unix
Data = strrep(Data, char(13), char(10));  % MacOS9 -> Unix

fid = fopen(FileName, 'w');
Data = fwrite(fid, Data, 'char');
fclose(fid);


Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
Verschoben: 06.09.2012, 13:57 Uhr von denny
Von Programmierung nach Bugs MATLAB
 
Andreas Goser
Forum-Meister

Forum-Meister


Beiträge: 3.654
Anmeldedatum: 04.12.08
Wohnort: Ismaning
Version: 1.0
     Beitrag Verfasst am: 06.09.2012, 15:49     Titel:
  Antworten mit Zitat      
Ich habe diesen Fall überprüft. Seit Januar 2012 sind nur 5 Kunden mit diesem Problem an MathWorks herangetreten. Auch wenn hier jemand gesagt hat, dass auch andere Betriebssysteme betroffen sind, waren es interessanterweise nur Mac user.

Der Bug wurde zügig gefixt und es gibt einen Workaround. Ob peinlich oder nicht, aber es kommt auf die Häufigkeit an und wie schwerwiegend ein Bug ist, ob ein Patch (als Teil eines Service Packs) geliefert wird. Von einem R2012a SP1 habe ich noch nicht gehört. Jeder Kunde, der sich an den Support wendet und nach einem Patch fragt kann sich darauf verlassen, dass der Aufwand von den Entwicklern geprüft wird. Technisch gibt es da extrem grosse Unterschiede.

Zu dem inwiefern der Support den Entwicklern auf die Füsse steigen soll - ich habe gesehen, dass ein Manager aus der Entwicklung schon von selbst aktiv geworden ist. Mehr kann ich öffentlich nicht sagen.

Andreas
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 06.09.2012, 21:14     Titel:
  Antworten mit Zitat      
Hallo Andreas,

Vielen Dank für die Antwort. Wie immer ist das Feedback von einem Insider sehr wertvoll. Ich kann

MAT-files im ASCII-Format mit CHAR(13) als Zeilentrenner wurde sicherlich unter MacOS-9 geschrieben. Dann finden sie wohl eher ihren Weg auf einen MacOS-X-Rechner, statt auf einen Windows- und Linux-PC.

Zitat:
Der Bug wurde zügig gefixt und es gibt einen Workaround.

Nun, "zügig" heißt offenbar nachdem das Release von TMW getestet wurde und die Pre-Release-Tester auch nichts fanden.
Mit "peinlich" meine ich, dass nun schon Generationen von Programmierern über das gleiche Problem stolpern. Der dämliche Streit um die Normierung der ASCII-Codes hat schon vor 30 Jahren die Programmierer zur Weißglut getrieben und das setzt sich bei Unicode nahtlos fort.
Programmierfehler sind verständlich und nicht zu verhindern. Aber Steuerzeichen bei ASCII-Text sind absolute Standard-Probleme und müssen unbedingt umfassend getestet werden, genau wie numerische Funktionen auf Inputs von leeren Arrays, Inf, NaN, imaginären Zahlen, SINGLEs, Integer-Typen etc. getestet werden müssen. Offenbar wurde hier punktuell geschlampt.

(Dear programmer of LOAD and/or its tests: Sorry! I never forget that I have programmed even more silly bugs! I have implemented the solution of "A*x = 0" by "x = -A" for a scientific publication about numerical methods. Because this was written in C and not in Matlab, the program did even run, but not successfully of course.)

In Matlab tauchen immer wieder Bugs auf, die in meinen Augen durch übliche Unit-Tests hätten auffallen müssen. Selbstverständlich lässt sich TMW nicht in die Karten schauen, wenn es um die internen Test-Methoden geht. Ich bin mir sicher, dass TMW sehr viele Bugs findet und bereinigt, bevor eine Version veröffentlicht wird. Nur rutschen immer wieder Bugs durch, die trivial aussehen. Ich erinnere mich an "A'\b;", das in 2009b (ohne SP1!) im Gegensatz zu "transpose(A)\b" falsche Ergebnbisse lieferte. Ein paar weitere wurden in CSSM: 26735 diskutiert. Die erwähnten Bugs waren "schwerwiegend" und traten "häufig" auf. Und TMW hat deshalb auch ein SP1 für 2009b herausgegeben. Das fand ich sehr gut, aber natürlich auch sehr notwendig.
Auch dass jetzt ein Manager der Entwicklungsabteilung aktiv wird, zeugt vom hohen Engagement und effizienter Qualitäts-Kontrolle. Ebenso, dass der Technische Support in diesem Forum so aktiv ist und offenbar bestens dokumentiert wird, wieviele Kunden welche Probleme hatten.

Mir ist klar, dass Servicepacks für TMW enorm teuer sind. Auf der anderen Seite bekomme ich fast täglich Micro-Patchs von Microsoft, Oracle und Adobe, wobei ich für Java und den Acrobat-Reader nicht einmal etwas bezahlt habe. Die Workarounds in Matlab's Bug-List sind bereits sehr gut. Zusammen mit einem automatischen Download wären dies oft bereits Micro-Patchs und viele Probleme könnten so bei den Nutzern so abgefangen werden. Gibt es keine Möglichkeit die SPs so handlich zu machen, dass auch 10 Stück davon pro Halbjahr machbar und finanzierbar werden?

Während ich die Patchs der genannten Firmen sehr nützlich finde, ist deren Support schlecht. Was nützen tägliche Updates, wenn z.B. Standard-Funktionen von Windows wie SHFileOperation nicht gefixed werden und undokumentiert ihr Verhalten ändern? Man kann hunderte Emails an Microsoft senden und sicher sein, dass gar nichts passiert. Ich weiß genau, warum ich meine Programme mit Matlab erstelle, und nicht mit MSVC.

Dass sich nur 5 User beschwert haben, heißt zwar, dass sich (Anzahl der Matlab-User) minus 5 nicht beschwert haben. Mit einem ordentlichen Unit-Test hätten sich 0 User beschwert.

Gruß, Jan

[EDITED, Jan, 07-Sep-2012 08:00, leicht gekürzt]

Zuletzt bearbeitet von Jan S am 07.09.2012, 08:18, insgesamt 2-mal bearbeitet
Private Nachricht senden Benutzer-Profile anzeigen
 
caprice82
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 12
Anmeldedatum: 25.07.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 06.09.2012, 22:57     Titel:
  Antworten mit Zitat      
Vielen Dank für die Beiträge und die background infos hinsichtlich der bugs. Die Sache ist sicherlich komplexer als sie scheint. Es ist allerdings schwierig zu beurteilen, wie es sein kann, dass ein offenbar plattformübergreifender bug in so einem Basisbefehl wie "load" nicht von viel mehr usern angezeigt wurde. Klar, es gibt workarounds, aber dennoch, es arbeiten doch sicher viele Leute mit dem Kommando.
Nichtsdestoweniger erscheint der TMW-support sehr hilfsbereit und engagiert, was man von anderen Softwareunternehmen nicht immer so behaupten kann.

Beste Grüße,
Christian
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

Du kannst Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.
Du kannst Dateien in diesem Forum posten
Du kannst Dateien in diesem Forum herunterladen
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2024 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.