1765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Author: John Van Drasek <john.r.van.drasek@intel.com>
2765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Copyright (c) 2015 Intel Corporation.
3765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang#
4765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Permission is hereby granted, free of charge, to any person obtaining
5765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# a copy of this software and associated documentation files (the
6765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# "Software"), to deal in the Software without restriction, including
7765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# without limitation the rights to use, copy, modify, merge, publish,
8765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# distribute, sublicense, and/or sell copies of the Software, and to
9765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# permit persons to whom the Software is furnished to do so, subject to
10765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# the following conditions:
11765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang#
12765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# The above copyright notice and this permission notice shall be
13765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# included in all copies or substantial portions of the Software.
14765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang#
15765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang
23765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhangimport time
24765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhangimport pyupm_mic as upmMicrophone
25765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang
26765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Attach microphone to analog port A0
27765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun ZhangmyMic = upmMicrophone.Microphone(0)
28765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun ZhangthreshContext = upmMicrophone.thresholdContext()
29765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun ZhangthreshContext.averageReading = 0
30765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun ZhangthreshContext.runningAverage = 0
31765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun ZhangthreshContext.averagedOver = 2
32765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang
33765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Infinite loop, ends when script is cancelled
34765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Repeatedly, take a sample every 2 microseconds;
35765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# find the average of 128 samples; and
36765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# print a running graph of dots as averages
37765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhangwhile(1):
38765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang    buffer = upmMicrophone.uint16Array(128)
39765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang    len = myMic.getSampledWindow(2, 128, buffer);
40765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang    if len:
41765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang        thresh = myMic.findThreshold(threshContext, 30, buffer, len)
42765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang        myMic.printGraph(threshContext)
43765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang        if(thresh):
44765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang            print "Threshold is ", thresh
45765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang
46765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhang# Delete the upmMicrophone object
47765adb95dc941c32690d6c43bc08b9d07d197fcbJianxun Zhangdel myMic
48