!7 cmodule BaseDrumFinder > DynPrintLog { new SimpleBaseDrumFinder2 finder; start { dm_requireLiveAudioFFT(); dm_vmBus_onMessage_q newAudioFrequencyImage(voidfunc(virtual BWImage img) { float[] b = bwImageColumnBrightnesses_generic(img); L ranges = finder.addFrequencyImageBrightnesses(b); int[] gaps = intRangeGaps(ranges); if (empty(gaps)) ret; sort(gaps); MultiSet ms = intArrayAsTreeMultiSet(gaps); new Best best; for (int gap : keys(ms)) best.put(gap, ms.get(gap-1)+ms.get(gap)+ms.get(gap+1)); Int bestGap = best!; if (bestGap == null) ret with print("no gaps"); double freq = audio_frequencyImageWidthPerSecond()/bestGap; printVars_str(+bestGap, +freq); }); } }