View Javadoc
1   package org.djunits.value.vfloat.vector;
2   
3   import java.util.stream.IntStream;
4   
5   import org.djunits.value.StorageType;
6   import org.djunits.value.ValueException;
7   import org.djunits.value.vfloat.FloatFunction;
8   
9   /**
10   * Stores dense data for a FloatVector and carries out basic operations.
11   * <p>
12   * Copyright (c) 2013-2018 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
13   * BSD-style license. See <a href="http://opentrafficsim.org/docs/license.html">OpenTrafficSim License</a>.
14   * </p>
15   * $LastChangedDate: 2015-07-24 02:58:59 +0200 (Fri, 24 Jul 2015) $, @version $Revision: 1147 $, by $Author: averbraeck $,
16   * initial version Oct 3, 2015 <br>
17   * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
18   * @author <a href="http://www.tudelft.nl/pknoppers">Peter Knoppers</a>
19   */
20  public class FloatVectorDataDense extends FloatVectorData
21  {
22      /**
23       * Create a vector with dense data.
24       * @param vectorSI the data to store
25       */
26      public FloatVectorDataDense(final float[] vectorSI)
27      {
28          super(StorageType.DENSE);
29          this.vectorSI = new float[vectorSI.length];
30          System.arraycopy(vectorSI, 0, this.vectorSI, 0, vectorSI.length);
31      }
32  
33      /**
34       * @param floatFunction the function to apply on the (mutable) data elements
35       */
36      public final void assign(final FloatFunction floatFunction)
37      {
38          IntStream.range(0, size()).parallel().forEach(i -> this.vectorSI[i] = floatFunction.apply(this.vectorSI[i]));
39      }
40  
41      /** {@inheritDoc} */
42      @Override
43      public final FloatVectorDataSparse toSparse()
44      {
45          return FloatVectorDataSparse.instantiate(this.vectorSI);
46      }
47  
48      /** {@inheritDoc} */
49      @Override
50      public final int size()
51      {
52          return this.vectorSI.length;
53      }
54  
55      /** {@inheritDoc} */
56      @Override
57      public final float getSI(final int index)
58      {
59          return this.vectorSI[index];
60      }
61  
62      /** {@inheritDoc} */
63      @Override
64      public final void setSI(final int index, final float valueSI)
65      {
66          this.vectorSI[index] = valueSI;
67      }
68  
69      /** {@inheritDoc} */
70      @Override
71      public final float[] getDenseVectorSI()
72      {
73          return this.vectorSI.clone();
74      }
75  
76      /** {@inheritDoc} */
77      @Override
78      public final FloatVectorDataDense copy()
79      {
80          float[] vCopy = new float[this.vectorSI.length];
81          System.arraycopy(this.vectorSI, 0, vCopy, 0, this.vectorSI.length);
82          return new FloatVectorDataDense(vCopy);
83      }
84  
85      /** {@inheritDoc} */
86      @Override
87      public final void incrementBy(final FloatVectorData right) throws ValueException
88      {
89          IntStream.range(0, size()).parallel().forEach(i -> this.vectorSI[i] += right.getSI(i));
90      }
91  
92      /** {@inheritDoc} */
93      @Override
94      public final void decrementBy(final FloatVectorData right) throws ValueException
95      {
96          IntStream.range(0, size()).parallel().forEach(i -> this.vectorSI[i] -= right.getSI(i));
97      }
98  
99      /** {@inheritDoc} */
100     @Override
101     public final void multiplyBy(final FloatVectorData right) throws ValueException
102     {
103         IntStream.range(0, size()).parallel().forEach(i -> this.vectorSI[i] *= right.getSI(i));
104     }
105 
106     /** {@inheritDoc} */
107     @Override
108     public final void divideBy(final FloatVectorData right) throws ValueException
109     {
110         IntStream.range(0, size()).parallel().forEach(i -> this.vectorSI[i] /= right.getSI(i));
111     }
112 }