-
Notifications
You must be signed in to change notification settings - Fork 1
/
analyseintervals.praat
executable file
·184 lines (165 loc) · 5.35 KB
/
analyseintervals.praat
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
#praat script
script_name$ = "analyse_intervals.praat"
#author Daniel Hirst
#email daniel.hirst@lpl.univ-aix.fr
version$ = "[2009:01:29]"
date$ = date$()
#purpose Analyse a folder of Sound files and a folder of TextGrid files
# for each interval on selected tier calculate
# - duration, mean pitch, intensity, f1, f2 f3
#output to Info window
#define parameters used in the script
form analyse intervals
word subject sub7
word vowelp 1
sentence Sound_folder /Users/zhiyangao/Desktop/englishFiles/phrases/askher/
sentence TextGrid_folder /Users/zhiyangao/Desktop/englishFiles/phrases/askher/
word Analysis_tier phones
positive Time_step 0.01
boolean automatic_max_min yes
natural Min_pitch 50
natural Max_pitch 700
natural Number_of_formants 5
natural Maximum_formant 5500
positive Window_length 0.025
positive Pre_emphasis 50
word Undefined_value NA
endform
clearinfo
printline 'tab$'extract'tab$'label'tab$'subject'tab$'vp'tab$'duration'tab$'pitch'tab$'intensity
...'tab$'F1'tab$'F2'tab$'F3'tab$'f1mid'tab$'f2mid'tab$'f3mid'tab$'stim'tab$'MaxInt'tab$'f0max'tab$'f0min'tab$'f0range
#Read in list of sound files
myStrings = Create Strings as file list... sounds 'sound_folder$'/*.wav
nSounds = Get number of strings
item = 0
#check if TextGrid file exists for each sound and call treatment
for iSound from 1 to nSounds
select myStrings
sound_name$ = Get string... iSound
textGrid_name$ = sound_name$ - "wav" + "TextGrid"
sound$ = sound_folder$ + "/" + sound_name$
textGrid$ = textGrid_folder$ + "/" + textGrid_name$
if fileReadable(textGrid$)
call treatment
endif
endfor
#subroutine treatment
procedure treatment
Read from file... 'sound$'
mySound = selected("Sound")
name$ = selected$("Sound")
Read from file... 'textGrid$'
myTextGrid = selected("TextGrid")
nTiers = Get number of tiers
#find number of analysis tier
tier = 0
for iTier from 1 to nTiers
tier_name$ = Get tier name... iTier
if tier_name$ = analysis_tier$
tier = iTier
endif
endfor
if tier
#create analysis objects
select mySound
myPitch = To Pitch... time_step min_pitch max_pitch
if automatic_max_min
q25 = Get quantile... 0 0 0.25 Hertz
q75 = Get quantile... 0 0 0.75 Hertz
min_pitch = 0.75*q25
max_pitch = 1.5*q75
Remove
select mySound
myPitch = To Pitch... time_step min_pitch max_pitch
#printline # min_pitch 'min_pitch:0'; max_pitch 'max_pitch:0'
endif
select mySound
myIntensity = To Intensity... min_pitch time_step Yes
select mySound
myFormant = To Formant (burg)... time_step number_of_formants maximum_formant window_length pre_emphasis
#Get time values of beginning and end of each interval for treatment
select myTextGrid
nIntervals = Get number of intervals... tier
for iInterval from 1 to nIntervals
select myTextGrid
label$ = Get label of interval... tier iInterval
#type$ = Get label of interval... 4 iInterval
##senPosition$ = Get label of interval... 4 iInterval
##tones$ = Get label of interval... 5 iInterval
#stim$ = Get label of interval... 1 iInterval
subject$ = subject$
vp$ = vowelp$
start = Get starting point... tier iInterval
end = Get end point... tier iInterval
mid = (end-start)/2
if label$ != "" and label$ != "_" and label$ != "#"
#calculate parameters for each non empty interval
item = item+1
#duration
duration = 1000*(end - start)
call set_undefined duration
duration$ = value$
#pitch
select myPitch
meanPitch = Get mean... start end Hertz
call set_undefined meanPitch
meanPitch$ = value$
maxTime= Get time of maximum... start end Hertz Parabolic
f0max= Get maximum... start end Hertz Parabolic
f0min= Get minimum... start end Hertz Parabolic
f0range=f0max-f0min
#f0minPre = Get minimum... start maxTime Hertz Parabolic
#f0minPost = Get minimum... maxTime end Hertz Parabolic
#intensity
select myIntensity
meanIntensity = Get mean... start end energy
max_int = Get maximum... start end Parabolic
call set_undefined meanIntensity
meanIntensity$ = value$
#formants
select myFormant
f1 = Get mean... 1 start end Hertz
f1_mean = Get value at time... 1 mid Hertz Linear
call set_undefined f1
f1$ = value$
f2 = Get mean... 2 start end Hertz
f2_mean = Get value at time... 2 mid Hertz Linear
call set_undefined f2
f2$ = value$
f3 = Get mean... 3 start end Hertz
f3_mean = Get value at time... 3 mid Hertz Linear
call set_undefined f3
f3$ = value$
#print out results
printline 'item''tab$''name$''tab$''label$''tab$''subject$''tab$''vp$''tab$''duration$'
...'tab$''meanPitch$''tab$''meanIntensity$''tab$''f1$'
...'tab$''f2$''tab$''f3$''tab$''f1_mean''tab$''f2_mean''tab$''f3_mean''tab$''stim$''tab$''max_int''tab$''f0max''tab$''f0min''tab$''f0range'
endif
endfor
#Remove analysis files
select myPitch
plus myIntensity
plus myFormant
Remove
else
#print warning if TextGrid has no analysis tier
printline ###TextGrid 'name$' has no tier 'analysis_tier$'
endif
#Remove Sound and TextGrid
select mySound
plus myTextGrid
Remove
endproc
#Remove file list
select myStrings
Remove
procedure set_undefined value
if value = undefined
value$ = undefined_value$
else
value$ = "'value:0'"
endif
endproc
#version history
#[2009:01:29] added automatic max min for pitch
#[2007:10:30] first version calculates duration pitch intensity & formants on intervals