Accord.Tests.Imaging.KCurvatureTest.FindPeaksTest6 C# (CSharp) Méthode

FindPeaksTest6() private méthode

private FindPeaksTest6 ( ) : void
Résultat void
        public void FindPeaksTest6()
        {
            Bitmap hand = Accord.Imaging.Image.Clone(Properties.Resources.rhand3);

            GaussianBlur median = new GaussianBlur(1.1);
            median.ApplyInPlace(hand);

            // Extract contour
            BorderFollowing bf = new BorderFollowing(1);
            List<IntPoint> contour = bf.FindContour(hand);

            hand = hand.Clone(new Rectangle(0, 0, hand.Width, hand.Height), PixelFormat.Format24bppRgb);

            // Find peaks
            KCurvature kcurv = new KCurvature(30, new DoubleRange(0, 45));
            var peaks = kcurv.FindPeaks(contour);

            List<IntPoint> supports = new List<IntPoint>();
            for (int i = 0; i < peaks.Count; i++)
            {
                int j = contour.IndexOf(peaks[i]);
                supports.Add(contour[(j + kcurv.K) % contour.Count]);
                supports.Add(contour[Accord.Math.Tools.Mod(j - kcurv.K, contour.Count)]);
            }

            // show(hand, contour, peaks, supports);

            Assert.AreEqual(5, peaks.Count);
            Assert.AreEqual(0, peaks[0].X);
            Assert.AreEqual(95, peaks[0].Y);
            Assert.AreEqual(98, peaks[1].X);
            Assert.AreEqual(13, peaks[1].Y);
            Assert.AreEqual(69, peaks[2].X);
            Assert.AreEqual(0, peaks[2].Y);
            Assert.AreEqual(39, peaks[3].X);
            Assert.AreEqual(0, peaks[3].Y);
            Assert.AreEqual(17, peaks[4].X);
            Assert.AreEqual(17, peaks[4].Y);
        }
    }