Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
JDK 17 jdk.incubator.vector.jmod - JDK Incubator Vector
JDK 17 jdk.incubator.vector.jmod is the JMOD file for JDK 17 HTTP Server module.
JDK 17 Incubator Vector module compiled class files are stored in \fyicenter\jdk-17.0.5\jmods\jdk.incubator.vector.jmod.
JDK 17 Incubator Vector module compiled class files are also linked and stored in the \fyicenter\jdk-17.0.5\lib\modules JImage file.
JDK 17 Incubator Vector module source code files are stored in \fyicenter\jdk-17.0.5\lib\src.zip\jdk.incubator.vector.
You can click and view the content of each source code file in the list below.
✍: FYIcenter
⏎ jdk/incubator/vector/Int512Vector.java
/* * Copyright (c) 2017, 2021, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package jdk.incubator.vector; import java.nio.ByteBuffer; import java.util.Arrays; import java.util.Objects; import java.util.function.IntUnaryOperator; import jdk.internal.vm.annotation.ForceInline; import jdk.internal.vm.vector.VectorSupport; import static jdk.internal.vm.vector.VectorSupport.*; import static jdk.incubator.vector.VectorOperators.*; // -- This file was mechanically generated: Do not edit! -- // @SuppressWarnings("cast") // warning: redundant cast final class Int512Vector extends IntVector { static final IntSpecies VSPECIES = (IntSpecies) IntVector.SPECIES_512; static final VectorShape VSHAPE = VSPECIES.vectorShape(); static final Class<Int512Vector> VCLASS = Int512Vector.class; static final int VSIZE = VSPECIES.vectorBitSize(); static final int VLENGTH = VSPECIES.laneCount(); // used by the JVM static final Class<Integer> ETYPE = int.class; // used by the JVM Int512Vector(int[] v) { super(v); } // For compatibility as Int512Vector::new, // stored into species.vectorFactory. Int512Vector(Object v) { this((int[]) v); } static final Int512Vector ZERO = new Int512Vector(new int[VLENGTH]); static final Int512Vector IOTA = new Int512Vector(VSPECIES.iotaArray()); static { // Warm up a few species caches. // If we do this too much we will // get NPEs from bootstrap circularity. VSPECIES.dummyVector(); VSPECIES.withLanes(LaneType.BYTE); } // Specialized extractors @ForceInline final @Override public IntSpecies vspecies() { // ISSUE: This should probably be a @Stable // field inside AbstractVector, rather than // a megamorphic method. return VSPECIES; } @ForceInline @Override public final Class<Integer> elementType() { return int.class; } @ForceInline @Override public final int elementSize() { return Integer.SIZE; } @ForceInline @Override public final VectorShape shape() { return VSHAPE; } @ForceInline @Override public final int length() { return VLENGTH; } @ForceInline @Override public final int bitSize() { return VSIZE; } @ForceInline @Override public final int byteSize() { return VSIZE / Byte.SIZE; } /*package-private*/ @ForceInline final @Override int[] vec() { return (int[])getPayload(); } // Virtualized constructors @Override @ForceInline public final Int512Vector broadcast(int e) { return (Int512Vector) super.broadcastTemplate(e); // specialize } @Override @ForceInline public final Int512Vector broadcast(long e) { return (Int512Vector) super.broadcastTemplate(e); // specialize } @Override @ForceInline Int512Mask maskFromArray(boolean[] bits) { return new Int512Mask(bits); } @Override @ForceInline Int512Shuffle iotaShuffle() { return Int512Shuffle.IOTA; } @ForceInline Int512Shuffle iotaShuffle(int start, int step, boolean wrap) { if (wrap) { return (Int512Shuffle)VectorSupport.shuffleIota(ETYPE, Int512Shuffle.class, VSPECIES, VLENGTH, start, step, 1, (l, lstart, lstep, s) -> s.shuffleFromOp(i -> (VectorIntrinsics.wrapToRange(i*lstep + lstart, l)))); } else { return (Int512Shuffle)VectorSupport.shuffleIota(ETYPE, Int512Shuffle.class, VSPECIES, VLENGTH, start, step, 0, (l, lstart, lstep, s) -> s.shuffleFromOp(i -> (i*lstep + lstart))); } } @Override @ForceInline Int512Shuffle shuffleFromBytes(byte[] reorder) { return new Int512Shuffle(reorder); } @Override @ForceInline Int512Shuffle shuffleFromArray(int[] indexes, int i) { return new Int512Shuffle(indexes, i); } @Override @ForceInline Int512Shuffle shuffleFromOp(IntUnaryOperator fn) { return new Int512Shuffle(fn); } // Make a vector of the same species but the given elements: @ForceInline final @Override Int512Vector vectorFactory(int[] vec) { return new Int512Vector(vec); } @ForceInline final @Override Byte512Vector asByteVectorRaw() { return (Byte512Vector) super.asByteVectorRawTemplate(); // specialize } @ForceInline final @Override AbstractVector<?> asVectorRaw(LaneType laneType) { return super.asVectorRawTemplate(laneType); // specialize } // Unary operator @ForceInline final @Override Int512Vector uOp(FUnOp f) { return (Int512Vector) super.uOpTemplate(f); // specialize } @ForceInline final @Override Int512Vector uOp(VectorMask<Integer> m, FUnOp f) { return (Int512Vector) super.uOpTemplate((Int512Mask)m, f); // specialize } // Binary operator @ForceInline final @Override Int512Vector bOp(Vector<Integer> v, FBinOp f) { return (Int512Vector) super.bOpTemplate((Int512Vector)v, f); // specialize } @ForceInline final @Override Int512Vector bOp(Vector<Integer> v, VectorMask<Integer> m, FBinOp f) { return (Int512Vector) super.bOpTemplate((Int512Vector)v, (Int512Mask)m, f); // specialize } // Ternary operator @ForceInline final @Override Int512Vector tOp(Vector<Integer> v1, Vector<Integer> v2, FTriOp f) { return (Int512Vector) super.tOpTemplate((Int512Vector)v1, (Int512Vector)v2, f); // specialize } @ForceInline final @Override Int512Vector tOp(Vector<Integer> v1, Vector<Integer> v2, VectorMask<Integer> m, FTriOp f) { return (Int512Vector) super.tOpTemplate((Int512Vector)v1, (Int512Vector)v2, (Int512Mask)m, f); // specialize } @ForceInline final @Override int rOp(int v, FBinOp f) { return super.rOpTemplate(v, f); // specialize } @Override @ForceInline public final <F> Vector<F> convertShape(VectorOperators.Conversion<Integer,F> conv, VectorSpecies<F> rsp, int part) { return super.convertShapeTemplate(conv, rsp, part); // specialize } @Override @ForceInline public final <F> Vector<F> reinterpretShape(VectorSpecies<F> toSpecies, int part) { return super.reinterpretShapeTemplate(toSpecies, part); // specialize } // Specialized algebraic operations: // The following definition forces a specialized version of this // crucial method into the v-table of this class. A call to add() // will inline to a call to lanewise(ADD,), at which point the JIT // intrinsic will have the opcode of ADD, plus all the metadata // for this particular class, enabling it to generate precise // code. // // There is probably no benefit to the JIT to specialize the // masked or broadcast versions of the lanewise method. @Override @ForceInline public Int512Vector lanewise(Unary op) { return (Int512Vector) super.lanewiseTemplate(op); // specialize } @Override @ForceInline public Int512Vector lanewise(Binary op, Vector<Integer> v) { return (Int512Vector) super.lanewiseTemplate(op, v); // specialize } /*package-private*/ @Override @ForceInline Int512Vector lanewiseShift(VectorOperators.Binary op, int e) { return (Int512Vector) super.lanewiseShiftTemplate(op, e); // specialize } /*package-private*/ @Override @ForceInline public final Int512Vector lanewise(VectorOperators.Ternary op, Vector<Integer> v1, Vector<Integer> v2) { return (Int512Vector) super.lanewiseTemplate(op, v1, v2); // specialize } @Override @ForceInline public final Int512Vector addIndex(int scale) { return (Int512Vector) super.addIndexTemplate(scale); // specialize } // Type specific horizontal reductions @Override @ForceInline public final int reduceLanes(VectorOperators.Associative op) { return super.reduceLanesTemplate(op); // specialized } @Override @ForceInline public final int reduceLanes(VectorOperators.Associative op, VectorMask<Integer> m) { return super.reduceLanesTemplate(op, m); // specialized } @Override @ForceInline public final long reduceLanesToLong(VectorOperators.Associative op) { return (long) super.reduceLanesTemplate(op); // specialized } @Override @ForceInline public final long reduceLanesToLong(VectorOperators.Associative op, VectorMask<Integer> m) { return (long) super.reduceLanesTemplate(op, m); // specialized } @ForceInline public VectorShuffle<Integer> toShuffle() { return super.toShuffleTemplate(Int512Shuffle.class); // specialize } // Specialized unary testing @Override @ForceInline public final Int512Mask test(Test op) { return super.testTemplate(Int512Mask.class, op); // specialize } // Specialized comparisons @Override @ForceInline public final Int512Mask compare(Comparison op, Vector<Integer> v) { return super.compareTemplate(Int512Mask.class, op, v); // specialize } @Override @ForceInline public final Int512Mask compare(Comparison op, int s) { return super.compareTemplate(Int512Mask.class, op, s); // specialize } @Override @ForceInline public final Int512Mask compare(Comparison op, long s) { return super.compareTemplate(Int512Mask.class, op, s); // specialize } @Override @ForceInline public Int512Vector blend(Vector<Integer> v, VectorMask<Integer> m) { return (Int512Vector) super.blendTemplate(Int512Mask.class, (Int512Vector) v, (Int512Mask) m); // specialize } @Override @ForceInline public Int512Vector slice(int origin, Vector<Integer> v) { return (Int512Vector) super.sliceTemplate(origin, v); // specialize } @Override @ForceInline public Int512Vector slice(int origin) { return (Int512Vector) super.sliceTemplate(origin); // specialize } @Override @ForceInline public Int512Vector unslice(int origin, Vector<Integer> w, int part) { return (Int512Vector) super.unsliceTemplate(origin, w, part); // specialize } @Override @ForceInline public Int512Vector unslice(int origin, Vector<Integer> w, int part, VectorMask<Integer> m) { return (Int512Vector) super.unsliceTemplate(Int512Mask.class, origin, w, part, (Int512Mask) m); // specialize } @Override @ForceInline public Int512Vector unslice(int origin) { return (Int512Vector) super.unsliceTemplate(origin); // specialize } @Override @ForceInline public Int512Vector rearrange(VectorShuffle<Integer> s) { return (Int512Vector) super.rearrangeTemplate(Int512Shuffle.class, (Int512Shuffle) s); // specialize } @Override @ForceInline public Int512Vector rearrange(VectorShuffle<Integer> shuffle, VectorMask<Integer> m) { return (Int512Vector) super.rearrangeTemplate(Int512Shuffle.class, (Int512Shuffle) shuffle, (Int512Mask) m); // specialize } @Override @ForceInline public Int512Vector rearrange(VectorShuffle<Integer> s, Vector<Integer> v) { return (Int512Vector) super.rearrangeTemplate(Int512Shuffle.class, (Int512Shuffle) s, (Int512Vector) v); // specialize } @Override @ForceInline public Int512Vector selectFrom(Vector<Integer> v) { return (Int512Vector) super.selectFromTemplate((Int512Vector) v); // specialize } @Override @ForceInline public Int512Vector selectFrom(Vector<Integer> v, VectorMask<Integer> m) { return (Int512Vector) super.selectFromTemplate((Int512Vector) v, (Int512Mask) m); // specialize } @ForceInline @Override public int lane(int i) { switch(i) { case 0: return laneHelper(0); case 1: return laneHelper(1); case 2: return laneHelper(2); case 3: return laneHelper(3); case 4: return laneHelper(4); case 5: return laneHelper(5); case 6: return laneHelper(6); case 7: return laneHelper(7); case 8: return laneHelper(8); case 9: return laneHelper(9); case 10: return laneHelper(10); case 11: return laneHelper(11); case 12: return laneHelper(12); case 13: return laneHelper(13); case 14: return laneHelper(14); case 15: return laneHelper(15); default: throw new IllegalArgumentException("Index " + i + " must be zero or positive, and less than " + VLENGTH); } } public int laneHelper(int i) { return (int) VectorSupport.extract( VCLASS, ETYPE, VLENGTH, this, i, (vec, ix) -> { int[] vecarr = vec.vec(); return (long)vecarr[ix]; }); } @ForceInline @Override public Int512Vector withLane(int i, int e) { switch (i) { case 0: return withLaneHelper(0, e); case 1: return withLaneHelper(1, e); case 2: return withLaneHelper(2, e); case 3: return withLaneHelper(3, e); case 4: return withLaneHelper(4, e); case 5: return withLaneHelper(5, e); case 6: return withLaneHelper(6, e); case 7: return withLaneHelper(7, e); case 8: return withLaneHelper(8, e); case 9: return withLaneHelper(9, e); case 10: return withLaneHelper(10, e); case 11: return withLaneHelper(11, e); case 12: return withLaneHelper(12, e); case 13: return withLaneHelper(13, e); case 14: return withLaneHelper(14, e); case 15: return withLaneHelper(15, e); default: throw new IllegalArgumentException("Index " + i + " must be zero or positive, and less than " + VLENGTH); } } public Int512Vector withLaneHelper(int i, int e) { return VectorSupport.insert( VCLASS, ETYPE, VLENGTH, this, i, (long)e, (v, ix, bits) -> { int[] res = v.vec().clone(); res[ix] = (int)bits; return v.vectorFactory(res); }); } // Mask static final class Int512Mask extends AbstractMask<Integer> { static final int VLENGTH = VSPECIES.laneCount(); // used by the JVM static final Class<Integer> ETYPE = int.class; // used by the JVM Int512Mask(boolean[] bits) { this(bits, 0); } Int512Mask(boolean[] bits, int offset) { super(prepare(bits, offset)); } Int512Mask(boolean val) { super(prepare(val)); } private static boolean[] prepare(boolean[] bits, int offset) { boolean[] newBits = new boolean[VSPECIES.laneCount()]; for (int i = 0; i < newBits.length; i++) { newBits[i] = bits[offset + i]; } return newBits; } private static boolean[] prepare(boolean val) { boolean[] bits = new boolean[VSPECIES.laneCount()]; Arrays.fill(bits, val); return bits; } @ForceInline final @Override public IntSpecies vspecies() { // ISSUE: This should probably be a @Stable // field inside AbstractMask, rather than // a megamorphic method. return VSPECIES; } @ForceInline boolean[] getBits() { return (boolean[])getPayload(); } @Override Int512Mask uOp(MUnOp f) { boolean[] res = new boolean[vspecies().laneCount()]; boolean[] bits = getBits(); for (int i = 0; i < res.length; i++) { res[i] = f.apply(i, bits[i]); } return new Int512Mask(res); } @Override Int512Mask bOp(VectorMask<Integer> m, MBinOp f) { boolean[] res = new boolean[vspecies().laneCount()]; boolean[] bits = getBits(); boolean[] mbits = ((Int512Mask)m).getBits(); for (int i = 0; i < res.length; i++) { res[i] = f.apply(i, bits[i], mbits[i]); } return new Int512Mask(res); } @ForceInline @Override public final Int512Vector toVector() { return (Int512Vector) super.toVectorTemplate(); // specialize } /** * Helper function for lane-wise mask conversions. * This function kicks in after intrinsic failure. */ @ForceInline private final <E> VectorMask<E> defaultMaskCast(AbstractSpecies<E> dsp) { if (length() != dsp.laneCount()) throw new IllegalArgumentException("VectorMask length and species length differ"); boolean[] maskArray = toArray(); return dsp.maskFactory(maskArray).check(dsp); } @Override @ForceInline public <E> VectorMask<E> cast(VectorSpecies<E> dsp) { AbstractSpecies<E> species = (AbstractSpecies<E>) dsp; if (length() != species.laneCount()) throw new IllegalArgumentException("VectorMask length and species length differ"); if (VSIZE == species.vectorBitSize()) { Class<?> dtype = species.elementType(); Class<?> dmtype = species.maskType(); return VectorSupport.convert(VectorSupport.VECTOR_OP_REINTERPRET, this.getClass(), ETYPE, VLENGTH, dmtype, dtype, VLENGTH, this, species, Int512Mask::defaultMaskCast); } return this.defaultMaskCast(species); } @Override @ForceInline public Int512Mask eq(VectorMask<Integer> mask) { Objects.requireNonNull(mask); Int512Mask m = (Int512Mask)mask; return xor(m.not()); } // Unary operations @Override @ForceInline public Int512Mask not() { return xor(maskAll(true)); } // Binary operations @Override @ForceInline public Int512Mask and(VectorMask<Integer> mask) { Objects.requireNonNull(mask); Int512Mask m = (Int512Mask)mask; return VectorSupport.binaryOp(VECTOR_OP_AND, Int512Mask.class, int.class, VLENGTH, this, m, (m1, m2) -> m1.bOp(m2, (i, a, b) -> a & b)); } @Override @ForceInline public Int512Mask or(VectorMask<Integer> mask) { Objects.requireNonNull(mask); Int512Mask m = (Int512Mask)mask; return VectorSupport.binaryOp(VECTOR_OP_OR, Int512Mask.class, int.class, VLENGTH, this, m, (m1, m2) -> m1.bOp(m2, (i, a, b) -> a | b)); } @ForceInline /* package-private */ Int512Mask xor(VectorMask<Integer> mask) { Objects.requireNonNull(mask); Int512Mask m = (Int512Mask)mask; return VectorSupport.binaryOp(VECTOR_OP_XOR, Int512Mask.class, int.class, VLENGTH, this, m, (m1, m2) -> m1.bOp(m2, (i, a, b) -> a ^ b)); } // Mask Query operations @Override @ForceInline public int trueCount() { return VectorSupport.maskReductionCoerced(VECTOR_OP_MASK_TRUECOUNT, Int512Mask.class, int.class, VLENGTH, this, (m) -> trueCountHelper(((Int512Mask)m).getBits())); } @Override @ForceInline public int firstTrue() { return VectorSupport.maskReductionCoerced(VECTOR_OP_MASK_FIRSTTRUE, Int512Mask.class, int.class, VLENGTH, this, (m) -> firstTrueHelper(((Int512Mask)m).getBits())); } @Override @ForceInline public int lastTrue() { return VectorSupport.maskReductionCoerced(VECTOR_OP_MASK_LASTTRUE, Int512Mask.class, int.class, VLENGTH, this, (m) -> lastTrueHelper(((Int512Mask)m).getBits())); } // Reductions @Override @ForceInline public boolean anyTrue() { return VectorSupport.test(BT_ne, Int512Mask.class, int.class, VLENGTH, this, vspecies().maskAll(true), (m, __) -> anyTrueHelper(((Int512Mask)m).getBits())); } @Override @ForceInline public boolean allTrue() { return VectorSupport.test(BT_overflow, Int512Mask.class, int.class, VLENGTH, this, vspecies().maskAll(true), (m, __) -> allTrueHelper(((Int512Mask)m).getBits())); } @ForceInline /*package-private*/ static Int512Mask maskAll(boolean bit) { return VectorSupport.broadcastCoerced(Int512Mask.class, int.class, VLENGTH, (bit ? -1 : 0), null, (v, __) -> (v != 0 ? TRUE_MASK : FALSE_MASK)); } private static final Int512Mask TRUE_MASK = new Int512Mask(true); private static final Int512Mask FALSE_MASK = new Int512Mask(false); } // Shuffle static final class Int512Shuffle extends AbstractShuffle<Integer> { static final int VLENGTH = VSPECIES.laneCount(); // used by the JVM static final Class<Integer> ETYPE = int.class; // used by the JVM Int512Shuffle(byte[] reorder) { super(VLENGTH, reorder); } public Int512Shuffle(int[] reorder) { super(VLENGTH, reorder); } public Int512Shuffle(int[] reorder, int i) { super(VLENGTH, reorder, i); } public Int512Shuffle(IntUnaryOperator fn) { super(VLENGTH, fn); } @Override public IntSpecies vspecies() { return VSPECIES; } static { // There must be enough bits in the shuffle lanes to encode // VLENGTH valid indexes and VLENGTH exceptional ones. assert(VLENGTH < Byte.MAX_VALUE); assert(Byte.MIN_VALUE <= -VLENGTH); } static final Int512Shuffle IOTA = new Int512Shuffle(IDENTITY); @Override @ForceInline public Int512Vector toVector() { return VectorSupport.shuffleToVector(VCLASS, ETYPE, Int512Shuffle.class, this, VLENGTH, (s) -> ((Int512Vector)(((AbstractShuffle<Integer>)(s)).toVectorTemplate()))); } @Override @ForceInline public <F> VectorShuffle<F> cast(VectorSpecies<F> s) { AbstractSpecies<F> species = (AbstractSpecies<F>) s; if (length() != species.laneCount()) throw new IllegalArgumentException("VectorShuffle length and species length differ"); int[] shuffleArray = toArray(); return s.shuffleFromArray(shuffleArray, 0).check(s); } @ForceInline @Override public Int512Shuffle rearrange(VectorShuffle<Integer> shuffle) { Int512Shuffle s = (Int512Shuffle) shuffle; byte[] reorder1 = reorder(); byte[] reorder2 = s.reorder(); byte[] r = new byte[reorder1.length]; for (int i = 0; i < reorder1.length; i++) { int ssi = reorder2[i]; r[i] = reorder1[ssi]; // throws on exceptional index } return new Int512Shuffle(r); } } // ================================================ // Specialized low-level memory operations. @ForceInline @Override final IntVector fromArray0(int[] a, int offset) { return super.fromArray0Template(a, offset); // specialize } @ForceInline @Override final IntVector fromByteArray0(byte[] a, int offset) { return super.fromByteArray0Template(a, offset); // specialize } @ForceInline @Override final IntVector fromByteBuffer0(ByteBuffer bb, int offset) { return super.fromByteBuffer0Template(bb, offset); // specialize } @ForceInline @Override final void intoArray0(int[] a, int offset) { super.intoArray0Template(a, offset); // specialize } @ForceInline @Override final void intoByteArray0(byte[] a, int offset) { super.intoByteArray0Template(a, offset); // specialize } // End of specialized low-level memory operations. // ================================================ }
⏎ jdk/incubator/vector/Int512Vector.java
Or download all of them as a single archive file:
File name: jdk.incubator.vector-17.0.5-src.zip File size: 350622 bytes Release date: 2022-09-13 Download
⇒ JDK 17 jdk.internal.ed.jmod - Internal Editor Module
2023-10-04, 4029👍, 0💬
Popular Posts:
MXP1 is a stable XmlPull parsing engine that is based on ideas from XPP and in particular XPP2 but c...
What Is commons-net-ftp-2.0.jar? commons-net-ftp-2.0.jar is the JAR file for Apache Commons Net FTP ...
pache Derby is an open source relational database implemented entirely in Java and available under t...
The Apache FontBox library is an open source Java tool to obtain low level information from font fil...
io.jar is a component in iText Java library to provide input/output functionalities. iText Java libr...