コード例 #1
0
        public AbsoluteEuclideanDistBelowThresholdForPtcOfWordsIsAMatch(double distanceThreshold, double wordsPctThreshold)
        {
            calculator    = new EuclideanDistanceCalculator();
            voiceDetector = new AutocorrellatedVoiceActivityDetector();

            this.distanceThreshold = distanceThreshold;
            this.wordsPctThreshold = wordsPctThreshold;

            featureExtractor = new PreprocessorAndFeatureExtractor(sampleRate);
        }
コード例 #2
0
ファイル: VoiceSample.cs プロジェクト: Majardom/CourseWork
        private double[] ProvideAmplitudeValues(byte[] sample)
        {
            var voiceDetector = new AutocorrellatedVoiceActivityDetector();

            File.WriteAllBytes(TEMP_FILE, sample);
            double[] result = null;
            using (var stream = File.OpenRead(TEMP_FILE))
            {
                result = AudioConverter.ConvertAudioToDoubleArray(stream, _sampleRate);
            }

            File.Delete(TEMP_FILE);

            return(voiceDetector.RemoveSilence(result, _sampleRate));
        }
コード例 #3
0
        public MatchResult <string> RecognizeSpeaker(byte[] sample)
        {
            var voiceDetector = new AutocorrellatedVoiceActivityDetector();

            var fullFileName = Path.Combine(_baseDirectory, "identify.wav");

            File.WriteAllBytes(fullFileName, sample);

            foreach (var persons in Directory.GetDirectories(_baseDirectory).OrderBy(f => f))
            {
                var info = new DirectoryInfo(persons);
                var name = info.Name;

                VoicePrint voice = null;

                foreach (var audio in Directory.GetFiles(persons, "*.wav", SearchOption.TopDirectoryOnly))
                {
                    using (var fs = File.OpenRead(audio))
                    {
                        if (voice == null)
                        {
                            voice = recognition.CreateVoicePrint(name, fs);
                        }
                        else
                        {
                            voice = recognition.MergeVoiceSample(name, fs);
                        }
                    }
                }
            }

            MatchResult <string> identify;


            using (var stream = new FileStream(fullFileName, FileMode.Open))
            {
                identify = recognition.Identify(stream).FirstOrDefault();
            }

            File.Delete(fullFileName);

            return(identify);
        }
コード例 #4
0
        static void Main(string[] args)
        {
            var start = DateTime.Now;

            try
            {
                string base_dir = "C:\\Users\\fabio\\Desktop\\audio_sample";

                var tests = new List <string>();

                using (var waveOut = new WaveOutEvent())
                {
                    var voiceDetector = new AutocorrellatedVoiceActivityDetector();


                    foreach (var pessoas in Directory.GetDirectories(base_dir).OrderBy(f => f))
                    {
                        var info = new DirectoryInfo(pessoas);
                        var nome = info.Name;

                        Console.WriteLine($"nome:{nome}");

                        VoicePrint voice = null;

                        foreach (var audio in Directory.GetFiles(pessoas, "audio_*.wav", SearchOption.TopDirectoryOnly))
                        {
                            Console.WriteLine($"nome:{audio}");



                            using (var fs = File.OpenRead(audio))
                            {
                                if (voice == null)
                                {
                                    voice = recognito.CreateVoicePrint(nome, fs);
                                }
                                else
                                {
                                    voice = recognito.MergeVoiceSample(nome, fs);
                                }
                            }

                            using (var wr = new WaveFileReader(audio))
                            {
                                Console.WriteLine("Play Original");
                                waveOut.Init(wr);
                                waveOut.PlayAndWait();
                            }

                            using (var fs = new FileStream(audio, FileMode.Open))
                            {
                                var sentence = AudioConverter.ConvertAudioToDoubleArray(fs, sampleRate);

                                var words = voiceDetector.SplitBySilence(sentence, sampleRate);

                                var aa = AudioConverter.WriteAudioInputStream(sentence);



                                if (words.Length > 1)
                                {
                                    foreach (var word in words)
                                    {
                                        var aw = AudioConverter.WriteAudioInputStream(word);

                                        using (var wr = new WaveFileReader(aw))
                                        {
                                            Console.WriteLine("Play Word");
                                            waveOut.Init(wr);
                                            waveOut.PlayAndWait();
                                            Thread.Sleep(1000);
                                        }
                                    }
                                }
                            }
                        }
                    }
                }

                Console.WriteLine("\n\nTestes");
                tests = Directory.GetFiles(base_dir, "teste_*.wav", SearchOption.AllDirectories).ToList();

                foreach (var test in tests)
                {
                    Console.WriteLine($"Testando: {test}");

                    using (var fs = new FileStream(test, FileMode.Open))
                    {
                        var identify = recognito.Identify(fs).FirstOrDefault();

                        Console.WriteLine($"identify.Key:{identify.Key},identify.Distance: {identify.Distance}, identify.LikelihoodRatio:{identify.LikelihoodRatio}");
                    }
                }
            }
            catch (Exception ex)
            {
                Console.WriteLine("[ERROR]");
                Console.WriteLine(ex);
            }
            finally
            {
                Console.WriteLine($"Time:{(DateTime.Now - start)}");

                Console.WriteLine("Press Any Key do Close");
                Console.ReadKey();
            }
        }
コード例 #5
0
ファイル: Program.cs プロジェクト: Majardom/CourseWork
        static void Main(string[] args)
        {
            var start = DateTime.Now;

            string base_dir = "D:\\samples";

            var tests = new List <string>();

            using (var waveOut = new WaveOutEvent())
            {
                var voiceDetector = new AutocorrellatedVoiceActivityDetector();


                foreach (var pessoas in Directory.GetDirectories(base_dir).OrderBy(f => f))
                {
                    var info = new DirectoryInfo(pessoas);
                    var nome = info.Name;

                    Console.WriteLine($"nome:{nome}");

                    VoicePrint voice = null;

                    foreach (var audio in Directory.GetFiles(pessoas, "audio_*.wav", SearchOption.TopDirectoryOnly))
                    {
                        Console.WriteLine($"nome:{audio}");



                        using (var fs = File.OpenRead(audio))
                        {
                            if (voice == null)
                            {
                                voice = recognito.CreateVoicePrint(nome, fs);
                            }
                            else
                            {
                                voice = recognito.MergeVoiceSample(nome, fs);
                            }
                        }

                        //using (var wr = new WaveFileReader(audio))
                        //{
                        //	Console.WriteLine("Play Original");
                        //	waveOut.Init(wr);
                        //	waveOut.PlayAndWait();
                        //}
                    }
                }
            }

            Console.WriteLine("\n\nTestes");
            tests = Directory.GetFiles(base_dir, "teste_*.wav", SearchOption.AllDirectories).ToList();

            foreach (var test in tests)
            {
                Console.WriteLine($"Testando: {test}");

                using (var fs = new FileStream(test, FileMode.Open))
                {
                    var identify = recognito.Identify(fs).FirstOrDefault();

                    Console.WriteLine($"identify.Key:{identify.Key},identify.Distance: {identify.Distance}, identify.LikelihoodRatio:{identify.LikelihoodRatio}");
                }
            }


            Console.WriteLine($"Time:{(DateTime.Now - start)}");

            Console.WriteLine("Press Any Key do Close");
            Console.ReadKey();
        }