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