LightJason - AgentSpeak(L++)
CWeightedDifference.java
Go to the documentation of this file.
1 /*
2  * @cond LICENSE
3  * ######################################################################################
4  * # LGPL License #
5  * # #
6  * # This file is part of the LightJason AgentSpeak(L++) #
7  * # Copyright (c) 2015-19, LightJason (info@lightjason.org) #
8  * # This program is free software: you can redistribute it and/or modify #
9  * # it under the terms of the GNU Lesser General Public License as #
10  * # published by the Free Software Foundation, either version 3 of the #
11  * # License, or (at your option) any later version. #
12  * # #
13  * # This program is distributed in the hope that it will be useful, #
14  * # but WITHOUT ANY WARRANTY; without even the implied warranty of #
15  * # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
16  * # GNU Lesser General Public License for more details. #
17  * # #
18  * # You should have received a copy of the GNU Lesser General Public License #
19  * # along with this program. If not, see http://www.gnu.org/licenses/ #
20  * ######################################################################################
21  * @endcond
22  */
23 
24 package org.lightjason.agentspeak.consistency.metric;
25 
27 
28 import java.util.Collection;
29 import java.util.HashSet;
30 import java.util.Set;
31 import java.util.stream.Collectors;
32 import java.util.stream.Stream;
33 
34 
39 public final class CWeightedDifference implements IMetric
40 {
41 
42  @Override
43  public final Double apply( final Stream<? extends ITerm> p_first, final Stream<? extends ITerm> p_second )
44  {
45  final Collection<ITerm> l_first = p_first.collect( Collectors.toCollection( HashSet<ITerm>::new ) );
46  final Collection<ITerm> l_second = p_second.collect( Collectors.toCollection( HashSet<ITerm>::new ) );
47 
48  // element aggregation
49  final double l_union = Stream.concat( l_first.stream(), l_second.stream() ).count();
50  final Set<? extends ITerm> l_intersection = new HashSet<>( l_first );
51  l_intersection.retainAll( l_second );
52 
53  // return distance
54  return ( 2.0 * l_union
55  - l_first.size()
56  - l_second.size()
57  )
58  * l_union
59  / l_intersection.size();
60  }
61 
62 }
metric interface of the coherency structure
Definition: IMetric.java:37
calculates the distance with respect to size of union and intersection of beliefbases.
final Double apply(final Stream<? extends ITerm > p_first, final Stream<? extends ITerm > p_second)