Exemple #1
0
        public List <double> merge_attack_by_user(KnowlegePattern KP_user1, KnowlegePattern KP_user2, string user1, string user2, string user_in_both)
        {
            List <double> output = new List <double> ();

            List <double> KP_user1_getattacklist = KP_user1.get_attack(user1, user_in_both);
            List <double> KP_user2_getattacklist = KP_user2.get_attack(user_in_both, user2);

            // рассматриваем все цепочки до связи между отделами
            for (int i = 0; i < KP_user1_getattacklist.Count; i++)
            {
                for (int j = 0; j < KP_user2_getattacklist.Count; j++)
                {
                    output.Add(KP_user2_getattacklist[j] *
                               KP_user1_getattacklist[i] / KP_user1.vertexWeight[user_in_both]
                               );
                }
            }
            return(output);
        }
Exemple #2
0
        // получаем списки отделов и смотрим на пересечения
        public List <double> merge_attack_by_edge(KnowlegePattern KP_user1, KnowlegePattern KP_user2, string user1, string user2, Edge <string> e)
        {
            List <double> output = new List <double> ();

            List <double> KP_user1_getattacklist = KP_user1.get_attack(user1, e.Source);
            List <double> KP_user2_getattacklist = KP_user2.get_attack(e.Target, user2);

            double _out;

            // рассматриваем все цепочки до связи между отделами
            for (int i = 0; i < KP_user1_getattacklist.Count; i++)
            {
                for (int j = 0; j < KP_user2_getattacklist.Count; j++)
                {
                    _out = (KP_user2_getattacklist [j] * KP_user1_getattacklist [i] * G.edgeWeight[e]) / KP_user1.vertexWeight [user2];
                    output.Add(_out);
                }
            }

            return(output);
        }