File: parse-to-h.py

package info (click to toggle)
pd-earplug 0.3.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,064 kB
  • sloc: ansic: 1,688; python: 35; makefile: 19
file content (53 lines) | stat: -rwxr-xr-x 1,238 bytes parent folder | download | duplicates (2)
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
#! /usr/bin/env python3
#
# convert KEMAR head-related impulse response measurement data set to C header
# file 3 dimensional array
#
# usage: parse-to-h.py [DATAFILE]
#
# Chikashi Miyama 2021
# adapted from original parse-to-h.pl Perl script by Hans-Christoph Steiner 2009
#

import sys

datafile = "earplug_data.txt"
if len(sys.argv) > 1:
    datafile = sys.argv[1]

src = open(datafile, "r")
dest = open("earplug_data.h", "w")

lines = src.readlines()

dest.write("/* default impulse responses as embedded binary data */\n")
dest.write("t_float earplug_impulses[368][2][128] = {\n")
for line in lines:
    if line[0] == "*":
        continue
    if line == '\n':
        continue
    else:
        irs = line.split(' ')
        irs.pop()

        count = 0
        leftSamples = []
        rightSamples = []
        for sample in irs:
            if count % 2 == 0:
                leftSamples.append(sample)
            else:
                rightSamples.append(sample)
            count += 1

        dest.write('{\n{')
        dest.write(', '.join(leftSamples))
        dest.write('},\n')

        dest.write('{')
        dest.write(', '.join(rightSamples))
        dest.write('}\n},\n')
dest.write('};\n')
src.close()
dest.close()