Enum Class VectorShape
- All Implemented Interfaces:
-
Serializable
,Comparable<VectorShape>
,Constable
public enum VectorShape extends Enum<VectorShape>
VectorShape
selects a particular implementation of Vector
s. A shape in combination with the element type determines a particular vector species object.- API Note:
- Because not all shapes are supported by all platforms, shape-agnostic code is more portable. User code that selects particular shapes may fail to run, or run slowly, on some platforms. Use
VectorShape.preferredShape()
andVectorSpecies.ofPreferred()
to select the shape that is usually preferable for most uses.
Nested Class Summary
Nested classes/interfaces declared in class java.lang.Enum
Enum.EnumDesc<E extends Enum<E>>
Enum Constant Summary
Enum Constant | Description |
---|---|
S_128_BIT |
Shape of length 128 bits |
S_256_BIT |
Shape of length 256 bits |
S_512_BIT |
Shape of length 512 bits |
S_64_BIT |
Shape of length 64 bits |
S_Max_BIT |
Shape of maximum length supported on the platform |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
static VectorShape |
forBitSize |
Finds an appropriate shape depending on the proposed bit-size of a vector. |
static VectorShape |
forIndexBitSize |
Finds an appropriate index shape depending on the proposed index-bit-size and element-size of a vector. |
static VectorShape |
preferredShape() |
Finds the vector shape preferred by the current platform for all vector element types. |
static VectorShape |
valueOf |
Returns the enum constant of this class with the specified name. |
static VectorShape[] |
values() |
Returns an array containing the constants of this enum class, in the order they are declared. |
int |
vectorBitSize() |
Returns the size, in bits, of vectors of this shape. |
<E> VectorSpecies<E> |
withLanes |
Finds a vector species with the given element type and the current shape. |
Enum Constant Details
S_64_BIT
public static final VectorShape S_64_BIT
S_128_BIT
public static final VectorShape S_128_BIT
S_256_BIT
public static final VectorShape S_256_BIT
S_512_BIT
public static final VectorShape S_512_BIT
S_Max_BIT
public static final VectorShape S_Max_BIT
Method Details
values
public static VectorShape[] values()
- Returns:
- an array containing the constants of this enum class, in the order they are declared
valueOf
public static VectorShape valueOf(String name)
- Parameters:
-
name
- the name of the enum constant to be returned. - Returns:
- the enum constant with the specified name
- Throws:
-
IllegalArgumentException
- if this enum class has no constant with the specified name -
NullPointerException
- if the argument is null
vectorBitSize
public int vectorBitSize()
- Returns:
- the size, in bits, of vectors of this shape.
withLanes
public <E> VectorSpecies<E> withLanes(Class<E> elementType)
VectorSpecies.of(elementType, this)
.- Type Parameters:
-
E
- the boxed element type - Parameters:
-
elementType
- the required element type - Returns:
- a species for the given element type and this shape
- See Also:
forBitSize
public static VectorShape forBitSize(int bitSize)
- Parameters:
-
bitSize
- the proposed vector size in bits - Returns:
- a shape corresponding to the vector bit-size
- Throws:
-
IllegalArgumentException
- if no such vector shape exists - See Also:
forIndexBitSize
public static VectorShape forIndexBitSize(int indexBitSize, int elementSize)
- Parameters:
-
indexBitSize
- the proposed index vector size in bits -
elementSize
- the proposed element size in bits - Returns:
- a shape corresponding to the index vector bit-size and element size.
- Throws:
-
IllegalArgumentException
- if no such vector shape exists - See Also:
preferredShape
public static VectorShape preferredShape()
The preferred shape by the platform has the largest possible bit-size, under the constraint that all lane sizes are supported, from byte
to double
. Thus, all the preferred vector species for various lane types will have a common underlying shape.
- Returns:
- a preferred shape for all element types
- Throws:
-
UnsupportedOperationException
- if no such shape exists - See Also:
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/jdk.incubator.vector/jdk/incubator/vector/VectorShape.html