當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript encode_common.ts類代碼示例

本文整理匯總了TypeScript中neuroglancer/sliceview/compressed_segmentation/encode_common.ts的典型用法代碼示例。如果您正苦於以下問題:TypeScript ts類的具體用法?TypeScript ts怎麽用?TypeScript ts使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了ts類的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: encodeBlock

export function encodeBlock(
    rawData: Uint32Array, inputOffset: number, inputStrides: ArrayLike<number>,
    blockSize: ArrayLike<number>, actualSize: ArrayLike<number>, baseOffset: number,
    cache: Map<string, number>, output: Uint32ArrayBuilder): [number, number] {
  const ax = actualSize[0], ay = actualSize[1], az = actualSize[2];
  const bx = blockSize[0], by = blockSize[1], bz = blockSize[2];
  let sx = inputStrides[0], sy = inputStrides[1], sz = inputStrides[2];
  sz -= sy * ay;
  sy -= sx * ax;
  if (ax * ay * az === 0) {
    return [0, 0];
  }

  let numBlockElements = bx * by * bz + 31; // Add padding elements.
  if (tempEncodingBuffer === undefined || tempEncodingBuffer.length < numBlockElements) {
    tempEncodingBuffer = new Uint32Array(numBlockElements);
    tempValuesBuffer1 = new Uint32Array(numBlockElements * uint32sPerElement);
    tempValuesBuffer2 = new Uint32Array(numBlockElements * uint32sPerElement);
    tempIndexBuffer1 = new Uint32Array(numBlockElements);
    tempIndexBuffer2 = new Uint32Array(numBlockElements);
  }

  const encodingBuffer = tempEncodingBuffer.subarray(0, numBlockElements);
  encodingBuffer.fill(0);
  const valuesBuffer1 = tempValuesBuffer1;
  const valuesBuffer2 = tempValuesBuffer2;
  const indexBuffer1 = tempIndexBuffer1;
  const indexBuffer2 = tempIndexBuffer2;

  let noAdjacentDuplicateIndex = 0;
  {
    let prevLow = ((rawData[inputOffset] + 1) >>> 0);
    
    let prevHigh = 0;
    
    let curInputOff = inputOffset;
    let blockElementIndex = 0;
    let bsy = bx - ax;
    let bsz = bx * by - bx * ay;
    for (let z = 0; z < az; ++z, curInputOff += sz, blockElementIndex += bsz) {
      for (let y = 0; y < ay; ++y, curInputOff += sy, blockElementIndex += bsy) {
        for (let x = 0; x < ax; ++x, curInputOff += sx) {
          let valueLow = rawData[curInputOff];
          
          let valueHigh = rawData[curInputOff + 1];
          
          if (valueLow !== prevLow
              
              || valueHigh !== prevHigh
              
             ) {
            prevLow = valuesBuffer1[noAdjacentDuplicateIndex * 2] = valueLow;
            
            prevHigh = valuesBuffer1[noAdjacentDuplicateIndex * 2 + 1] = valueHigh;
            
            indexBuffer1[noAdjacentDuplicateIndex] = noAdjacentDuplicateIndex++;
          }
          encodingBuffer[blockElementIndex++] = noAdjacentDuplicateIndex;
        }
      }
    }
  }

  indexBuffer1.subarray(0, noAdjacentDuplicateIndex).sort((a, b) => {
    
    let aHigh = valuesBuffer1[2 * a + 1];
    let bHigh = valuesBuffer1[2 * b + 1];
    let aLow = valuesBuffer1[2 * a];
    let bLow = valuesBuffer1[2 * b];
    return (aHigh - bHigh) || (aLow - bLow);
    
  });

  let numUniqueValues = -1;
  {
    let prevLow = (valuesBuffer1[indexBuffer1[0] * uint32sPerElement] + 1) >>> 0;
    
    let prevHigh = 0;
    
    for (let i = 0; i < noAdjacentDuplicateIndex; ++i) {
      let index = indexBuffer1[i];
      let valueIndex = index * uint32sPerElement;
      let valueLow = valuesBuffer1[valueIndex];
      
      let valueHigh = valuesBuffer1[valueIndex + 1];
      
      if (valueLow !== prevLow
          
          || valueHigh !== prevHigh
          
         ) {
        ++numUniqueValues;
        let outputIndex2 = numUniqueValues * uint32sPerElement;
        prevLow = valuesBuffer2[outputIndex2] = valueLow;
        
        prevHigh = valuesBuffer2[outputIndex2 + 1] = valueHigh;
        
      }
      indexBuffer2[index + 1] = numUniqueValues;
    }
//.........這裏部分代碼省略.........
開發者ID:j6k4m8,項目名稱:neuroglancer,代碼行數:101,代碼來源:encode_uint64.ts

示例2: encodeChannels

export function encodeChannels(
    output: Uint32ArrayBuilder, blockSize: ArrayLike<number>, rawData: Uint32Array,
    volumeSize: ArrayLike<number>, baseInputOffset: number = 0,
    inputStrides = getFortranOrderStrides(volumeSize, 2)) {
  return encodeChannelsCommon(
      output, blockSize, rawData, volumeSize, baseInputOffset, inputStrides, encodeBlock);
}
開發者ID:j6k4m8,項目名稱:neuroglancer,代碼行數:7,代碼來源:encode_uint64.ts


注:本文中的neuroglancer/sliceview/compressed_segmentation/encode_common.ts類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。