LightJason - AgentSpeak(L++)
CRandomSample.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.action.builtin.math.statistic;
25 
26 import org.apache.commons.math3.distribution.AbstractRealDistribution;
34 
35 import javax.annotation.Nonnegative;
36 import javax.annotation.Nonnull;
37 import java.util.Arrays;
38 import java.util.Collections;
39 import java.util.List;
40 import java.util.stream.Collectors;
41 import java.util.stream.Stream;
42 
43 
53 public final class CRandomSample extends IBuiltinAction
54 {
58  private static final long serialVersionUID = 1823216973305374276L;
59 
63  public CRandomSample()
64  {
65  super( 3 );
66  }
67 
68  @Nonnegative
69  @Override
70  public final int minimalArgumentNumber()
71  {
72  return 1;
73  }
74 
75  @Nonnull
76  @Override
77  public final IFuzzyValue<Boolean> execute( final boolean p_parallel, @Nonnull final IContext p_context,
78  @Nonnull final List<ITerm> p_argument, @Nonnull final List<ITerm> p_return )
79  {
80  final List<ITerm> l_arguments = CCommon.flatten( p_argument ).collect( Collectors.toList() );
81 
82  (
83  l_arguments.size() < 2
84  ? Stream.of( 1 )
85  : l_arguments.stream()
86  .skip( 1 )
87  .map( ITerm::<Number>raw )
88  )
89  .mapToInt( Number::intValue )
90  .mapToObj( i -> CRandomSample.samples( l_arguments.get( 0 ).<AbstractRealDistribution>raw(), i, p_parallel ) )
91  .forEach( p_return::add );
92 
93  return CFuzzyValue.from( true );
94  }
95 
104  @Nonnull
105  private static ITerm samples( @Nonnull final AbstractRealDistribution p_distribution, final int p_size, final boolean p_parallel )
106  {
107  if ( p_size < 2 )
108  return CRawTerm.from( p_distribution.sample() );
109 
110  final List<Double> l_list = Arrays.stream( p_distribution.sample( p_size ) ).boxed().collect( Collectors.toList() );
111  return CRawTerm.from( p_parallel ? Collections.synchronizedList( l_list ) : l_list );
112 
113  }
114 
115 }
base class of build-in actions for setting name by package/classname (without prefix character) ...
static< N > IFuzzyValue< N > from( @Nonnull final N p_value)
factory
common structure for execution definition
execution context with local data
Definition: IContext.java:42
static Stream< ITerm > flatten( @Nonnull final Collection<? extends ITerm > p_terms)
flat term-in-term collection into a straight term list
result for an immutable fuzzy value
static< N > CRawTerm< N > from(final N p_value)
factory for a raw term
Definition: CRawTerm.java:104
static ITerm samples( @Nonnull final AbstractRealDistribution p_distribution, final int p_size, final boolean p_parallel)
creates the sample structure
final IFuzzyValue< Boolean > execute(final boolean p_parallel, @Nonnull final IContext p_context, @Nonnull final List< ITerm > p_argument, @Nonnull final List< ITerm > p_return)
defines a plan-body operation
term structure for simple datatypes
Definition: CRawTerm.java:45