當前位置: 首頁>>代碼示例>>C#>>正文


C# Matrix.SetRandNormal方法代碼示例

本文整理匯總了C#中System.Matrix.SetRandNormal方法的典型用法代碼示例。如果您正苦於以下問題:C# Matrix.SetRandNormal方法的具體用法?C# Matrix.SetRandNormal怎麽用?C# Matrix.SetRandNormal使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Matrix的用法示例。


在下文中一共展示了Matrix.SetRandNormal方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: TestArithmatic

        public void TestArithmatic()
        {
            Matrix<byte> m = new Matrix<byte>(10, 8);
             m.SetRandNormal(new MCvScalar(), new MCvScalar(30));
             Matrix<byte> mMultiplied = m.Mul(2.0);

             for (int i = 0; i < m.Rows; i++)
            for (int j = 0; j < m.Cols; j++)
               Assert.AreEqual(m[i, j] * 2, mMultiplied[i, j]);
        }
開發者ID:samuto,項目名稱:UnityOpenCV,代碼行數:10,代碼來源:AutoTestMatrix.cs

示例2: TestQuaternions1

      public void TestQuaternions1()
      {
         Quaternions q = new Quaternions();
         double epsilon = 1.0e-10;

         Matrix<double> point = new Matrix<double>(3, 1);
         point.SetRandNormal(new MCvScalar(), new MCvScalar(20));
         using (Matrix<double> pt1 = new Matrix<double>(3, 1))
         using (Matrix<double> pt2 = new Matrix<double>(3, 1))
         using (Matrix<double> pt3 = new Matrix<double>(3, 1))
         {
            double x1 = 1.0, y1 = 0.2, z1 = 0.1;
            double x2 = 0.0, y2 = 0.0, z2 = 0.0;

            q.SetEuler(x1, y1, z1);
            q.GetEuler(ref x2, ref y2, ref z2);

            EmguAssert.IsTrue(
               Math.Abs(x2 - x1) < epsilon &&
               Math.Abs(y2 - y1) < epsilon &&
               Math.Abs(z2 - z1) < epsilon);

            q.RotatePoints(point, pt1);

            Matrix<double> rMat = new Matrix<double>(3, 3);
            q.GetRotationMatrix(rMat);
            CvInvoke.Gemm(rMat, point, 1.0, null, 0.0, pt2, Emgu.CV.CvEnum.GemmType.Default);

            CvInvoke.AbsDiff(pt1, pt2, pt3);

            EmguAssert.IsTrue(
               pt3[0, 0] < epsilon &&
               pt3[1, 0] < epsilon &&
               pt3[2, 0] < epsilon);

         }

         double rotationAngle = 0.2;
         q.SetEuler(rotationAngle, 0.0, 0.0);
         EmguAssert.IsTrue(Math.Abs(q.RotationAngle - rotationAngle) < epsilon);
         q.SetEuler(0.0, rotationAngle, 0.0);
         EmguAssert.IsTrue(Math.Abs(q.RotationAngle - rotationAngle) < epsilon);
         q.SetEuler(0.0, 0.0, rotationAngle);
         EmguAssert.IsTrue(Math.Abs(q.RotationAngle - rotationAngle) < epsilon);

         q = q * q;
         EmguAssert.IsTrue(Math.Abs(q.RotationAngle / 2.0 - rotationAngle) < epsilon);

         q.SetEuler(0.2, 0.1, 0.05);
         double t = q.RotationAngle;
         q = q * q;
         EmguAssert.IsTrue(Math.Abs(q.RotationAngle / 2.0 - t) < epsilon);

      }
開發者ID:Delaley,項目名稱:emgucv,代碼行數:54,代碼來源:AutoTestQuaternions.cs

示例3: GoToNextState

 public void GoToNextState()
 {
     Matrix<float> processNoise = new Matrix<float>(2, 1);
     processNoise.SetRandNormal(new MCvScalar(), new MCvScalar(processNoise[0, 0]));
     state = transitionMatrix * state + processNoise;
 }
開發者ID:abraxas4,項目名稱:AR-Drone-Project,代碼行數:6,代碼來源:SyntheticData.cs

示例4: GetMeasurement

 public Matrix<float> GetMeasurement()
 {
     Matrix<float> measurementNoise = new Matrix<float>(2, 1);
     measurementNoise.SetRandNormal(new MCvScalar(), new MCvScalar(Math.Sqrt(measurementNoise[0, 0])));
     return measurementMatrix * state + measurementNoise;
 }
開發者ID:abraxas4,項目名稱:AR-Drone-Project,代碼行數:6,代碼來源:SyntheticData.cs

示例5: TestEigenVV

      public void TestEigenVV()
      {
         int size = 3;
         Matrix<float> tmp = new Matrix<float>(size, size);
         tmp.SetRandNormal(new MCvScalar(0), new MCvScalar(1));
         Matrix<float> symMat = new Matrix<float>(tmp.Size);
         CvInvoke.MulTransposed(tmp, symMat, false, null, 1.0, CvEnum.DepthType.Cv32S);
         Matrix<float> clone = symMat.Clone();

         Matrix<float> evects = new Matrix<float>(symMat.Size);
         Matrix<float> evals = new Matrix<float>(symMat.Rows, 1);
         CvInvoke.Eigen(symMat, evals, evects);
      }
開發者ID:neutmute,項目名稱:emgucv,代碼行數:13,代碼來源:AutoTestMatrix.cs

示例6: TestRuntimeSerialize1

      public void TestRuntimeSerialize1()
      {
         Matrix<Byte> mat = new Matrix<Byte>(100, 80, 2);
         mat.SetRandNormal(new MCvScalar(100, 100, 100), new MCvScalar(50, 50, 50));

         System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
             formatter = new System.Runtime.Serialization.Formatters.Binary.BinaryFormatter();

         Byte[] bytes;
         using (MemoryStream ms = new MemoryStream())
         {
            formatter.Serialize(ms, mat);
            bytes = ms.GetBuffer();
         }
         using (MemoryStream ms2 = new MemoryStream(bytes))
         {
            Matrix<Byte> mat2 = (Matrix<Byte>) formatter.Deserialize(ms2);
            EmguAssert.IsTrue(mat.Equals(mat2));
         }
      }
開發者ID:neutmute,項目名稱:emgucv,代碼行數:20,代碼來源:AutoTestMatrix.cs

示例7: TestEigenVV

        public void TestEigenVV()
        {
            int size = 3;
             Matrix<float> tmp = new Matrix<float>(size, size);
             tmp.SetRandNormal(new MCvScalar(0), new MCvScalar(1));
             Matrix<float> symMat = new Matrix<float>(tmp.Size);
             CvInvoke.cvMulTransposed(tmp, symMat, 1, IntPtr.Zero, 1.0);
             Matrix<float> clone = symMat.Clone();

             Matrix<float> evects = new Matrix<float>(symMat.Size);
             Matrix<float> evals = new Matrix<float>(symMat.Rows, 1);
             CvInvoke.cvEigenVV(symMat, evects, evals, 1.0e-15, 0, 0);
        }
開發者ID:samuto,項目名稱:UnityOpenCV,代碼行數:13,代碼來源:AutoTestMatrix.cs

示例8: TestBinaryStorage

      public void TestBinaryStorage()
      {
         //generate some randome points
         PointF[] pts = new PointF[120];
         GCHandle handle = GCHandle.Alloc(pts, GCHandleType.Pinned);
         using (Matrix<float> ptsMat = new Matrix<float>(pts.Length, 2, handle.AddrOfPinnedObject(), Marshal.SizeOf(typeof(float)) * 2))
         {
            ptsMat.SetRandNormal(new MCvScalar(), new MCvScalar(100));
         }
         handle.Free();

         String fileName = Path.Combine(Path.GetTempPath(), "tmp.dat");
         Stopwatch watch = Stopwatch.StartNew();
         BinaryFileStorage<PointF> stor = new BinaryFileStorage<PointF>(fileName, pts);
         //BinaryFileStorage<PointF> stor = new BinaryFileStorage<PointF>("abc.data", pts);
         watch.Stop();
         EmguAssert.WriteLine(String.Format("Time for writing {0} points: {1} milliseconds", pts.Length, watch.ElapsedMilliseconds));
         int estimatedSize = stor.EstimateSize();

         //EmguAssert.IsTrue(pts.Length == estimatedSize);

         watch.Reset();
         watch.Start();
         PointF[] pts2 = stor.ToArray();
         watch.Stop();
         EmguAssert.WriteLine(String.Format("Time for reading {0} points: {1} milliseconds", pts.Length, watch.ElapsedMilliseconds));

         if (File.Exists(fileName))
            File.Delete(fileName);

         //EmguAssert.IsTrue(pts.Length == pts2.Length);

         //Check for equality
         for (int i = 0; i < pts.Length; i++)
         {
            //EmguAssert.IsTrue(pts[i] == pts2[i]);
         }
      }
開發者ID:Delaley,項目名稱:emgucv,代碼行數:38,代碼來源:AutoTestVarious.cs

示例9: TestVectorOfMat

      public void TestVectorOfMat()
      {
         Matrix<double> m1 = new Matrix<double>(3, 3);
         m1.SetRandNormal(new MCvScalar(0.0), new MCvScalar(1.0));
         Matrix<int> m2 = new Matrix<int>(4, 4);
         m2.SetRandNormal(new MCvScalar(2), new MCvScalar(2));

         VectorOfMat vec = new VectorOfMat(m1.Mat, m2.Mat);

         Mat tmp1 = vec[0];
         Mat tmp2 = vec[1];
         Matrix<double> n1 = new Matrix<double>(tmp1.Size);
         Matrix<int> n2 = new Matrix<int>(tmp2.Size);
         tmp1.CopyTo(n1, null);
         tmp2.CopyTo(n2, null);

         EmguAssert.IsTrue(m1.Equals(n1));
         EmguAssert.IsTrue(m2.Equals(n2));
      }
開發者ID:Delaley,項目名稱:emgucv,代碼行數:19,代碼來源:AutoTestVarious.cs

示例10: GoToNextState

 public void GoToNextState()
 {
    Matrix<float> processNoise = new Matrix<float>(2, 1);
    processNoise.SetRandNormal(new MCvScalar(), new MCvScalar(Math.Sqrt(ProcessNoise[0, 0])));
    _state = TransitionMatrix * _state + processNoise;
 }
開發者ID:Warren-GH,項目名稱:emgucv,代碼行數:6,代碼來源:Class1.cs

示例11: GoToNextState

 public void GoToNextState()
 {
     var processNoise = new Matrix<float>(4, 1);
     processNoise.SetRandNormal(new MCvScalar(), new MCvScalar(processNoise[0, 0]));
     State = TransitionMatrix * State + processNoise;
 }
開發者ID:AlternateIf,項目名稱:huddle-engine,代碼行數:6,代碼來源:SyntheticData.cs


注:本文中的System.Matrix.SetRandNormal方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。