File: filtered_block_read.h

package info (click to toggle)
edfbrowser 2.12%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 4,532 kB
  • sloc: cpp: 84,441; ansic: 13,112; sh: 178; xml: 19; makefile: 13
file content (85 lines) | stat: -rw-r--r-- 2,026 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
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
/*
***************************************************************************
*
* Author: Teunis van Beelen
*
* Copyright (C) 2012 - 2024 Teunis van Beelen
*
* Email: teuniz@protonmail.com
*
***************************************************************************
*
* 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, version 3 of the License.
*
* 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/>.
*
***************************************************************************
*/


#ifndef filtered_block_read_INCLUDED
#define filtered_block_read_INCLUDED


#include <stdlib.h>
#include <stdio.h>
#include <string.h>

#include "global.h"
#include "edf_helper.h"

#include "filt/filter.h"
#include "filt/fir_filter.h"
#include "filt/ravg_filter.h"
#include "filt/spike_filter.h"
#include "filt/math_func.h"
#include "filt/plif_ecg_subtract_filter.h"
#include "filt/plif_eeg_subtract_filter.h"

#include "third_party/fidlib/fidlib.h"


#ifdef __cplusplus
extern "C" {
#endif

typedef struct
{
  FILE *inputfile;
  edfhdrblck_t *hdr;
  sigcompblck_t *signalcomp;
  int datarecord_cnt;
  int samples_per_datrec;
  int skip_filters;
  int smpl_mode;
  long long total_samples;
  long long samples_in_file;
  char *readbuf;
  double *processed_samples_buf;
  double bitvalue;
} flt_blck_rd_t;


flt_blck_rd_t * create_flt_blck_rd(sigcompblck_t *, int, int, int, int *, double **);
int run_flt_blck_rd(flt_blck_rd_t *, int);
long long get_samples_flt_blck_rd(flt_blck_rd_t *);
void free_flt_blck_rd(flt_blck_rd_t *);

#ifdef __cplusplus
} /* extern "C" */
#endif

#endif