Commit a965774eac951b7198a8a751015801ec166db286

Authored by aklotz
1 parent f2387923
Exists in master

Fix bugs C code

gui/tp_audine_elec/main.cpp
1 1 /*
2   - * Fichier pour travaux pratiques
3   - * Universite de Toulouse
  2 + * Title: Code C de pilotage de camera Audine avec Raspberry
  3 + * Author: A. Klotz. Universite de Toulouse
4 4 *
5   - * --- rappel des bits de donnes du port parallele pour Audine
6   - * ordre : 87654321
7   - * bit 1 : horloge V1
8   - * bit 2 : horloge V2
9   - * bit 3 : horloge H1
10   - * bit 4 : horloge R (reset)
11   - * bit 5 : horloge CL (clamp)
12   - * bit 6 : horloge Start Convert (CAN)
13   - * bit 7 : horloge Select Byte (CAN)
14   - * bit 8 : horloge Select Nibble
  5 + * To install the GPIO access library BCM2835 for Ubuntu:
  6 + * Some infos: http://www.airspayce.com/mikem/bcm2835/
  7 + * Install procedure: https://raspberry-projects.com/pi/programming-in-c/io-pins/bcm2835-by-mike-mccauley
  8 + * Do not forget to change the rights of the driver:
  9 + * $ sudo chown user:user /dev/gpiomem
  10 + * $ sudo crontab -e and add the line @reboot chown user:user /dev/gpiomem
15 11 *
  12 + * Code::Blocks configuration to use the GPIO library BCM2835 in C code:
  13 + * Menu Settings -> Compiler...
  14 + * Tab "Linker Settings", "Link libraries" [Add] bcm2835 [OK]
16 15 */
17 16  
18   - // https://raspberry-projects.com/pi/programming-in-c/io-pins/bcm2835-by-mike-mccauley
19   -// http://www.airspayce.com/mikem/bcm2835/
20   -// sudo chown user:user /dev/gpiomem
21   -// Dans CodeBlocks, Menu Settings -> Compiler Settings, tab Other compiler options: Add -lbcm2835
22   -// spyder : https://stackoverflow.com/questions/72114520/error-when-starting-spyder-on-ubuntu-22-04
23   -
24 17 #include <stdlib.h>
25 18 #include <stdio.h>
26 19 #include <string.h>
... ... @@ -46,8 +39,8 @@
46 39 #define LEVEL_HIGH 0
47 40 #define LEVEL_LOW 1
48 41  
  42 +// -- Structure of camera informations
49 43 struct camprop {
50   - /* --- parametres standards, ne pas changer --- */
51 44 char msg[2048];
52 45 float exptime;
53 46 int binx, biny;
... ... @@ -62,30 +55,22 @@ struct camprop {
62 55 int nb_deadendphotoy;
63 56 int nb_photox;
64 57 int nb_photoy;
65   - unsigned short *p;
66   - /* --- pour l'amplificateur des Kaf-401 --- */
67   - int ampliindex;
68   - int nbampliclean;
69   - timespec t1;
70   - timespec t2;
  58 + float *p;
71 59 };
72 60  
73   -int cmdAudineAcqNormal(struct camprop *cam);
74   -
  61 +// -- Declaration of functions
  62 +int tp_acquisition_fullframe(struct camprop *cam);
75 63 static int tp_fast_vidage(struct camprop *cam);
76   -static int tp_read_win(struct camprop *cam);
77   -static void libcam_sleep(float us);
78   -
  64 +static int tp_read_frame(struct camprop *cam);
  65 +static void tp_sleep(float us);
79 66 static int tp_zi_zh(struct camprop *cam);
80 67 static int tp_read_pel_fast2(struct camprop *cam);
81   -
82 68 int tp_fast_line(struct camprop *cam);
83 69  
84   -
85 70 /*
86   - * Attente en micro-secondes.
  71 + * Wait in micro-seconds.
87 72 */
88   -void libcam_sleep(float us)
  73 +void tp_sleep(float us)
89 74 {
90 75 int i,n;
91 76 n = (int)(us*10);
... ... @@ -94,32 +79,32 @@ void libcam_sleep(float us)
94 79 }
95 80 }
96 81  
97   -int cmdAudineAcqNormal(struct camprop *cam)
  82 +int tp_acquisition_fullframe(struct camprop *cam)
98 83 {
99 84 int i;
100   - int nb_vidages = 1;
  85 + int nb_vidages = 2;
101 86 /* =============================================== */
102 87 /* === Etape de rincage de la matrice CCD === */
103 88 /* =============================================== */
104   - /* vidage de la matrice */
  89 + // Vidage de la matrice
105 90 for (i = 0; i < nb_vidages; i++) {
106 91 tp_fast_vidage(cam);
107 92 }
108 93 /* =============================================== */
109 94 /* === Integration de l'image (attente) === */
110 95 /* =============================================== */
111   - /* Delais du temps de pose (en micro-secondes) */
112   - libcam_sleep((int) (1e6 * cam->exptime));
  96 + // Delais du temps de pose (en micro-secondes)
  97 + tp_sleep((int) (1e6 * cam->exptime));
113 98 /* =============================================== */
114 99 /* === Etape de lecture de la matrice CCD === */
115 100 /* =============================================== */
116   - /* Parametres de dimensions pour allouer le pointeur image */
  101 + // Parametres de dimensions pour allouer le pointeur image
117 102 cam->w = cam->nb_photox / cam->binx;
118 103 cam->h = cam->nb_photoy / cam->biny;
119   - /* Allocation memoire du pointeur image */
120   - cam->p = (unsigned short *) calloc(cam->w*cam->h, sizeof(unsigned short));
121   - /* Lecture et numรฏยฟยฝrisation de l'image vers le pointeur p */
122   - tp_read_win(cam);
  104 + // Allocation memoire du pointeur image
  105 + cam->p = (float *) calloc(cam->w*cam->h, sizeof(float));
  106 + // Lecture et numรฏยฟยฝrisation de l'image vers le pointeur p
  107 + tp_read_frame(cam);
123 108 return 0;
124 109 }
125 110  
... ... @@ -133,25 +118,25 @@ int tp_fast_vidage(struct camprop *cam)
133 118 int i, j;
134 119 int imax, jmax, decaligne;
135 120  
136   - /* Nombre total de photocellules dans le registre horizontal. */
  121 + // -- Nombre total de photocellules dans le registre horizontal.
137 122 imax = cam->nb_photox + cam->nb_deadbeginphotox + cam->nb_deadendphotox;
138 123  
139   - /* Nombre total de photocellules dans une colonne de la matrice. */
  124 + // -- Nombre total de photocellules dans une colonne de la matrice.
140 125 jmax = cam->nb_photoy + cam->nb_deadbeginphotoy + cam->nb_deadendphotoy;
141 126  
142   - /* Nombre de lignes decalees a chaque boucle sur l'axe vertical. */
  127 + // -- Nombre de lignes decalees a chaque boucle sur l'axe vertical.
143 128 decaligne = 20;
144 129  
145   - /* Nombre total de boucles sur l'axe vertical. */
  130 + // -- Nombre total de boucles sur l'axe vertical.
146 131 jmax = (int) ceil (1. * jmax / decaligne) ;
147 132  
148   - /* Boucle sur les paquets de lignes. */
  133 + // -- Boucle sur les paquets de lignes.
149 134 for (j = 0; j < jmax; j++) {
150   - /* Decalage d'un paquet de 20 lignes. */
  135 + // -- Decalage d'un paquet de 'decaligne' lignes.
151 136 for (i = 0; i < decaligne; i++) {
152 137 tp_zi_zh(cam);
153 138 }
154   - /* Lecture du registre horizontal sans reset */
  139 + // -- Lecture du registre horizontal sans reset
155 140 for (i = 0; i < imax; i++) {
156 141 tp_read_pel_fast2(cam);
157 142 }
... ... @@ -171,38 +156,38 @@ int tp_zi_zh(struct camprop *cam)
171 156 float tphiV=2.0;
172 157 float tphiHS=1.0;
173 158 // ---
174   - bcm2835_gpio_write (PHI_V1, LEVEL_HIGH) ;
175   - libcam_sleep(tphiV);
176   - bcm2835_gpio_write (PHI_V1, LEVEL_LOW) ;
177   - bcm2835_gpio_write (PHI_V2, LEVEL_HIGH) ;
178   - libcam_sleep(tphiV);
179   - bcm2835_gpio_write (PHI_V1, LEVEL_HIGH) ;
180   - bcm2835_gpio_write (PHI_V2, LEVEL_LOW) ;
181   - libcam_sleep(tphiV);
182   - bcm2835_gpio_write (PHI_V1, LEVEL_LOW) ;
183   - libcam_sleep(tphiHS);
  159 + bcm2835_gpio_write (PHI_V1, LEVEL_HIGH);
  160 + tp_sleep(tphiV);
  161 + bcm2835_gpio_write (PHI_V1, LEVEL_LOW);
  162 + bcm2835_gpio_write (PHI_V2, LEVEL_HIGH);
  163 + tp_sleep(tphiV);
  164 + bcm2835_gpio_write (PHI_V1, LEVEL_HIGH);
  165 + bcm2835_gpio_write (PHI_V2, LEVEL_LOW);
  166 + tp_sleep(tphiV);
  167 + bcm2835_gpio_write (PHI_V1, LEVEL_LOW);
  168 + tp_sleep(tphiHS);
184 169 return 0;
185 170 }
186 171  
187 172 /*
188 173 tp_read_pel_fast2(struct camprop *cam) --
189   - Lecture rapide d'un pixel : decalage du registre horizontal
  174 + Lecture rapide d'une photocellule : decalage du registre horizontal
190 175 sans Reset, mais sans lecture du CAN,
191 176 */
192 177 int tp_read_pel_fast2(struct camprop *cam)
193 178 {
194 179 float tphiPIX=0.25;
195 180 // ---
196   - bcm2835_gpio_write (PHI_H1, LEVEL_LOW) ;
197   - libcam_sleep(tphiPIX);
198   - bcm2835_gpio_write (PHI_H1, LEVEL_HIGH) ;
199   - libcam_sleep(tphiPIX);
  181 + bcm2835_gpio_write (PHI_H1, LEVEL_LOW);
  182 + tp_sleep(tphiPIX);
  183 + bcm2835_gpio_write (PHI_H1, LEVEL_HIGH);
  184 + tp_sleep(tphiPIX);
200 185 return 0;
201 186 }
202 187  
203 188 /*
204 189 tp_read_pel_fast(struct camprop *cam) --
205   - Lecture rapide d'un pixel : decalage du registre horizontal
  190 + Lecture rapide d'une photocellule : decalage du registre horizontal
206 191 avec Reset, mais sans lecture du CAN,
207 192 */
208 193 int tp_read_pel_fast(struct camprop *cam)
... ... @@ -210,25 +195,25 @@ int tp_read_pel_fast(struct camprop *cam)
210 195 float tphiPIX=0.25;
211 196 float tphiR=0.020;
212 197 // ---
213   - bcm2835_gpio_write (PHI_R, LEVEL_HIGH) ;
214   - libcam_sleep(tphiR);
215   - bcm2835_gpio_write (PHI_R, LEVEL_LOW) ;
216   - libcam_sleep(tphiR);
217   - bcm2835_gpio_write (PHI_H1, LEVEL_LOW) ;
218   - libcam_sleep(tphiPIX);
219   - bcm2835_gpio_write (PHI_H1, LEVEL_HIGH) ;
220   - libcam_sleep(tphiPIX);
  198 + bcm2835_gpio_write (PHI_R, LEVEL_HIGH);
  199 + tp_sleep(tphiR);
  200 + bcm2835_gpio_write (PHI_R, LEVEL_LOW);
  201 + tp_sleep(tphiR);
  202 + bcm2835_gpio_write (PHI_H1, LEVEL_LOW);
  203 + tp_sleep(tphiPIX);
  204 + bcm2835_gpio_write (PHI_H1, LEVEL_HIGH);
  205 + tp_sleep(tphiPIX);
221 206 return 0;
222 207 }
223 208  
224 209 /*
225 210 tp_fast_line_() --
226   - Lecture rapide du registre horizontal, avec la fonction read_pel_fast.
  211 + Lecture rapide du registre horizontal, avec la fonction tp_read_pel_fast.
227 212 */
228 213 int tp_fast_line(struct camprop *cam)
229 214 {
230 215 int i, imax;
231   - /* Nombre total de photocellules dans le registre horizontal. */
  216 + // Nombre total de photocellules dans le registre horizontal.
232 217 imax = cam->nb_photox + cam->nb_deadbeginphotox + cam->nb_deadendphotox;
233 218 for (i = 0; i < imax; i++) {
234 219 tp_read_pel_fast(cam);
... ... @@ -236,7 +221,7 @@ int tp_fast_line(struct camprop *cam)
236 221 return 0;
237 222 }
238 223  
239   -int tp_read_win(struct camprop *cam)
  224 +int tp_read_frame(struct camprop *cam)
240 225 {
241 226  
242 227 int i, j;
... ... @@ -244,42 +229,42 @@ int tp_read_win(struct camprop *cam)
244 229 int imax, jmax;
245 230 int cx1, cx2, cy1;
246 231 unsigned short buffer[2048];
247   - int x;
  232 + unsigned short x;
248 233  
249   - /* dimensions de l'image a digitaliser */
  234 + // -- Dimensions de l'image a digitaliser
250 235 imax = cam->w;
251 236 jmax = cam->h;
252   - /* nombre de colonnes de debut a ne pas digitaliser */
  237 + // -- Nombre de photocellules de debut de ligne a ne pas digitaliser
253 238 cx1 = cam->nb_deadbeginphotox;
254   - /* nombre de colonnes de fin a ne pas digitaliser */
  239 + // -- Nombre de photocellules de fin de ligne a ne pas digitaliser
255 240 cx2 = cam->nb_deadendphotox;
256   - /* nombre de lignes de debut a ne pas digitaliser */
  241 + // -- Nombre de lignes de debut a ne pas digitaliser
257 242 cy1 = cam->nb_deadbeginphotoy;
258 243  
259   - /* On supprime les cy1 premieres lignes */
  244 + // -- On supprime les cy1 premieres lignes
260 245 for (i = 0; i < cy1; i++) {
261 246 tp_zi_zh(cam);
262 247 }
263 248  
264   - /* On nettoie le registre horizontal */
  249 + // -- On nettoie le registre horizontal
265 250 for (i = 0; i < 1; i++) {
266 251 tp_fast_line(cam);
267 252 }
268 253  
269   - /* boucle sur l'horloge verticale (transfert) */
  254 + // -- Boucle sur le transfert vertical
270 255 for (i = 0; i < jmax; i++) {
271 256  
272   - /* boucle de binning vertical */
  257 + // -- Boucle de binning vertical
273 258 for (k = 0; k < cam->biny; k++) {
274 259 tp_zi_zh(cam);
275 260 }
276 261  
277   - /* On retire les cx1 premiers pixels avec reset */
  262 + // -- On retire les cx1 premieres photocellules avec reset
278 263 for (j = 0; j < cx1; j++) {
279 264 tp_read_pel_fast(cam);
280 265 }
281 266  
282   - /* boucle sur l'horloge horizontale (registre de sortie) */
  267 + // -- Boucle sur le transfert horizontal
283 268 for (j = 0; j < imax; j++) {
284 269 float tphiR=0.020;
285 270 float tRef1=4.0;
... ... @@ -287,100 +272,105 @@ int tp_read_win(struct camprop *cam)
287 272 float tRef3=1.0;
288 273 float tphiPIX=0.25;
289 274 float tVid1=4.0;
290   - // palier de reset
291   - bcm2835_gpio_write (PHI_R, LEVEL_HIGH) ;
  275 + float tVid2=1.0;
  276 + float tSel=1.0;
  277 +
  278 + // -- Palier de reset
292 279 bcm2835_gpio_write (PHI_H1, LEVEL_LOW) ;
293   - libcam_sleep(tphiR);
  280 + bcm2835_gpio_write (PHI_R, LEVEL_HIGH) ;
  281 + tp_sleep(tphiR);
294 282 bcm2835_gpio_write (PHI_R, LEVEL_LOW) ;
295   - libcam_sleep(tphiR);
296   - // palier de reference
297   - libcam_sleep(tRef1);
  283 +
  284 + // -- Palier de reference
  285 + tp_sleep(tRef1);
298 286 bcm2835_gpio_write (PHI_CL, LEVEL_HIGH) ;
299   - libcam_sleep(tRef2);
  287 + tp_sleep(tRef2);
300 288 bcm2835_gpio_write (PHI_CL, LEVEL_LOW) ;
301   - libcam_sleep(tRef3);
  289 + tp_sleep(tRef3);
302 290  
303   - /* boucle de binning horizontal */
  291 + // -- Boucle de binning horizontal
304 292 for (l = 0; l < cam->binx; l++) {
305 293 bcm2835_gpio_write (PHI_H1, LEVEL_LOW) ;
306   - libcam_sleep(tphiPIX);
  294 + tp_sleep(tphiPIX);
307 295 bcm2835_gpio_write (PHI_H1, LEVEL_HIGH) ;
308   - libcam_sleep(tphiPIX);
  296 + tp_sleep(tphiPIX);
309 297 }
310 298  
311   - // palier video
312   - libcam_sleep(tVid1);
  299 + // -- Palier video
  300 + tp_sleep(tVid1);
313 301 bcm2835_gpio_write (PHI_SC, LEVEL_HIGH) ;
  302 + tp_sleep(tVid2);
314 303  
315   - // -- recupere le nibble _ _ _ _ _ _ _ _ _ _ _ _ 3 2 1 0
  304 + // -- Recupere le nibble _ _ _ _ _ _ _ _ _ _ _ _ 3 2 1 0
316 305 // SB = Select Byte <---- SB=1 ----> <---- SB=0 ---->
317 306 // SN = Select Nibble <SN=1 > <SN=0 > <SN=1 > <SN=0 >
318 307 bcm2835_gpio_write (PHI_SB, LEVEL_LOW) ;
319 308 bcm2835_gpio_write (PHI_SN, LEVEL_LOW) ;
320   - x = (int)bcm2835_gpio_lev(BIT_0);
321   - x += (int)bcm2835_gpio_lev(BIT_1) << 1;
322   - x += (int)bcm2835_gpio_lev(BIT_2) << 2;
323   - x += (int)bcm2835_gpio_lev(BIT_3) << 3;
  309 + tp_sleep(tSel);
  310 + x = (unsigned short)bcm2835_gpio_lev(BIT_0) ;
  311 + x += (unsigned short)bcm2835_gpio_lev(BIT_1) << 1;
  312 + x += (unsigned short)bcm2835_gpio_lev(BIT_2) << 2;
  313 + x += (unsigned short)bcm2835_gpio_lev(BIT_3) << 3;
324 314  
325   - // -- recupere le nibble _ _ _ _ _ _ _ _ 3 2 1 0 _ _ _ _
  315 + // -- Recupere le nibble _ _ _ _ _ _ _ _ 3 2 1 0 _ _ _ _
326 316 bcm2835_gpio_write (PHI_SB, LEVEL_LOW) ;
327 317 bcm2835_gpio_write (PHI_SN, LEVEL_HIGH) ;
328   - x += (int)bcm2835_gpio_lev(BIT_0) << 4;
329   - x += (int)bcm2835_gpio_lev(BIT_1) << 5;
330   - x += (int)bcm2835_gpio_lev(BIT_2) << 6;
331   - x += (int)bcm2835_gpio_lev(BIT_3) << 7;
  318 + tp_sleep(tSel);
  319 + x += (unsigned short)bcm2835_gpio_lev(BIT_0) << 4;
  320 + x += (unsigned short)bcm2835_gpio_lev(BIT_1) << 5;
  321 + x += (unsigned short)bcm2835_gpio_lev(BIT_2) << 6;
  322 + x += (unsigned short)bcm2835_gpio_lev(BIT_3) << 7;
332 323  
333   - // -- recupere le nibble _ _ _ _ 3 2 1 0 _ _ _ _ _ _ _ _
  324 + // -- Recupere le nibble _ _ _ _ 3 2 1 0 _ _ _ _ _ _ _ _
334 325 bcm2835_gpio_write (PHI_SB, LEVEL_HIGH) ;
335 326 bcm2835_gpio_write (PHI_SN, LEVEL_LOW) ;
336   - x += (int)bcm2835_gpio_lev(BIT_0) << 8;
337   - x += (int)bcm2835_gpio_lev(BIT_1) << 9;
338   - x += (int)bcm2835_gpio_lev(BIT_2) << 10;
339   - x += (int)bcm2835_gpio_lev(BIT_3) << 11;
  327 + tp_sleep(tSel);
  328 + x += (unsigned short)bcm2835_gpio_lev(BIT_0) << 8;
  329 + x += (unsigned short)bcm2835_gpio_lev(BIT_1) << 9;
  330 + x += (unsigned short)bcm2835_gpio_lev(BIT_2) << 10;
  331 + x += (unsigned short)bcm2835_gpio_lev(BIT_3) << 11;
340 332  
341   - // -- recupere le nibble 3 2 1 0 _ _ _ _ _ _ _ _ _ _ _ _
  333 + // -- Recupere le nibble 3 2 1 0 _ _ _ _ _ _ _ _ _ _ _ _
342 334 bcm2835_gpio_write (PHI_SB, LEVEL_HIGH) ;
343 335 bcm2835_gpio_write (PHI_SN, LEVEL_HIGH) ;
344   - x += (int)bcm2835_gpio_lev(BIT_0) << 12;
345   - x += (int)bcm2835_gpio_lev(BIT_1) << 13;
346   - x += (int)bcm2835_gpio_lev(BIT_2) << 14;
347   - x += (int)bcm2835_gpio_lev(BIT_3) << 15;
  336 + tp_sleep(tSel);
  337 + x += (unsigned short)bcm2835_gpio_lev(BIT_0) << 12;
  338 + x += (unsigned short)bcm2835_gpio_lev(BIT_1) << 13;
  339 + x += (unsigned short)bcm2835_gpio_lev(BIT_2) << 14;
  340 + x += (unsigned short)bcm2835_gpio_lev(BIT_3) << 15;
348 341  
349   - // -- remises au niveaux bas
  342 + // -- Remises aux niveaux bas
350 343 bcm2835_gpio_write (PHI_SC, LEVEL_LOW) ;
351 344 bcm2835_gpio_write (PHI_SB, LEVEL_LOW) ;
352 345 bcm2835_gpio_write (PHI_SN, LEVEL_LOW) ;
353 346  
354   - if (x > 32767) {
355   - x = 32767;
356   - }
357   - /* Stockage dans un buffer dans la meme page mem */
358   - buffer[j] = (unsigned short) x;
  347 + // -- Stockage du pixel dans un buffer de ligne
  348 + buffer[j] = x;
359 349  
360 350 }
361 351  
362   - /* On retire cx2 pixels a la fin */
  352 + // -- On retire cx2 photocellules a la fin
363 353 for (j = 0; j < cx2; j++) {
364 354 tp_read_pel_fast(cam);
365 355 }
366 356  
367   - /* On transfere le tableau vers la matrice image */
  357 + // -- On transfere le buffer de ligne vers la matrice image
368 358 if (i != 0) {
369   - cam->p[(i - 1) * imax] = buffer[0];
  359 + cam->p[(i - 1) * imax] = (float)buffer[0];
370 360 }
371 361 for (j = 1; j < imax; j++) {
372   - cam->p[(i + 1) * imax - j] = buffer[j];
  362 + cam->p[(i + 1) * imax - j] = (float)buffer[j];
373 363 }
374 364  
375 365 }
376 366 return 0;
377 367 }
378 368  
379   -void mc_savefits(struct camprop *cam, char *filename)
  369 +void tp_savefits(struct camprop *cam, char *filename)
380 370 {
381 371 FILE *f;
382 372 char line[1024],car;
383   - float value0;
  373 + short value0;
384 374 char *cars0;
385 375 int k,k0;
386 376 long one= 1;
... ... @@ -396,9 +386,9 @@ void mc_savefits(struct camprop *cam, char *filename)
396 386 fwrite(line,80,sizeof(char),f);
397 387 sprintf(line,"NAXIS2 = %3d / length of data axis 2 ",cam->h);
398 388 fwrite(line,80,sizeof(char),f);
399   - strcpy(line,"BZERO = 32768 / uint16 ");
  389 + strcpy(line,"BZERO = 32768 / uint16 32768 ");
400 390 fwrite(line,80,sizeof(char),f);
401   - strcpy(line,"BSCALE = 1 / uint16 ");
  391 + strcpy(line,"BSCALE = 1 / uint16 1 ");
402 392 fwrite(line,80,sizeof(char),f);
403 393 k0=9;
404 394 strcpy(line,"END ");
... ... @@ -407,25 +397,24 @@ void mc_savefits(struct camprop *cam, char *filename)
407 397 for (k=k0;k<=36;k++) {
408 398 fwrite(line,80,sizeof(char),f);
409 399 }
410   - /* byte order test */
  400 + // -- Byte order test
411 401 if (!(*((char *)(&one)))) {
412 402 big_endian=1;
413 403 } else {
414 404 big_endian=0;
415 405 }
416   - /* write data */
  406 + // -- Write data
417 407 for (k=0;k<cam->h*cam->w;k++) {
418   - value0=cam->p[k]; // 32=4*8bits
  408 + value0 = cam->p[k]-32768;
419 409 if (big_endian==0) {
420 410 cars0=(char*)&value0;
421 411 car=cars0[0];
422 412 cars0[0]=cars0[1];
423 413 cars0[1]=car;
424 414 }
425   - fwrite(&value0,1,sizeof(unsigned short),f);
  415 + fwrite(&value0,1,sizeof(short),f);
426 416 }
427 417 int n= (cam->h*cam->w) % 2880 -1;
428   - //printf("big_endian=%d n=%d",big_endian, n);
429 418 value0=(float)0.;
430 419 for (k=0;k<n;k++) {
431 420 if (big_endian==0) {
... ... @@ -434,22 +423,24 @@ void mc_savefits(struct camprop *cam, char *filename)
434 423 cars0[0]=cars0[1];
435 424 cars0[1]=car;
436 425 }
437   - fwrite(&value0,1,sizeof(unsigned short),f);
  426 + fwrite(&value0,1,sizeof(short),f);
438 427 }
439 428 fclose(f);
440 429 }
441 430  
  431 +// -- This is the start point of the program
442 432 int main(int argc, char* argv[])
443 433 {
444 434  
445   - // decode la ligne de commandes. Exemple : tp_ccd.exe 0.5 1
  435 + // -- Decode la ligne de commandes. Exemple : tp_ccd.exe full_frame 0.5 1
446 436 char method[1024];
447 437 float exptime = 0.5;
448 438 int binning = 1;
  439 + strcpy(method,"full_frame");
449 440 if(argc < 3)
450 441 {
451 442 printf("ERR 1 : Not enough command line parameters\n: method exptime binningn");
452   - //exit(1);
  443 + return 1;
453 444 } else {
454 445 strcpy(method,argv[1]);
455 446 exptime = atof(argv[2]);
... ... @@ -457,8 +448,8 @@ int main(int argc, char* argv[])
457 448 }
458 449 printf("ERR 0 : %s %f %d\n", method, exptime, binning);
459 450  
  451 + // -- Initialise la structure des donnees de la camera
460 452 struct camprop cam;
461   - // === initialise la structure des donnees de la camera
462 453 strcpy(cam.msg,"");
463 454 cam.exptime=exptime; // sec
464 455 cam.binx=binning;
... ... @@ -477,15 +468,14 @@ int main(int argc, char* argv[])
477 468 cam.nb_deadbeginphotoy=4;
478 469 cam.nb_deadendphotoy=4;
479 470 cam.p=NULL;
480   - /* --- pour l'amplificateur des Kaf-401 --- */
481   - cam.ampliindex=0;
482   - cam.nbampliclean=0;
483   - // === initialise le GPIO
  471 +
  472 + // -- Initialise le GPIO
484 473 if (!bcm2835_init()) {
485 474 printf("Probleme bcm2835_init");
486 475 return 1;
487 476 }
488   - // Set the pin to be an output
  477 +
  478 + // -- Set the pin to be an output
489 479 bcm2835_gpio_fsel(PHI_V1, BCM2835_GPIO_FSEL_OUTP);
490 480 bcm2835_gpio_fsel(PHI_V2, BCM2835_GPIO_FSEL_OUTP);
491 481 bcm2835_gpio_fsel(PHI_H1, BCM2835_GPIO_FSEL_OUTP);
... ... @@ -495,12 +485,14 @@ int main(int argc, char* argv[])
495 485 bcm2835_gpio_fsel(PHI_SC, BCM2835_GPIO_FSEL_OUTP);
496 486 bcm2835_gpio_fsel(PHI_SN, BCM2835_GPIO_FSEL_OUTP);
497 487 bcm2835_gpio_fsel(DELAY, BCM2835_GPIO_FSEL_OUTP); // special delay us
498   - // Set the pin to be an input
  488 +
  489 + // -- Set the pin to be an input
499 490 bcm2835_gpio_fsel(BIT_0, BCM2835_GPIO_FSEL_INPT);
500 491 bcm2835_gpio_fsel(BIT_1, BCM2835_GPIO_FSEL_INPT);
501 492 bcm2835_gpio_fsel(BIT_2, BCM2835_GPIO_FSEL_INPT);
502 493 bcm2835_gpio_fsel(BIT_3, BCM2835_GPIO_FSEL_INPT);
503   - // Set default values for outputs
  494 +
  495 + // -- Set default values for outputs
504 496 bcm2835_gpio_write (PHI_V1, LEVEL_LOW) ;
505 497 bcm2835_gpio_write (PHI_V2, LEVEL_LOW) ;
506 498 bcm2835_gpio_write (PHI_H1, LEVEL_HIGH) ;
... ... @@ -510,14 +502,12 @@ int main(int argc, char* argv[])
510 502 bcm2835_gpio_write (PHI_SC, LEVEL_LOW) ;
511 503 bcm2835_gpio_write (PHI_SN, LEVEL_LOW) ;
512 504  
  505 + // -- Select the method to apply
513 506 if (strcmp(method, "full_frame")==0) {
514   - printf("=== init OK\n");
515   - cmdAudineAcqNormal(&cam);
516   - printf("=== acq OK\n");
  507 + tp_acquisition_fullframe(&cam);
517 508 char filename[1024];
518 509 strcpy(filename,"/home/user/Documents/image.fit");
519   - mc_savefits(&cam, filename);
520   -
  510 + tp_savefits(&cam, filename);
521 511 } else if (strcmp(method, "zi_zh")==0) {
522 512 for (int i = 0; i <1; i++) {
523 513 tp_zi_zh(&cam);
... ... @@ -551,7 +541,7 @@ int main(int argc, char* argv[])
551 541 bcm2835_gpio_write (PHI_SB, LEVEL_HIGH) ;
552 542 bcm2835_gpio_write (PHI_SC, LEVEL_HIGH) ;
553 543 bcm2835_gpio_write (PHI_SN, LEVEL_HIGH) ;
554   - libcam_sleep(tphiV);
  544 + tp_sleep(tphiV);
555 545 bcm2835_gpio_write (PHI_V1, LEVEL_LOW) ;
556 546 bcm2835_gpio_write (PHI_V2, LEVEL_LOW) ;
557 547 bcm2835_gpio_write (PHI_H1, LEVEL_LOW) ;
... ... @@ -560,8 +550,27 @@ int main(int argc, char* argv[])
560 550 bcm2835_gpio_write (PHI_SB, LEVEL_LOW) ;
561 551 bcm2835_gpio_write (PHI_SC, LEVEL_LOW) ;
562 552 bcm2835_gpio_write (PHI_SN, LEVEL_LOW) ;
563   - libcam_sleep(tphiHS);
  553 + tp_sleep(tphiHS);
564 554 }
  555 + } else if (strcmp(method, "set_255")==0) {
  556 + bcm2835_gpio_write (PHI_V1, LEVEL_HIGH) ;
  557 + bcm2835_gpio_write (PHI_V2, LEVEL_HIGH) ;
  558 + bcm2835_gpio_write (PHI_H1, LEVEL_HIGH) ;
  559 + bcm2835_gpio_write (PHI_R, LEVEL_HIGH) ;
  560 + bcm2835_gpio_write (PHI_CL, LEVEL_HIGH) ;
  561 + bcm2835_gpio_write (PHI_SB, LEVEL_HIGH) ;
  562 + bcm2835_gpio_write (PHI_SC, LEVEL_HIGH) ;
  563 + bcm2835_gpio_write (PHI_SN, LEVEL_HIGH) ;
  564 + tp_sleep(5e6);
  565 + } else if (strcmp(method, "set_0")==0) {
  566 + bcm2835_gpio_write (PHI_V1, LEVEL_LOW) ;
  567 + bcm2835_gpio_write (PHI_V2, LEVEL_LOW) ;
  568 + bcm2835_gpio_write (PHI_H1, LEVEL_LOW) ;
  569 + bcm2835_gpio_write (PHI_R, LEVEL_LOW) ;
  570 + bcm2835_gpio_write (PHI_CL, LEVEL_LOW) ;
  571 + bcm2835_gpio_write (PHI_SB, LEVEL_LOW) ;
  572 + bcm2835_gpio_write (PHI_SC, LEVEL_LOW) ;
  573 + bcm2835_gpio_write (PHI_SN, LEVEL_LOW) ;
565 574 }
566 575 printf("=== Termine\n");
567 576 return 0;
... ...
gui/tp_audine_elec/tp_audine_elec.py
... ... @@ -55,7 +55,7 @@ if __name__ == &quot;__main__&quot;:
55 55 print(exc)
56 56  
57 57 # --- Global variable to select the method
58   - methods = ["full_frame", "zi_zh", "fast_line", "read_pel_fast", "read_pel_fast2", "fast_vidage", "square_signal"]
  58 + methods = ["full_frame", "zi_zh", "fast_line", "read_pel_fast", "read_pel_fast2", "fast_vidage", "square_signal", "set_0", "set_255"]
59 59  
60 60 # --- Global variable to define info messages
61 61 infos = {}
... ...