Forum: Mikrocontroller und Digitale Elektronik [AVR] Suche Formel(n) zur Kissenentzerrung


von Juergen (Gast)


Lesenswert?

Hallo.

Ich suche für mein aktuelles Projekt Formeln um eine Kissenentzerrung zu 
machen.
Es handelt sich um einen Laser und 2 Galvanometer im XY-Betrieb.
Leider ist das 'Koordinatensystem', aufgrund des geringen Abstands zur 
Projektionsfläche, stark Kissen- bzw. Tonnenförmig verzerrt.

Ich wollte es erst mit einer Koordinatenliste machen, mit deren Hilfe 
dann die Werte interpoliert werden, aber da komme ich schnell auf 
mehrere tausend Werte, die ich alle einyeln ausmessen muss. Da habe ich 
nicht so den Antrieb zu. ;)

Kann mir da vielleicht jemand weiter helfen?

von Joe F. (easylife)


Lesenswert?


von Juergen (Gast)


Lesenswert?

Herzlichen Dank. Werde es sofort versuchen.

von Juergen (Gast)


Lesenswert?

Kurze Rückmeldung:
Das klappt einwandfrei mit dem im Link vorhandenm Beispielcode.

Für meine Zwecke reichen die beiden auskommentierten Zeilen. Die 4 
Zeilen mit x2 und x3 habe ioch auskommmentiert und die beiden mit x2 
reingenommen.
Falls der Link mal nicht mehr geht, hier der Code, so wie ich ihn jetzt 
drin habe:
1
// Normalize the u,v coordinates in the range [-1;+1]
2
volatile float x0 = ((2.0 * x_32) - SOURCE_XSIZE) / SOURCE_XSIZE;
3
volatile float y0 = ((2.0 * y_32) - SOURCE_YSIZE) / SOURCE_YSIZE;
4
5
// Calculate l2 norm
6
float r = x0 * x0 + y0 * y0;
7
8
// Calculate the deflated or inflated new coordinate (reverse transform)
9
//         float x1 = x0 / (1.0 - (PARSER_ALPHAX * r));
10
//         float y1 = y0 / (1.0 - (PARSER_ALPHAY * r));
11
//         float x2 = x0 / (1.0 - (PARSER_ALPHAX * ((x1 * x1) + (y1 * y1))));
12
//         float y2 = y0 / (1.0 - (PARSER_ALPHAY * ((x1 * x1) + (y1 * y1))));
13
14
// Forward transform
15
float x2 = x0 * (1.0 - PARSER_ALPHAX * r);
16
float y2 = y0 * (1.0 - PARSER_ALPHAY * r);
17
18
// De-normalize to the original range
19
float k = (x2 + 1.0) * DEST_XSIZE / 2.0;
20
float l = (y2 + 1.0) * DEST_YSIZE / 2.0;

Kurze Erklärung hierzu:
SOURCE_nSIZE und DEST_nSIZE sind wg. unterschiedlichen Größen des 
Koordinatensystems. Einmal wird in mm eingelesen und als Ausgabe habe 
ich einen 16-Bit DAC...
x_32 und y_32 sind die Werte aus der Datei als 32-Bit Variable 
umgerechnet. Zur Info: 250,0000mm (im maximum) entsprechen, der 
Einfachheit halber, 2500000.
k und l sind das Ergebnis.

Hoffe mich klar ausgedrüückt zu haben. ;)

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.