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

wenn mind.300 0er zwischen 2 1er, dann in eine spalte eine 1

 

muscarin

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 01.04.2010, 17:15     Titel: wenn mind.300 0er zwischen 2 1er, dann in eine spalte eine 1
  Antworten mit Zitat      
hallo zusammen,

ich habe eine matrix 1:j, bestehend aus 0 und 1


ich möchte nun in die nächste spalte eine 1 schreiben, wenn


a)zwischen der ersten 1 und zweiten 1 mind.20, max. 50 Nuller und
b)zwischen der zweiten und der dritten 1 mind. 30 max. 60 Nuller liegen

a) und b) muss gegeben sein.


weiter dann wieder zwischen der dritten und vierten 1 wieder a) zwischen der vierten und fünften wieder b) usw.
Gesplittet: 01.04.2010, 17:18 Uhr von Martin
Von Beitrag Frohe Ostern ... aus dem Forum News zum Forum


muvik
Forum-Anfänger

Forum-Anfänger


Beiträge: 17
Anmeldedatum: 27.11.07
Wohnort: Mannheim
Version: ---
     Beitrag Verfasst am: 02.04.2010, 19:38     Titel:
  Antworten mit Zitat      
Würden hier nicht ein Paar Schleifen und if-Abfragen genügen? Oder was ist die Frage?
Private Nachricht senden Benutzer-Profile anzeigen
 
muscarin

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 02.04.2010, 20:04     Titel:
  Antworten mit Zitat      
würden? bin über jeden konkreten vorschlag/hilfe/tip dankbar..

ich weiss nicht wie ich es anstellen soll, dass zwischen der ersten und der zweiten 1 in der Spalte mind. a*Nullen, höchstens aber b* Nullen liegen müssen, bzw. dann natürlich weiter, dass zwischen der zweiten und dritten 1 genau mind. c*Nullen, höchstens aber d* Nullen liegen sollen..


vielen dank für eure tips und tricks
 
Zenon
Forum-Guru

Forum-Guru


Beiträge: 292
Anmeldedatum: 20.01.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 06.04.2010, 08:59     Titel:
  Antworten mit Zitat      
Eine vielleicht nicht elegante, aber einfache Lösung wäre das:

B ist deine Matrix, ERG dein Ergebnisvektor. ERG beinhaltet dann die Anzahl der Nullen zwischen den Einsen. Alternativ kann man bei der korrekten Anzahl auch direkt irgendwo null und eins reinschreiben, wäre mir eine weitere if-Anweisung mit countZero, das solltest Du ja selbst hinkriegen.

Code:

countZero = 0;
ERG = [];
for i = 1:numel(B(1,:))
  if B(1,i) == 1
    ERG = [ERG countZero];  
    countZero = 0;
  else
    countZero = countZero + 1;
  end
end
 
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 06.04.2010, 11:40     Titel:
  Antworten mit Zitat      
Hallo,

ist zwischen Einsen immer mindestens eine Null vorhanden?
Wenn ja dann könnte man das so lösen:
Code:

A =  [1 0 0 1 0 1 0 0 0 1 0 1;
      1 0 1 0 1 0 0 0 1 0 0 1;
      1 0 0 1 0 0 1 0 1 0 0 1];
zeros_num = arrayfun(@(x){findstr(A(x,:),[0 1]) - findstr(A(x,:),[1 0])}, 1:size(A,1));
zeros_num = vertcat(zeros_num{:});


% dann muss du bloß vergleichen
% a)
a = zeros_num(:,1)>=20 & zeros_num(:,1)<=50;
% b)
b = zeros_num(:,2)>=30 & zeros_num(:,2)<=60;

erg = a & b;
 


Noch eine Frage: wie meinst du in die nächste Spalte eine Eins schreiben, wenn die Bedingung erfüllt ist?
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 06.04.2010, 14:01     Titel:
  Antworten mit Zitat      
Falls es doch solche Situationen existieren wo keine Null zw. Einsen vorhandne ist ,
dann benutze diese Version:

Code:

A =  [1 0 0 1 0 1 0 0 0 1 0 1;
      1 0 1 0 1 0 0 0 1 0 0 1;
      1 0 0 1 0 0 1 0 1 0 0 1;
      1 1 0 0 0 0 1 0 1 0 0 1;
      1 0 0 0 0 0 1 0 1 0 1 1;
      1 0 0 0 0 0 0 1 1 0 1 1;
      1 0 0 0 0 0 0 0 1 1 1 1];
zeros_num = arrayfun(@(x){...
unique([findstr(A(x,:),[0 1]),findstr(A(x,:),[1 1])]) - ...
unique([findstr(A(x,:),[1 0]),findstr(A(x,:),[1 1])])}, 1:size(A,1));
zeros_num = vertcat(zeros_num{:})
%
% dann muss du bloß vergleichen, für alle regeln
% a)
a = all(zeros_num(:,1:2:end)>=20 & zeros_num(:,1:2:end)<=50, 2);
% b)
b = all(zeros_num(:,2:2:end)>=30 & zeros_num(:,2:2:end)<=60, 2);

erg = a & b
 
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.