Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender-addons.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'power_sequencer/operators/audiosync/cross_correlation.py')
-rw-r--r--power_sequencer/operators/audiosync/cross_correlation.py33
1 files changed, 33 insertions, 0 deletions
diff --git a/power_sequencer/operators/audiosync/cross_correlation.py b/power_sequencer/operators/audiosync/cross_correlation.py
new file mode 100644
index 00000000..b18ab35e
--- /dev/null
+++ b/power_sequencer/operators/audiosync/cross_correlation.py
@@ -0,0 +1,33 @@
+#
+# Copyright (C) 2016-2019 by Nathan Lovato, Daniel Oakey, Razvan Radulescu, and contributors
+#
+# This file is part of Power Sequencer.
+#
+# Power Sequencer is free software: you can redistribute it and/or modify it under the terms of the
+# GNU General Public License as published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# Power Sequencer is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+# without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with Power Sequencer. If
+# not, see <https://www.gnu.org/licenses/>.
+#
+import numpy as np
+
+
+def cross_correlation(mfcc1, mfcc2, nframes):
+ n1, mdim1 = mfcc1.shape
+ # n2, mdim2 = mfcc2.shape
+
+ n = n1 - nframes + 1
+
+ if n < 0:
+ return None
+
+ c = np.zeros(n)
+ for k in range(n):
+ cc = np.sum(np.multiply(mfcc1[k : k + nframes], mfcc2[:nframes]), axis=0)
+ c[k] = np.linalg.norm(cc)
+ return c