コード例 #1
0
        public void ShouldAddProductClass()
        {
            string name = "Неклассифицированный";
            ProductClassRepository repo = new ProductClassRepository();

            repo.CreateProductClass(name, null, null);
        }
コード例 #2
0
        public void ShouldGetAllDescendants()
        {
            string wine               = "Вино";
            string redWine            = "Красное вино";
            string whiteWine          = "Белое вино";
            string redDryWine         = "Красное сухое вино";
            string whiteDryWine       = "Белое сухое вино";
            string redSemisweetWine   = "Красное полусладкое вино";
            string whiteSemisweetWine = "Белое полусладкое вино";
            string redSweetWine       = "Красное сладкое вино";
            string whiteSweetWine     = "Белое сладкое вино";

            ProductClassRepository repo = new ProductClassRepository();
            //repo.CreateProductClass(wine, null, null);
            ProductClass parent = repo.GetProductClass(wine);

            //repo.CreateProductClass(redWine, null, parent.Id);
            //repo.CreateProductClass(whiteWine, null, parent.Id);
            //parent = repo.GetProductClass(redWine);
            //repo.CreateProductClass(redDryWine, null, parent.Id);
            //repo.CreateProductClass(redSemisweetWine, null, parent.Id);
            //repo.CreateProductClass(redSweetWine, null, parent.Id);
            //parent = repo.GetProductClass(whiteWine);
            //repo.CreateProductClass(whiteDryWine, null, parent.Id);
            //repo.CreateProductClass(whiteSemisweetWine, null, parent.Id);
            //repo.CreateProductClass(whiteSweetWine, null, parent.Id);
            parent = repo.GetProductClass(wine);

            repo.GetProductClassDescendants(parent.Id);
        }
コード例 #3
0
ファイル: Program.cs プロジェクト: dmitrykudin/Demo
        public static void getProductClassesFromTemp()
        {
            List <string> pClasses = getProductClassesStrings();

            foreach (var item in pClasses)
            {
                // TODO не создавать одинаковые тэги
                //Console.WriteLine("Input: ");
                //string str = Console.ReadLine();
                //Console.WriteLine("ParentId: ");
                //int? parent = Convert.ToInt32(Console.ReadLine());
                string[]               parts = item.Split(':');
                string                 name  = parts[0].Split('"')[1];
                List <string>          tags  = parts[1].Split('"').Where((it, index) => index % 2 != 0).ToList();
                ProductClassRepository productClassRepository = new ProductClassRepository();
                ProductClass           productClass           = productClassRepository.CreateProductClass(name, null, null);
                TagRepository          tagRepository          = new TagRepository();
                ClassTagRepository     classTagRepository     = new ClassTagRepository();
                if (tags.Any())
                {
                    foreach (var tagName in tags)
                    {
                        Tag      tag      = tagRepository.CreateTag(tagName);
                        ClassTag classTag = classTagRepository.CreateClassTag(productClass.Id, tag.Id);
                    }
                }
            }
        }
コード例 #4
0
ファイル: HowToClassify.cs プロジェクト: dmitrykudin/Demo
        public void Classify()
        {
            Dictionary <Product, ProductClass> setClass = new Dictionary <Product, ProductClass>();
            ProductClassRepository             productClassRepository = new ProductClassRepository();
            ProductRepository   productRepository = new ProductRepository();
            List <ProductClass> productClasses    = productClassRepository.GetAllProductClasses();
            List <Product>      products          = productRepository.GetAllProducts();

            foreach (var product in products)
            {
                float similarity = 0.0F;
                Dictionary <ProductClass, float> res = new Dictionary <ProductClass, float>();
                foreach (var cl in productClasses)
                {
                    string tagStr = "";
                    foreach (var tag in cl.ClassTags)
                    {
                        tagStr += tag.Tag.TagName + " ";
                    }
                    MatchsMaker match = new MatchsMaker(ReplaceBadStrings(product.Name), tagStr);
                    res.Add(cl, match.Score);
                    //if (similarity < match.Score)
                    //{
                    //    similarity = match.Score;
                    //    if (setClass.ContainsKey(product))
                    //    {
                    //        setClass.Remove(product);
                    //    }
                    //    setClass.Add(product, cl);
                    //    string output = "Product: " + product.Name + " is " + cl.Name + "(" + tagStr + ") with " + similarity * 100.0 + "% confidence.";
                    //    Console.WriteLine(output);
                    //    if (!File.Exists(filePath))
                    //    {
                    //        File.WriteAllText(filePath, output + Environment.NewLine);
                    //    }
                    //    else
                    //    {
                    //        File.AppendAllText(filePath, output + Environment.NewLine);
                    //    }
                    //}
                }
                var result = res.ToList();
                result.Sort((pair1, pair2) => pair2.Value.CompareTo(pair1.Value));
                Console.WriteLine("Лучшие 3 совпадения для " + product.Name + ":");
                if (!File.Exists(filePath))
                {
                    File.WriteAllText(filePath, "Лучшие 3 совпадения для " + product.Name + ":" + Environment.NewLine);
                }
                else
                {
                    File.AppendAllText(filePath, "Лучшие 3 совпадения для " + product.Name + ":" + Environment.NewLine);
                }
                for (int i = 0; i < 3; i++)
                {
                    string output = "Product: " + product.Name + " is " + result.ElementAt(i).Key.Name + " with " + result.ElementAt(i).Value * 100.0 + "% confidence.";
                    Console.WriteLine(output);
                    File.AppendAllText(filePath, output + Environment.NewLine);
                }
            }
        }
コード例 #5
0
ファイル: HowToClassify.cs プロジェクト: dmitrykudin/Demo
        public void ClassifyV3()
        {
            Dictionary <Product, ProductClass> setClass = new Dictionary <Product, ProductClass>();
            ProductClassRepository             productClassRepository = new ProductClassRepository();
            ProductRepository   productRepository = new ProductRepository();
            List <ProductClass> productClasses    = productClassRepository.GetAllProductClasses();
            List <Product>      products          = productRepository.GetAllProducts();

            foreach (var product in products)
            {
                float similarity = 0.0F;
                Dictionary <ProductClass, float> res = new Dictionary <ProductClass, float>();
                foreach (var cl in productClasses)
                {
                    MatchsMaker match = new MatchsMaker(ReplaceBadStrings(product.Name), ReplaceBadStrings(cl.Name));
                    res.Add(cl, match.Score);
                }
                var result = res.ToList();
                result.Sort((pair1, pair2) => pair2.Value.CompareTo(pair1.Value));
                Console.WriteLine("Лучшие 3 совпадения для " + product.Name + ":");
                if (!File.Exists(filePath))
                {
                    File.WriteAllText(filePath, "Лучшие 3 совпадения для " + product.Name + ":" + Environment.NewLine);
                }
                else
                {
                    File.AppendAllText(filePath, "Лучшие 3 совпадения для " + product.Name + ":" + Environment.NewLine);
                }
                for (int i = 0; i < 3; i++)
                {
                    string output = "Product: " + product.Name + " is " + result.ElementAt(i).Key.Name + " with " + result.ElementAt(i).Value * 100.0 + "% confidence.";
                    Console.WriteLine(output);
                    File.AppendAllText(filePath, output + Environment.NewLine);
                }
            }
        }
コード例 #6
0
 public void ShouldGetChildren()
 {
     ProductClassRepository repo     = new ProductClassRepository();
     List <ProductClass>    children = repo.GetProductClassChildren(2);
 }
コード例 #7
0
ファイル: ModifyProductClass.cs プロジェクト: AbnerTisa/Yhgd
 public ModifyProductClass()
 {
     repository = DbFactory.Repository <ProductClassRepository>(false);
 }
コード例 #8
0
ファイル: HowToClassify.cs プロジェクト: dmitrykudin/Demo
        // HUINYA
        public void ClassifyV2()
        {
            TagRepository          tagRepository          = new TagRepository();
            List <Tag>             tags                   = tagRepository.GetAllTags();
            ProductClassRepository productClassRepository = new ProductClassRepository();
            ProductRepository      productRepository      = new ProductRepository();
            List <Product>         products               = productRepository.GetAllProducts();
            List <ProductClass>    productClasses         = new List <ProductClass>();

            foreach (var product in products)
            {
                string[] terms = ReplaceBadStrings(product.Name).Split(' ');
                for (int i = 0; i < terms.Length; i++)
                {
                    Tag tagMatch = tags.Find(t => t.TagName == terms[i]);
                    if (tagMatch != null)
                    {
                        productClasses.AddRange(productClassRepository.GetProductClassesByTag(tagMatch));
                    }
                }

                Dictionary <ProductClass, float> res = new Dictionary <ProductClass, float>();
                foreach (var productClass in productClasses)
                {
                    string tagStr = "";
                    foreach (var tag in productClass.ClassTags)
                    {
                        tagStr += tag.Tag.TagName + " ";
                    }
                    MatchsMaker match = new MatchsMaker(ReplaceBadStrings(product.Name), tagStr);
                    res.Add(productClass, match.Score);
                }

                var result = res.ToList();
                result.Sort((pair1, pair2) => pair2.Value.CompareTo(pair1.Value));
                Console.WriteLine("Лучшие 3 совпадения для " + product.Name + ":");
                if (!File.Exists(filePath))
                {
                    File.WriteAllText(filePath, "Лучшие 5 совпадений для " + product.Name + ":" + Environment.NewLine);
                }
                else
                {
                    File.AppendAllText(filePath, "Лучшие 5 совпадений для " + product.Name + ":" + Environment.NewLine);
                }
                if (result.Count < 5)
                {
                    foreach (var item in result)
                    {
                        string output = "Product: " + product.Name + " is " + item.Key.Name + " with " + item.Value * 100.0 + "% confidence.";
                        Console.WriteLine(output);
                        File.AppendAllText(filePath, output + Environment.NewLine);
                    }
                }
                else
                {
                    for (int i = 0; i < 5; i++)
                    {
                        string output = "Product: " + product.Name + " is " + result.ElementAt(i).Key.Name + " with " + result.ElementAt(i).Value * 100.0 + "% confidence.";
                        Console.WriteLine(output);
                        File.AppendAllText(filePath, output + Environment.NewLine);
                    }
                }
            }
        }