diff options
| author | wukong <wukong@longaeva> | 2018-12-25 14:44:46 -0800 |
|---|---|---|
| committer | wukong <wukong@longaeva> | 2018-12-25 14:44:46 -0800 |
| commit | 9ac9c6f724c16a172ecb923a0360bc9a9ffc3806 (patch) | |
| tree | e076a3a7f567834ffa05daefd94b081c8dec8899 /hamming.awk | |
| parent | 7ab9ca8f57c44e812d3c782209a9e600dc513fbc (diff) | |
began merging windowing scripts;
swapped std_dev and std_err in mean and mean_avg;
Diffstat (limited to 'hamming.awk')
| -rw-r--r-- | hamming.awk | 48 |
1 files changed, 33 insertions, 15 deletions
diff --git a/hamming.awk b/hamming.awk index f7ff9f7..acfde97 100644 --- a/hamming.awk +++ b/hamming.awk @@ -2,35 +2,52 @@ ### hamming.awk
# generate a Hamming window
+# R.W. Hamming, 'Digital Filters': H = '0.23 0.54 0.23'
# https://en.wikipedia.org/wiki/Window_function provides a few values for the
# 'a0' and 'a1' parameters of the raised cosine.
-BEGIN {
- ARGV[1] ? N = ARGV[1] : N = 0
- ARGV[2] ? OFMT = "%." ARGV[2] "g" : OFMT = "%g"
+### Gaussian
+function gaussian(n) {
+ # sigma <= 0.5
+ sigma = 0.4
+ e[n] = (n)/(sigma*M)
+ return exp(-0.5*e[n]*e[n])
+}
- # window interval goes from -M to M
- M = 0.5*(N - 1)
- pi = 4*atan2(1,1)
- ### R.W. Hamming, "Digital Filters"
- # H = "0.23 0.54 0.23"
+### Hamming, raised cosine
+function hamming(n) {
+ ### optimal values for equal-ripple
+ #a0 = 0.53836
+ #a1 = 0.46164
a0 = (25.0/46.0)
a1 = (21.0/46.0)
+ return a0 + a1*cos((pi*n)/M)
+}
- ### optimal values for equal-ripple
- #a0 = 0.53836
- #a1 = 0.46164
- ### VonHann
- #a0 = 0.5
- #a1 = 0.5
+### vonHann, raised cosine
+function vonhann(n) {
+ a0 = 0.5
+ a1 = 0.5
+ return a0 + a1*cos((pi*n)/M)
+}
+
+
+BEGIN {
+
+ ARGV[1] ? N = ARGV[1] : N = 0
+ ARGV[2] ? OFMT = "%." ARGV[2] "g" : OFMT = "%g"
+
+ # window interval goes from -M to M
+ M = 0.5*(N - 1)
+ pi = 4*atan2(1,1)
for (n=-M; n<=M; n++) {
if (N > 1 && M > 0) {
- w[n] = a0 + a1*cos((pi*n)/M)
+ w[n] = hamming(n)
print n + M, w[n]/M
}
else {
@@ -39,3 +56,4 @@ BEGIN { }
}
+
|
