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

Wieso macht mir 'image registration' keine Translation?

 

Berti
Forum-Anfänger

Forum-Anfänger


Beiträge: 12
Anmeldedatum: 19.12.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 11.02.2011, 10:55     Titel: Wieso macht mir 'image registration' keine Translation?
  Antworten mit Zitat      
Hi Leute,

ich habe folgendes problem: ich will Bild 'D' über cp2tform so an Bild 'A1' angleichen, dass das Bild 'registered' identisch zu 'A1' ist.

Nonreflective similarity beinhaltet nach meinem wissen die funktionen der Skalierung (klappt), Rotation(klappt) und auch Translation (klappt nicht!).

-> hat einer von euch eine idee, warum die translation nicht klappt?

hier mal mein Code:

Code:

   % Erstes Bild A1
    A = uint8(zeros(200,200));
    A(81:120, 81:120) = 255;
    A(91:110, 151:170) = 255;
    A1 = A;
    A1(100:103, 101) = 120;
    A1(100:103, 160) = 120;
        figure, imshow(A1)
                       
    B = imrotate(A,90);
    B(100:103,101) = 120;
    B(40:43, 101) = 120;
        figure, imshow(B);
       
   % das zweite Bild ist D: es ist rotatorisch und translatorisch verschoben zu A1
    D = uint8(zeros(200,200));
    D(:,1:100) = B(:,51:150);
        figure, imshow(D);
 
        cpselect(D,A1);      
       
    mytform = cp2tform(input_points, base_points,'nonreflective similarity');
    registered = imtransform(D, mytform);
        figure, imshow(registered)    
 
[/b]
Private Nachricht senden Benutzer-Profile anzeigen


Sco
Forum-Meister

Forum-Meister


Beiträge: 699
Anmeldedatum: 15.08.10
Wohnort: Dundee
Version: 2008a, 2010a
     Beitrag Verfasst am: 11.02.2011, 13:38     Titel:
  Antworten mit Zitat      
Hallo,

mit deinem Versuch nimmt Matlab an das beide Bilder im selben "raumlichen" Koordinatensystem sind. Damit deine Translation klappt musst du den Code folgendermassen abaendern:
Code:

% Erstes Bild A1
A = uint8(zeros(200,200));
A(81:120, 81:120) = 255;
A(91:110, 151:170) = 255;
A1 = A;
A1(100:103, 101) = 120;
A1(100:103, 160) = 120;
figure, imshow(A1)
                       
B = imrotate(A,90);
B(100:103,101) = 120;
B(40:43, 101) = 120;
figure, imshow(B);
       
% das zweite Bild ist D: es ist rotatorisch und translatorisch verschoben zu A1
D = uint8(zeros(200,200));
D(:,1:100) = B(:,51:150);
figure, imshow(D);

[input_points, base_points] = cpselect(A1,D,'Wait',true);
tform = cp2tform(input_points,base_points,'nonreflective similarity');
registered = imtransform(A1,tform,'bicubic','XData',[1 size(A1,2)],'YData',[1 size(A1,1)]);
figure, imshow(registered)
 


Ansonsten kanns du dir auch dieses Beispiel anschauen, was noch andere Moeglichkeiten erklaert: http://www.mathworks.com/help/toolbox/images/f12-23518.html

MFG

Sco
Private Nachricht senden Benutzer-Profile anzeigen
 
Berti
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 12
Anmeldedatum: 19.12.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 11.02.2011, 15:48     Titel:
  Antworten mit Zitat      
Tausend Dank, Sco!
...jetzt kann ich beruhigt ins WE geh'n Very Happy

Ein Fehler hat sich in deinem code aber dennoch eingeschlichen:

Code:

[input_points, base_points] = cpselect(D, A1,'Wait',true);
tform = cp2tform(input_points,base_points,'nonreflective similarity');
registered = imtransform(D,tform,'bicubic','XData',[1 size(D,2)],'YData',[1 size(D,1)]);
figure, imshow(registered)
 


sprich, überall, wo A1 steht, muss D hin und umgekehrt.


Grüße
Private Nachricht senden Benutzer-Profile anzeigen
 
Sco
Forum-Meister

Forum-Meister


Beiträge: 699
Anmeldedatum: 15.08.10
Wohnort: Dundee
Version: 2008a, 2010a
     Beitrag Verfasst am: 11.02.2011, 16:17     Titel:
  Antworten mit Zitat      
Hallo,

Zitat:

Ein Fehler hat sich in deinem code aber dennoch eingeschlichen:
...
sprich, überall, wo A1 steht, muss D hin und umgekehrt.


Das hatte ich 1 min nach dem Posten meines Beitrages auch schon gemerkt und auch sofort editiert. Du hasst aber wohl die Zeit zwischen dem Aufrufen meines Posts und der Erstellung deines Posts nicht einmal die Homepage aktualisiert Smile.

MFG

Sco
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.