File: recinxdf.c

package info (click to toggle)
eegdev 0.2-3
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 4,972 kB
  • sloc: ansic: 32,259; sh: 10,941; makefile: 247; lex: 128; yacc: 118
file content (96 lines) | stat: -rw-r--r-- 2,383 bytes parent folder | download | duplicates (6)
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
    Copyright (C) 2011  EPFL (Ecole Polytechnique Fédérale de Lausanne)
    Nicolas Bourdaud <nicolas.bourdaud@epfl.ch>

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stdint.h>
#include "acquisition.h"

static size_t nstot;
static unsigned int fs;

static
void data_cb(void* data, size_t ns, float* eeg, float *sens, int32_t *tri)
{
	size_t i, sec;
	(void)data;
	(void)eeg;
	(void)sens;
	(void)tri;

	for (i=nstot; i<nstot+ns; i++) {
		if (i % fs == 0) {
			sec = i/fs;
			printf(sec % 10 ? "." : "|");
			fflush(stdout);
		}
	}
	nstot += ns;
}

int main(int argc, char *argv[])
{
	char str[256] = {'\0'};
	const char* devstring = NULL;
	struct acq* acq;
	int opt;

	// Parse command line options
	while ((opt = getopt(argc, argv, "d:h")) != -1) {
		switch (opt) {
		case 'd':
			devstring = optarg;
			break;
		default:	/* '?' */
			fprintf(stderr, "Usage: %s [-d devstr]\n", argv[0]);
			return (opt == 'h') ? EXIT_SUCCESS : EXIT_FAILURE;
		}
	}

	// Open the connection to the data acquisition device
	if (!(acq = acq_init(devstring, data_cb, NULL)))
		return EXIT_FAILURE;
	fs = acq_get_info(acq, ACQ_FS);

	for (;;) {
		nstot = 0;
		printf("Enter a filename for recording "
		       "(Ctrl+D to exit):\n");
		if (scanf(" %255s%*1c", str) == EOF)
			break;

		// Create and initialize file for recording
		if (acq_prepare_rec(acq, str))
			continue;
		
		printf("Press ENTER to start recording\n");
		while(getchar() != '\n');
		acq_start(acq);

		printf("Press ENTER to stop recording\n");
		while(getchar() != '\n');
		// Stop file recording and close it
		acq_stop(acq);
	}
	// Close the connection to the data acquisition device
	acq_close(acq);

	return EXIT_SUCCESS;
}