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

Probleme mit Variablen im Workspace

 

MikeB

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 13:55     Titel: Probleme mit Variablen im Workspace
  Antworten mit Zitat      
Hallo,

ich habe ein Prog mit einigen Funktionen geschrieben, ähnlich diesem kleinen Beispiel:

function main
x = 2;
y = 1;
[z,k] = mon(x,y)
b = my(x,y)

function [z,k] = mon(x,y)
z = x+y;
k=x*3;

function [b] = my(x,y)
b = x*y;


Das funktioniert auch wunderbar bei diesem kleinen Beispiel, nur bei meinem umfangreicheren Programm bleiben die vorher im Hauptprogramm definierten Variablen nicht im Workspace und so funktioniert bei Zugriff auf eine Funktion B z.B. der Zugriff auf ein Blockschaltbild nicht mehr, da ihm die Werte fehlen, die eigentlich schon im Hauptprog definiert sein sollten.

Hat jemand einen Tipp für mich?

Mfg Mike


Vito
Forum-Guru

Forum-Guru


Beiträge: 315
Anmeldedatum: 02.11.09
Wohnort: Stuttgart
Version: ---
     Beitrag Verfasst am: 07.05.2010, 14:46     Titel:
  Antworten mit Zitat      
Hi,

du kannst dir die Variablen speicher mit
Code:

save name variable
 

und mit
Code:

wieder aufrufen lassen oder im Workspace holen Wink .

Gruß,
Vito
Private Nachricht senden Benutzer-Profile anzeigen
 
quant82
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 97
Anmeldedatum: 30.04.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 14:46     Titel:
  Antworten mit Zitat      
hmmm ich versteh nicht ganz...

also variablen die du an eine funktion übergibst funktionieren nicht oder der rückgabewert ?

könntest du das problem ein wenig besser fassen
Private Nachricht senden Benutzer-Profile anzeigen
 
MikeB

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 15:03     Titel:
  Antworten mit Zitat      
Also mein Prog sieht so aus:
Geschweifte Klammern nur für bessere übersicht drin.
Code:

{
clear all
close all
global Tg dt f sa;
set(gca,'LineWidth',1)

%% Modelleigenschaften
%% Massen
m_R=10;      %[kg]
m_A=40;   %[kg]
m_M=50;   %[kg]

%% Steifigkeiten
k_R=20e3;   %[N/m]
k_A=310e3;   %[N/m]
k_M=3020e3;   %[N/m]

%% Dämpfung
c_R=0.51e3;   %[Ns/m]
c_A=13.4e3;   %[Ns/m]
c_M=0;      %[Ns/m]

%% Berechnung der Modell-Eigenschaften
M=[m_R 0 0; 0 m_A 0; 0 0 m_M];                              % Massenmatrix
S=[(k_A + k_R) -k_A 0; -k_A (k_M + k_A) -k_M; 0 -k_M k_M];  % Steifigkeitsmatrix
D=[(c_A + c_R) -c_A 0; -c_A (c_M + c_A) -c_M; 0 -c_M c_M];  % Dämpfungsmatrix
Hyp=[zeros(3) eye(3); -inv(M)*S -inv(M)*D];                 % Hypermatrix
eig(Hyp);       % Eigenkreisfrequenzen omega
eig(Hyp)/(2*pi) % Eigenfrequenzen f


%% Eingabewert
sa1=0.9;      % Erste Wegamplidute in m


fvector = [0.5:0.5:15]; % Frequenzden von 0.5 bis 15 Hz in 0.5 Hz Schritten
na=4;                   % Schwingungen, die ausgewertet werden; Auswertesützstellen: na*p
ns=na*2;            % Anzahl der Gesamtschwingungen pro Auswertefrequenz
p=2^12;               % Anzahl der Stützstellen pro Schwingung 2^12
                        % Untere Grenzfrequenz f=1Hz bei na=4 und p=2^4

%% Diagramm-Aufrufe                        
figure(1)   % Öffnen Graphikfenster 1
xlim([fvector(1) fvector(end)]);ylim([0  5]); grid on; hold on;
figure(2)   % Öffnen Graphikfenster 2
xlim([fvector(1) fvector(end)]);ylim([-360 360]); grid on; hold on;

% Aufruf Funktion dyn_val_1_MP mit Sinusgenerierung und Modellstart
    if not(sa1==0)
       [fr,c_dynr,loss_angler]=dynamo(sa1,fvector,p,na,ns); % Berechnung mit FFT
       
     end
 }    
   

Ab hier beginnt die Funktion dynamo
Code:

function[fr,c_dynr,loss_angler]=dynamo(s,fvector,p,na,ns)

{
global Tg dt f sa;

sa = s;
% calculated values**************************************************************
    i=1;
    N=length(fvector);
    while i<N+1,
        f = fvector(i);
        T = 1/f;                   %Periodendauer
        dt = T/p;                  %Abtastrate
        Tg = T*ns;                %Geamtsimulationszeit
   
        %Aufruf der Simulink modell************************************************
           
           sim('Modelblockschaltbild.mdl');  
                                   
              %prepare data**************************************************************
                 w=hann(na*p);
                 y_out(:,1)=y_out(:,1).*w(:);    %Hanning-Fenster
                 y_out(:,2)=y_out(:,2).*w(:);  
                 %figure(10);plot(t_out,y_out(:,1)*1E6,t_out,y_out(:,2));  
              %FFT Transformation*********************************************************
                 
                   
                   
                    %result vector biuld up************************************************
                   
            i=i+1;
           
    end%*****************************************************************************************
}    
 
 
Vito
Forum-Guru

Forum-Guru


Beiträge: 315
Anmeldedatum: 02.11.09
Wohnort: Stuttgart
Version: ---
     Beitrag Verfasst am: 07.05.2010, 15:06     Titel:
  Antworten mit Zitat      
Hi,

und welche Parameter brauchst du fürs Dynamoteil?

Gruß,
Vito
Private Nachricht senden Benutzer-Profile anzeigen
 
MikeB

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 15:08     Titel:
  Antworten mit Zitat      
Der Fehler ist dann:
??? Error using ==>
>dynamo at xxx..
Error evaluating expression 'Tg' for
'Stop time' specified in the
Configuration Parameters dialog for
block diagram 'Modellblockschaltbild':
Undefined function or variable 'Tg'.

Wenn ich Tg in die Funktion reinschreibe fehlen aber alle in main eigegebenen Massen und sontiges.
Es steht nix mehr im Workspace anscheinend...
 
MikeB

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 15:11     Titel:
  Antworten mit Zitat      
Ich brauch alle oberen Parameter in main (Massen usw.) für den Aufruf des Blockschaltbildes in dynamo. Und ich wollte die Parameter oben stehen haben und nicht in dynamo.

Das komische ist, wenn ich eine m_File namens Dynamo.m erstelle dann hat er zugriff auch die massen etc. Nur wenn ich alles an main unten dranhäng geht nix mehr. Ich kapiers echt nicht
 
Vito
Forum-Guru

Forum-Guru


Beiträge: 315
Anmeldedatum: 02.11.09
Wohnort: Stuttgart
Version: ---
     Beitrag Verfasst am: 07.05.2010, 16:10     Titel:
  Antworten mit Zitat      
Hi,

gib mal folgenden Code ein:
Code:

clear all
close all
global Tg dt f sa;
set(gca,'LineWidth',1)

%% Modelleigenschaften
%% Massen
m_R=10;      %[kg]
m_A=40;   %[kg]
m_M=50;   %[kg]

%% Steifigkeiten
k_R=20e3;   %[N/m]
k_A=310e3;   %[N/m]
k_M=3020e3;   %[N/m]

%% Dämpfung
c_R=0.51e3;   %[Ns/m]
c_A=13.4e3;   %[Ns/m]
c_M=0;      %[Ns/m]

%% Berechnung der Modell-Eigenschaften
M=[m_R 0 0; 0 m_A 0; 0 0 m_M];                              % Massenmatrix
S=[(k_A + k_R) -k_A 0; -k_A (k_M + k_A) -k_M; 0 -k_M k_M];  % Steifigkeitsmatrix
D=[(c_A + c_R) -c_A 0; -c_A (c_M + c_A) -c_M; 0 -c_M c_M];  % Dämpfungsmatrix
Hyp=[zeros(3) eye(3); -inv(M)*S -inv(M)*D];                 % Hypermatrix
eig(Hyp);       % Eigenkreisfrequenzen omega
eig(Hyp)/(2*pi) % Eigenfrequenzen f


%% Eingabewert
sa1=0.9;      % Erste Wegamplidute in m


fvector = [0.5:0.5:15]; % Frequenzden von 0.5 bis 15 Hz in 0.5 Hz Schritten
na=4;                   % Schwingungen, die ausgewertet werden; Auswertesützstellen: na*p
ns=na*2;            % Anzahl der Gesamtschwingungen pro Auswertefrequenz
p=2^12;               % Anzahl der Stützstellen pro Schwingung 2^12
                        % Untere Grenzfrequenz f=1Hz bei na=4 und p=2^4

                       
 % dynamo_file;
%% Diagramm-Aufrufe                        
figure(1)   % Öffnen Graphikfenster 1
xlim([fvector(1) fvector(end)]);ylim([0  5]); grid on; hold on;
figure(2)   % Öffnen Graphikfenster 2
xlim([fvector(1) fvector(end)]);ylim([-360 360]); grid on; hold on;

% Aufruf Funktion dyn_val_1_MP mit Sinusgenerierung und Modellstart
    if (sa1~=0)
        % function[fr,c_dynr,loss_angler]=dynamo(sa1,fvector,p,na,ns)
        % global Tg dt f sa;

        sa = sa1;
        % calculated values**************************************************************
            i=1;
            N=length(fvector);
            while i<N+1,
            f = fvector(i);
            T = 1/f;                   %Periodendauer
            dt = T/p;                  %Abtastrate
            Tg = T*ns;                %Geamtsimulationszeit
   
            %Aufruf der Simulink modell************************************************
           
            sim('Modelblockschaltbild.mdl');  
                                   
              %prepare data**************************************************************
                 w=hann(na*p);
                 y_out(:,1)=y_out(:,1).*w(:);    %Hanning-Fenster
                 y_out(:,2)=y_out(:,2).*w(:);  
                 %figure(10);plot(t_out,y_out(:,1)*1E6,t_out,y_out(:,2));  
              %FFT Transformation*********************************************************
                 
                   
                   
                    %result vector biuld up************************************************
            i=i+1;
           
            end% *****************************************************************************************
    end
 
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 - 2025 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.