Пример #1
0
        //zTODO: 如果匹配一致?包括完美一致?
        //使用词语近似性算法:LevenshteinDistance
        public MemberCompareResult_t Compare(CSharpMember_t src)
        {
            if (Members.Count == 0)
            {
                return(null);
            }

            MemberCompareResult_t mcr = new MemberCompareResult_t(src);

            Int32  Distance;
            Double Similarity;

            for (int i = 0; i < Members.Count; ++i)
            {
                if (UseSign[i] == true)
                {
                    continue;
                }

                if (Members[i].Name == src.Name)
                {
                    this.UseSign[i] = true;

                    mcr.Distance   = 0;
                    mcr.Similarity = 1;
                    mcr.dst        = Members[i];
                    return(mcr);
                }

                //忽略太短的词语
                if (CONFIG_Member_LevenshteinDistance)
                {
                    if (src.Name.Length > 4)
                    {
                        Distance = CCLevenshtein.LevenshteinDistance(Members[i].Name, src.Name, out Similarity, false);
                        if (Similarity > mcr.Similarity)
                        {
                            mcr.Distance   = Distance;
                            mcr.Similarity = Similarity;
                            mcr.dst        = Members[i];
                        }
                    }
                }
            }
            return(mcr);
        }
Пример #2
0
        //2个类型比较,返回相似度: 0-100
        //z: 使用调节因子
        public CSharpTypeCompareResult_t Compare(CSharpType_t other)
        {
            if (Members.Count == 0)
            {
                return(null);
            }

            other.InitUseSign();

            CSharpTypeCompareResult_t res = new CSharpTypeCompareResult_t();

            for (int i = 0; i < Members.Count; ++i)
            {
                //如果我的成员在ref集合中找到。。。
                MemberCompareResult_t mcr = other.Compare(Members[i]);
                if (mcr != null && mcr.Similarity >= 0.7)
                {
                    res.strs.Add(mcr);//Members[i].Name
                }
            }
            res.refType = other;
            res.percent = (int)(res.strs.Count * 100.0f / Members.Count);
            return(res);
        }