View Javadoc
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.primitive.number;
28  
29  import com.rapiddweller.common.ConversionException;
30  import com.rapiddweller.common.converter.NumberToNumberConverter;
31  import com.rapiddweller.common.converter.ThreadSafeConverter;
32  
33  /**
34   * Quantizes integer numbers ({@link Byte}, {@link Short}, {@link Integer}, {@link Long})
35   * to be <code>min</code> plus an integral multiple of <code>granularity</code>.<br/><br/>
36   * Created: 15.03.2010 15:27:08
37   *
38   * @param <E> the type parameter
39   * @author Volker Bergmann
40   * @since 0.6.0
41   */
42  public class IntegralQuantizer<E extends Number> extends ThreadSafeConverter<E, E> {
43  
44    private final long min;
45    private final long granularity;
46    private final NumberToNumberConverter<Long, E> converter;
47  
48    /**
49     * Instantiates a new Integral quantizer.
50     *
51     * @param numberType  the number type
52     * @param min         the min
53     * @param granularity the granularity
54     */
55    public IntegralQuantizer(Class<E> numberType, Long min, long granularity) {
56      super(numberType, numberType);
57      this.min = (min != null ? min : 0L);
58      this.granularity = granularity;
59      this.converter = new NumberToNumberConverter<>(Long.class, numberType);
60    }
61  
62    @Override
63    public E convert(E sourceValue) throws ConversionException {
64      long l = (sourceValue.longValue() - min) / granularity * granularity + min;
65      return converter.convert(l);
66    }
67  
68  }