当前位置: 首页>>代码示例>>C#>>正文


C# Vector.size方法代码示例

本文整理汇总了C#中SceneLibrary.Vector.size方法的典型用法代码示例。如果您正苦于以下问题:C# Vector.size方法的具体用法?C# Vector.size怎么用?C# Vector.size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SceneLibrary.Vector的用法示例。


在下文中一共展示了Vector.size方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: OuterProduct

 /// <summary>
 /// Returns the nxn outer product of two nd-vectors, or [v1]^T*[v2].\ O(n).
 /// </summary>
 /// <param name="v1"></param>
 /// <param name="v2"></param>
 /// <returns></returns>
 public static MatrixFixed OuterProduct(Vector v1, Vector v2) 
 {
     MatrixFixed outp = new MatrixFixed(v1.size(), v2.size());
     for (int i = 0; i < outp.Rows; i++)             // v1.column() * v2.row()
         for (int j = 0; j < outp.Columns; j++)
             outp[i,j] = v1[i] * v2[j];
     return outp;
 }
开发者ID:iManbot,项目名称:monoslam,代码行数:14,代码来源:vector.cs

示例2: Solve

        /// <summary>
        /// Solve the matrix-vector system M x = y, returning x.
        /// </summary>
        /// <param name="y"></param>
        /// <returns></returns>
        public Vector Solve(Vector y)
        {
            // fsm sanity check :
            if (y.size() != U_.Rows) 
            {
                
                Debug.WriteLine("__FILE__ : size of rhs is incompatible with no. of rows in U_ " +
                                "y =" + Convert.ToString(y) + "\n" +
                                "m_=" + Convert.ToString(m_) + "\n" +
                                "n_=" + Convert.ToString(n_) + "\n" +
                                "U_=\n" + Convert.ToString(U_) + "V_=\n" + Convert.ToString(V_) +
                                "W_=\n" + W_);
                
            }

  
            Vector x = new Vector(V_.Rows);   // Solution matrix.
            if (U_.Rows < U_.Columns) 
            {  // Augment y with extra rows of
                Vector yy = new Vector(U_.Rows);  // zeros, so that it matches
                yy.Fill(0);
                if (yy.size() < y.size()) 
                { // fsm
                    Debug.WriteLine("yy=" + Convert.ToString(yy));
                    Debug.WriteLine("y =" + Convert.ToString(y));
                    // the update() call on the next line will abort...
                }
    
                yy.Update(y);     // cols of u.transpose.    
                x = U_.ConjugateTranspose() * yy;
            }
            else
                x = U_.ConjugateTranspose() * y;

            for (int i = 0; i < x.size(); i++) 
            {  // multiply with diagonal 1/W
                float weight = W_[i, i], zero_ = 0.0f;
                if (weight != zero_)
                    x[i] /= weight;
                else
                    x[i] = zero_;
            }
  
            return V_ * x;  // premultiply with v.
        }
开发者ID:kasertim,项目名称:sentience,代码行数:50,代码来源:SVD.cs

示例3: Update

 /// <summary>
 /// Replaces elements with index begining at start, by values of v.
 /// </summary>
 /// <param name="v"></param>
 /// <param name="start"></param>
 /// <returns></returns>
 public Vector Update (Vector v, int start) 
 {
     int end = start + v.size();
     if ((start < data.Length) && (end <= data.Length))
     {
         for (int i = start; i < end; i++)
         {
             data[i] = v.data[i - start];
         }
     }
     return this;
 }
开发者ID:iManbot,项目名称:monoslam,代码行数:18,代码来源:vector.cs


注:本文中的SceneLibrary.Vector.size方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。