Examples of MemorySegment


Examples of org.apache.flink.core.memory.MemorySegment

    try {
      TypeComparator<T> comparator = getComparator(true);
      T[] data = getSortedData();
      int normKeyLen = getNormKeyLen(halfLength, data, comparator);

      MemorySegment memSeg1 = setupNormalizedKeysMemSegment(data, normKeyLen, comparator);
      MemorySegment memSeg2 = setupNormalizedKeysMemSegment(data, normKeyLen, comparator);

      for (int i = 0; i < data.length; i++) {
        assertTrue(MemorySegment.compare(memSeg1, memSeg2, i * normKeyLen, i * normKeyLen, normKeyLen) == 0);
      }
    } catch (Exception e) {
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

      T[] data = getSortedData();
      // Get the normKeyLen on which we are testing
      int normKeyLen = getNormKeyLen(halfLength, data, comparator);

      // Write the data into different 2 memory segements
      MemorySegment memSegLow = setupNormalizedKeysMemSegment(data, normKeyLen, comparator);
      MemorySegment memSegHigh = setupNormalizedKeysMemSegment(data, normKeyLen, comparator);

      boolean fullyDetermines = !comparator.isNormalizedKeyPrefixOnly(normKeyLen);
     
      // Compare every element with every bigger element
      for (int l = 0; l < data.length - 1; l++) {
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    final int segmentOffsetI = (i % this.recordsPerSegment) * this.recordSize;
   
    final int bufferNumJ = j / this.recordsPerSegment;
    final int segmentOffsetJ = (j % this.recordsPerSegment) * this.recordSize;
   
    final MemorySegment segI = this.sortBuffer.get(bufferNumI);
    final MemorySegment segJ = this.sortBuffer.get(bufferNumJ);
   
    int val = MemorySegment.compare(segI, segJ, segmentOffsetI, segmentOffsetJ, this.numKeyBytes);
    return this.useNormKeyUninverted ? val : -val;
  }
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    final int segmentOffsetI = (i % this.recordsPerSegment) * this.recordSize;
   
    final int bufferNumJ = j / this.recordsPerSegment;
    final int segmentOffsetJ = (j % this.recordsPerSegment) * this.recordSize;
   
    final MemorySegment segI = this.sortBuffer.get(bufferNumI);
    final MemorySegment segJ = this.sortBuffer.get(bufferNumJ);
   
    MemorySegment.swapBytes(segI, segJ, this.swapBuffer, segmentOffsetI, segmentOffsetJ, this.recordSize);
  }
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    final int recordsPerSegment = this.recordsPerSegment;
    int recordsLeft = this.numRecords;
    int currentMemSeg = 0;
   
    while (recordsLeft > 0) {
      final MemorySegment currentIndexSegment = this.sortBuffer.get(currentMemSeg++);
      inView.set(currentIndexSegment, 0);
     
      // check whether we have a full or partially full segment
      if (recordsLeft >= recordsPerSegment) {
        // full segment
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    final int recordsPerSegment = this.recordsPerSegment;
    int currentMemSeg = start / recordsPerSegment;
    int offset = (start % recordsPerSegment) * this.recordSize;
   
    while (num > 0) {
      final MemorySegment currentIndexSegment = this.sortBuffer.get(currentMemSeg++);
      inView.set(currentIndexSegment, offset);
     
      // check whether we have a full or partially full segment
      if (num >= recordsPerSegment && offset == 0) {
        // full segment
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    final int segmentOffsetI = (i % this.indexEntriesPerSegment) * this.indexEntrySize;
   
    final int bufferNumJ = j / this.indexEntriesPerSegment;
    final int segmentOffsetJ = (j % this.indexEntriesPerSegment) * this.indexEntrySize;
   
    final MemorySegment segI = this.sortIndex.get(bufferNumI);
    final MemorySegment segJ = this.sortIndex.get(bufferNumJ);
   
    int val = MemorySegment.compare(segI, segJ, segmentOffsetI + OFFSET_LEN, segmentOffsetJ + OFFSET_LEN, this.numKeyBytes);
   
    if (val != 0 || this.normalizedKeyFullyDetermines) {
      return this.useNormKeyUninverted ? val : -val;
    }
   
    final long pointerI = segI.getLong(segmentOffsetI);
    final long pointerJ = segJ.getLong(segmentOffsetJ);
   
    return compareRecords(pointerI, pointerJ);
  }
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    final int segmentOffsetI = (i % this.indexEntriesPerSegment) * this.indexEntrySize;
   
    final int bufferNumJ = j / this.indexEntriesPerSegment;
    final int segmentOffsetJ = (j % this.indexEntriesPerSegment) * this.indexEntrySize;
   
    final MemorySegment segI = this.sortIndex.get(bufferNumI);
    final MemorySegment segJ = this.sortIndex.get(bufferNumJ);
   
    MemorySegment.swapBytes(segI, segJ, this.swapBuffer, segmentOffsetI, segmentOffsetJ, this.indexEntrySize);
  }
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

  public void writeToOutput(final ChannelWriterOutputView output) throws IOException {
    int recordsLeft = this.numRecords;
    int currentMemSeg = 0;
    while (recordsLeft > 0)
    {
      final MemorySegment currentIndexSegment = this.sortIndex.get(currentMemSeg++);
      int offset = 0;
      // check whether we have a full or partially full segment
      if (recordsLeft >= this.indexEntriesPerSegment) {
        // full segment
        for (;offset <= this.lastIndexEntryOffset; offset += this.indexEntrySize) {
          final long pointer = currentIndexSegment.getLong(offset);
          this.recordBuffer.setReadPosition(pointer);
          this.serializer.copy(this.recordBuffer, output);
         
        }
        recordsLeft -= this.indexEntriesPerSegment;
      } else {
        // partially filled segment
        for (; recordsLeft > 0; recordsLeft--, offset += this.indexEntrySize)
        {
          final long pointer = currentIndexSegment.getLong(offset);
          this.recordBuffer.setReadPosition(pointer);
          this.serializer.copy(this.recordBuffer, output);
        }
      }
    }
View Full Code Here

Examples of org.apache.flink.core.memory.MemorySegment

    int currentMemSeg = start / this.indexEntriesPerSegment;
    int offset = (start % this.indexEntriesPerSegment) * this.indexEntrySize;
   
    while (num > 0)
    {
      final MemorySegment currentIndexSegment = this.sortIndex.get(currentMemSeg++);
      // check whether we have a full or partially full segment
      if (num >= this.indexEntriesPerSegment && offset == 0) {
        // full segment
        for (;offset <= this.lastIndexEntryOffset; offset += this.indexEntrySize) {
          final long pointer = currentIndexSegment.getLong(offset);
          this.recordBuffer.setReadPosition(pointer);
          this.serializer.copy(this.recordBuffer, output);
        }
        num -= this.indexEntriesPerSegment;
      } else {
        // partially filled segment
        for (; num > 0 && offset <= this.lastIndexEntryOffset; num--, offset += this.indexEntrySize)
        {
          final long pointer = currentIndexSegment.getLong(offset);
          this.recordBuffer.setReadPosition(pointer);
          this.serializer.copy(this.recordBuffer, output);
        }
      }
      offset = 0;
View Full Code Here
TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.