File: ReceiveDataC.c

package info (click to toggle)
liblsl 1.16.2b1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 1,724 kB
  • sloc: cpp: 12,515; ansic: 666; python: 28; sh: 25; makefile: 18
file content (55 lines) | stat: -rw-r--r-- 2,069 bytes parent folder | download
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
#include <lsl_c.h>
#include <stdio.h>

/**
 * Example program that demonstrates how to resolve a specific stream on the lab network and how to
 * connect to it in order to receive data.
 */
#define NCHANS 8


int main(int argc, char *argv[]) {

	unsigned k, t;		 /* channel index */
	lsl_streaminfo info; /* the streaminfo returned by the resolve call */
	lsl_inlet inlet;	 /* a stream inlet to get samples from */
	int errcode;		 /* error code (lsl_lost_error or timeouts) */
	float cursample[NCHANS]; /* array to hold our current sample */
	double timestamp;	 /* time stamp of the current sample (in sender time) */

	/* resolve the stream of interest (result array: info, array capacity: 1 element, type shall be
	 * EEG, resolve at least 1 stream, wait forever if necessary) */
	printf("Now waiting for an EEG stream...\n");
	lsl_resolve_byprop(&info, 1, "type", "EEG", 1, LSL_FOREVER);

	/* These next two variables aren't used for anything in this example.
	 * They simply demonstrate how to use streaminfo getters. */
	lsl_channel_format_t fmt = lsl_get_channel_format(info);
	double srate = lsl_get_nominal_srate(info);

	/* make an inlet to read data from the stream (buffer max. 300 seconds of data, no preference
	 * regarding chunking, automatic recovery enabled) */
	inlet = lsl_create_inlet(info, 300, LSL_NO_PREFERENCE, 1);

	/* subscribe to the stream (automatically done by push, but a nice way of checking early on that
	 * we can connect successfully) */
	lsl_open_stream(inlet, LSL_FOREVER, &errcode);
	if (errcode != 0) return errcode;

	printf("Displaying data...\n");
	for (t = 0; t < 100000000; t++) {
		/* get the next sample form the inlet (read into cursample, 8 values, wait forever if
		 * necessary) and return the timestamp if we got something */
		timestamp = lsl_pull_sample_f(inlet, cursample, NCHANS, LSL_FOREVER, &errcode);

		/* print the data */
		printf("%.2f", timestamp);
		for (k = 0; k < 8; ++k) printf("\t%.2f", cursample[k]);
		printf("\n");
	}

	/* we never get here, but anyway */
	lsl_destroy_inlet(inlet);

	return 0;
}