1 /*
2 * (c) Copyright 2006-2020 by rapiddweller GmbH & Volker Bergmann. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, is permitted under the terms of the
6 * GNU General Public License.
7 *
8 * For redistributing this software or a derivative work under a license other
9 * than the GPL-compatible Free Software License as defined by the Free
10 * Software Foundation or approved by OSI, you must first obtain a commercial
11 * license to this software product from rapiddweller GmbH & Volker Bergmann.
12 *
13 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14 * WITHOUT A WARRANTY OF ANY KIND. ALL EXPRESS OR IMPLIED CONDITIONS,
15 * REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF
16 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE
17 * HEREBY EXCLUDED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
18 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
19 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
20 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
21 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
22 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
23 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
24 * POSSIBILITY OF SUCH DAMAGE.
25 */
26
27 package com.rapiddweller.benerator.distribution.sequence;
28
29 import com.rapiddweller.benerator.NonNullGenerator;
30 import com.rapiddweller.benerator.distribution.Sequence;
31 import com.rapiddweller.benerator.wrapper.WrapperFactory;
32 import com.rapiddweller.common.BeanUtil;
33 import com.rapiddweller.common.ConfigurationError;
34 import com.rapiddweller.common.NumberUtil;
35
36 import java.math.BigInteger;
37
38 import static com.rapiddweller.common.NumberUtil.toDouble;
39 import static com.rapiddweller.common.NumberUtil.toLong;
40
41 /**
42 * {@link Sequence} implementation for an efficient bell-like distribution.<br/>
43 * <br/>
44 * Created at 23.09.2009 18:59:30
45 *
46 * @author Volker Bergmann
47 * @since 0.6.0
48 */
49 public class CumulatedSequence extends Sequence {
50
51 @Override
52 public <T extends Number> NonNullGenerator<T> createNumberGenerator(Class<T> numberType, T min, T max, T granularity, boolean unique) {
53 if (unique) {
54 throw new ConfigurationError(getClass().getSimpleName() + " does not support uniqueness");
55 }
56 NonNullGenerator<? extends Number> base;
57 if (BeanUtil.isIntegralNumberType(numberType)) {
58 long lMax = (max != null ? max.longValue() :
59 (numberType != Long.class && numberType != BigInteger.class ? NumberUtil.maxValue(numberType).longValue() :
60 CumulatedLongGenerator.DEFAULT_MAX));
61 base = new CumulatedLongGenerator(toLong(min), lMax, toLong(granularity));
62 } else {
63 double dMax = (max != null ? max.doubleValue() : Long.MAX_VALUE);
64 base = new CumulatedDoubleGenerator(toDouble(min), dMax, toDouble(granularity));
65 }
66 return WrapperFactory.asNonNullNumberGeneratorOfType(numberType, base, min, granularity);
67 }
68
69 }