Windows Azure Cloud Storage ermöglicht es Ihnen bereits ab 0,10€ pro GB/Monat die Vorteile der Cloud zu nutzen.
Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   
Advanced Developers Conference     
Bücher-Shop mit Amazon (Buchkategorien)C++ : Referenzen zu C++ : C++ Builder : Visual C++ : C# : Java : Spieleprogrammierung : Systemprogrammierung Linux : Software-Entwicklung : .NET : Compilertechnik : Algorithmen & Datenstrukturen : Objektorientierung : Entwurfsmuster : UML : eXtreme Programming : Scrum : Projektmanagement : Software-Testing : Datenbanken : Tom DeMarco : Dilbert : User Friendly
C/C++ Forum :: Die Artikel ::  Grundlegende Algorithmen in der Bildverarbeitung  
Gehen Sie zu Seite Zurück  1, 2, 3, 4, 5, 6  Weiter
  Zeige alle Beiträge auf einer Seite
Auf Beitrag antworten
Autor Nachricht
deeporion
Unregistrierter




Beitrag deeporion Unregistrierter 20:44:24 05.04.2006   Titel:              Zitieren

kgilgig

zafiro schrieb:
Zitat:
make -f Makefile

= make das Makefile

Zitat:
bin/test-rotation sample.pgm out.pgm

= out.pgm is das bild was "raus kommt"

PS: natürlich musst du alles in die Konsole eingeben ;)


hmmm, dann kommt "error reading pgm image" . Dabei ist sample.pgm im richtigen Verzeichnis ... An was könnte das liegen :confused:
Rufus
Mitglied

Benutzerprofil
Anmeldungsdatum: 18.11.2005
Beiträge: 52
Beitrag Rufus Mitglied 08:21:39 13.04.2006   Titel:   Algorithmus gesucht zum Verkleinern von Bildern            Zitieren

Hallo ich habe hier mal reingeschaut und finde den Artikel super,
auch wenn ich nicht alles gelesen habe. Diese Grundlagen sind gut und wichtig, nett zusammengestellt.
Ich selbst interessiere mich für einen Algorithmus der mir Bilder verkleinert.

Aufgabe:

Ich habe ein Bild mit n-Megapixel das in einem Control dargestellt wird z.B. m*m Pixel.
Um die Performance zu steigern soll das Bild reduziert an das Control gesendet werden,
es muss doch reichen m*m Daten zu übertragen plus den Infos die das Bildformat benötigt.

Zusätzlich wäre es schön wenn die Koordinaten wieder hochgerechnet werden könnten wenn
z.B. im Control an Position x/y geklickt wurde entspricht dies ja im Originalbild anderen
Koordinaten.

Gibt es da Algorithmen ?
Wie heißt der Fachbegriff nach dem ich suchen sollte ?

_________________
joh 3,30
Vertexwahn
Mitglied

Benutzerprofil
Anmeldungsdatum: 15.03.2003
Beiträge: 2170
Beitrag Vertexwahn Mitglied 22:42:05 25.04.2006   Titel:              Zitieren

Skalierung von Rastergrafiken
http://turing.fh-landshut.de/~jamann/Skalierung%20von%20Rastergrafiken.pdf

_________________
http://home.in.tum.de/~amannj
Gregor
Moderator

Benutzerprofil
Anmeldungsdatum: 16.01.2002
Beiträge: 7442
Beitrag Gregor Moderator 18:39:46 28.04.2006   Titel:              Zitieren

Vertexwahn schrieb:
Skalierung von Rastergrafiken
http://turing.fh-landshut.de/~jamann/Skalierung%20von%20Rastergrafiken.pdf

Interessant. :)

Vielleicht noch ein Zusatz zur Verkleinerung von Bildern...

Das Problem ist da, dass im Ursprungsbild Frequenzen vorhanden sein können, die im verkleinerten Bild nicht mehr realisiert werden können. In dem PDF gibt es da ein Beispiel mit solchen Gittern, die teilweise beim Verkleinern verschwinden. Eine Variante, wie man dem aus dem Weg gehen kann, ist, mit einer passenden Tiefpassfilterung vor dem Verkleinern dafür zu sorgen, dass die Grenzfrequenz im Originalbild klein genug ist.

_________________
"The problem with quotes on the Internet is that it is hard to verify their authenticity" - Abraham Lincoln


Zuletzt bearbeitet von Gregor am 18:40:41 28.04.2006, insgesamt 1-mal bearbeitet
mariejo
Unregistrierter




Beitrag mariejo Unregistrierter 12:58:30 29.03.2007   Titel:   Ubergabe 2 dimensionales Array an Funktion uebergeben            Zitieren

Hallo,

ich habe folgendes Problem:
Ich möchte in einem 2-Dimensionales Array (momentan nur aus bestehend 0 und 1 Feldern = einem Binärbild) Seqmente finden und zusammenhängende 1er Felder mit einem gemeinsamen Label beschriften (in diesem Falle geht dann das Label von 2 bis n und wird gesetzt indem ich einfach die 1 im Feld mit dem jeweiligen Wert ueberschreibe.

Das ganze versuche ich rekursiv, habe aber bisher noch ein Problem bei der Uebergabe des Arrays (=grid[resX][resY]) an die Rekursion. (Ob der Rest so funktioniert weiss ich noch nicht, weils ichs ja noch nicht ausprobieren konnte.)
Wäre super wenn mir jemand einen Tipp geben könnte was ich falsch mache. Bin nicht so wirklich erfahren in C++ und vorallem nicht mit Rekursionen. Das macht mir diverse Gehirnverknotungen :rolleyes:

Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//******************************************************************************************
//initialisierung der Array-Grössen (momentan global)

int resX = 500;
int resY = 500;

...

//segmentierungsfunktion  
void doSegmentation(int **grid, int x, int y, int label) {

  grid[x][y] = label;
 
//gehe ueber alle 8 nachbarn des aktuellen pixels und gehe in rekursion wenn ein Pixel mit 1 belegt ist (d.h. nicht 0 und nicht schon gelabelt)
 
  for (int dy=-1; dy<=1; dy++) {
  for (int dx=-1; dx<=1; dx++) {
//TODO: pruefe hier ob Nachbar existiert oder gleich grid[x][y] ist
    if(grid[x+dx][y+dy] == 1) {
      doSegmentation(grid, x+dx, y+dy, label);
      cout<<"in recursion"<<endl;
      }
    else
    continue
;  
   }
 }
  return;  
}

......
//startpunkt der Rekursion

 int label = 2;  
//gehe ueber 2 dim array von 1 bis res-2
//wenn pixel ==1 gehe in rekursion


  for(int i=1; i<resX-1; i++) {
    for(int j=1; j<resY-1; j++){
     
      if(grid[i][j]==1) {
 doSegmentation(grid, i, j, label); //uebergabe grid an rekursion
      }
      label++;
    }
 }  
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//******************************************************************************************
//initialisierung der Array-Grössen (momentan global)

int resX = 500;
int resY = 500;

...

//segmentierungsfunktion
void doSegmentation(int **grid, int x, int y, int label) {

grid[x][y] = label;

//gehe ueber alle 8 nachbarn des aktuellen pixels und gehe in rekursion wenn ein Pixel mit 1 belegt ist (d.h. nicht 0 und nicht schon gelabelt)

for (int dy=-1; dy<=1; dy++) {
for (int dx=-1; dx<=1; dx++) {
//TODO: pruefe hier ob Nachbar existiert oder gleich grid[x][y] ist
if(grid[x+dx][y+dy] == 1) {
doSegmentation(grid, x+dx, y+dy, label);
cout<<"in recursion"<<endl;
}
else
continue
;
}
}
return;
}

......
//startpunkt der Rekursion

int label = 2;
//gehe ueber 2 dim array von 1 bis res-2
//wenn pixel ==1 gehe in rekursion


for(int i=1; i<resX-1; i++) {
for(int j=1; j<resY-1; j++){

if(grid[i][j]==1) {
doSegmentation(grid, i, j, label); //uebergabe grid an rekursion
}
label++;
}
}
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//******************************************************************************************
//initialisierung der Array-Grössen (momentan global)

int resX = 500;
int resY = 500;

...

//segmentierungsfunktion  
void doSegmentation(int **grid, int x, int y, int label) {

  grid[x][y] = label;
 
//gehe ueber alle 8 nachbarn des aktuellen pixels und gehe in rekursion wenn ein Pixel mit 1 belegt ist (d.h. nicht 0 und nicht schon gelabelt)
 
  for (int dy=-1; dy<=1; dy++) {
  for (int dx=-1; dx<=1; dx++) {
//TODO: pruefe hier ob Nachbar existiert oder gleich grid[x][y] ist
    if(grid[x+dx][y+dy] == 1) {
      doSegmentation(grid, x+dx, y+dy, label);
      cout<<"in recursion"<<endl;
      }
    else
    continue
;  
   }
 }
  return;  
}

......
//startpunkt der Rekursion

 int label = 2;  
//gehe ueber 2 dim array von 1 bis res-2
//wenn pixel ==1 gehe in rekursion


  for(int i=1; i<resX-1; i++) {
    for(int j=1; j<resY-1; j++){
     
      if(grid[i][j]==1) {
 doSegmentation(grid, i, j, label); //uebergabe grid an rekursion
      }
      label++;
    }
 }  


//******************************************************************************************
compilerfehler ist momentan folgender:
cannot convert 'int(*)[((resY-1)+1]' to 'int**' for argument '1' to 'void doSegmentation(int**,int,int,int)'

**********************************************************************

Vielen dank und viele Gruesse
marie
Sinthoras
Mitglied

Benutzerprofil
Anmeldungsdatum: 08.11.2006
Beiträge: 336
Beitrag Sinthoras Mitglied 15:04:32 14.05.2007   Titel:              Zitieren

Hm, der Link zum Beispielprojekt geht nich:
http://www.korbinian-riedhammer.de/misc/ip-suite.tar.bz2

Wo kann ich jetzt den Quellcode herbekommen?
Danke.
estartu
Moderator

Benutzerprofil
Anmeldungsdatum: 05.09.2003
Beiträge: 11494
Beitrag estartu Moderator 14:04:02 16.05.2007   Titel:              Zitieren

Sinthoras schrieb:
Hm, der Link zum Beispielprojekt geht nich:
http://www.korbinian-riedhammer.de/misc/ip-suite.tar.bz2

Wo kann ich jetzt den Quellcode herbekommen?
Danke.
Der Link ist repariert, versuch es nochmal. :)
Danke für den Hinweis.

_________________
Das c-plusplus.de-Magazin sucht Mitmacher --- Die Artikel --- meine Homepage
thimo81
Unregistrierter




Beitrag thimo81 Unregistrierter 17:25:10 05.12.2007   Titel:              Zitieren

mariejo schrieb:

//******************************************************************************************
compilerfehler ist momentan folgender:
cannot convert 'int(*)[((resY-1)+1]' to 'int**' for argument '1' to 'void doSegmentation(int**,int,int,int)'

**********************************************************************


Eine Loesung ist, einen Array von int* zu erstellen, die auf die Zeilenanfänge zeigen.

Gruesse,
Thimo
Bullseye
Unregistrierter




Beitrag Bullseye Unregistrierter 12:41:40 05.02.2008   Titel:              Zitieren

Hallo, ich suche Methoden zum Ermitteln von Greifpunkten für einen sauger!

ich möchte aus einer kste mehrere päckchen rausholen und benötige dazu einen greifpunkt!
welche möglichkeiten gibt es? ( mittelpunkt,schwerpunkt)
ich binarisiere das bild und erhalte helle wolken an den relevanten stellen und möchte nun in diese wolken greifen.

hier das bild: http://s2.directupload.net/file/d/1329/53xqil3z_jpg.htm
Hos
Unregistrierter




Beitrag Hos Unregistrierter 17:16:50 15.04.2009   Titel:   danke für die Infos            Zitieren

danke.
C/C++ Forum :: Die Artikel ::  Grundlegende Algorithmen in der Bildverarbeitung  
Gehen Sie zu Seite Zurück  1, 2, 3, 4, 5, 6  Weiter
Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können keine Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info, www.c-sar.de, www.c-plusplus.net und www.baeckmann.de enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.