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


Java RawErasureDecoder類代碼示例

本文整理匯總了Java中org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder的典型用法代碼示例。如果您正苦於以下問題:Java RawErasureDecoder類的具體用法?Java RawErasureDecoder怎麽用?Java RawErasureDecoder使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


RawErasureDecoder類屬於org.apache.hadoop.io.erasurecode.rawcoder包,在下文中一共展示了RawErasureDecoder類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: prepareDecodingStep

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
@Override
protected ErasureCodingStep prepareDecodingStep(
        final ECBlockGroup blockGroup) {

  RawErasureDecoder rawDecoder;
  RawErasureEncoder rawEncoder;

  ECBlock[] inputBlocks = getInputBlocks(blockGroup);
  ECBlock[] outputBlocks = getOutputBlocks(blockGroup);

  rawDecoder = checkCreateRSRawDecoder();
  rawEncoder = checkCreateXorRawEncoder();

  return new HHXORErasureDecodingStep(inputBlocks,
          getErasedIndexes(inputBlocks), outputBlocks, rawDecoder,
          rawEncoder);
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:18,代碼來源:HHXORErasureDecoder.java

示例2: testRSDefaultRawCoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
@Test
public void testRSDefaultRawCoder() {
  ErasureCoderOptions coderOptions = new ErasureCoderOptions(
      numDataUnit, numParityUnit);
  // should return default raw coder of rs-default codec
  RawErasureEncoder encoder = CodecUtil.createRawEncoder(
      conf, ErasureCodeConstants.RS_DEFAULT_CODEC_NAME, coderOptions);
  Assert.assertTrue(encoder instanceof RSRawEncoder);
  RawErasureDecoder decoder = CodecUtil.createRawDecoder(
      conf, ErasureCodeConstants.RS_DEFAULT_CODEC_NAME, coderOptions);
  Assert.assertTrue(decoder instanceof RSRawDecoder);

  // should return default raw coder of rs-legacy codec
  encoder = CodecUtil.createRawEncoder(conf,
      ErasureCodeConstants.RS_LEGACY_CODEC_NAME, coderOptions);
  Assert.assertTrue(encoder instanceof RSRawEncoderLegacy);
  decoder = CodecUtil.createRawDecoder(conf,
      ErasureCodeConstants.RS_LEGACY_CODEC_NAME, coderOptions);
  Assert.assertTrue(decoder instanceof RSRawDecoderLegacy);
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:21,代碼來源:TestCodecRawCoderMapping.java

示例3: HHXORErasureDecodingStep

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
/**
 * The constructor with all the necessary info.
 * @param inputBlocks
 * @param erasedIndexes the indexes of erased blocks in inputBlocks array
 * @param outputBlocks
 * @param rawDecoder underlying RS decoder for hitchhiker decoding
 * @param rawEncoder underlying XOR encoder for hitchhiker decoding
 */
public HHXORErasureDecodingStep(ECBlock[] inputBlocks, int[] erasedIndexes,
    ECBlock[] outputBlocks, RawErasureDecoder rawDecoder,
    RawErasureEncoder rawEncoder) {
  super(inputBlocks, outputBlocks);
  this.pbIndex = rawDecoder.getNumParityUnits() - 1;
  this.erasedIndexes = erasedIndexes;
  this.rsRawDecoder = rawDecoder;
  this.xorRawEncoder = rawEncoder;

  this.piggyBackIndex = HHUtil.initPiggyBackIndexWithoutPBVec(
      rawDecoder.getNumDataUnits(), rawDecoder.getNumParityUnits());
  this.piggyBackFullIndex = HHUtil.initPiggyBackFullIndexVec(
      rawDecoder.getNumDataUnits(), piggyBackIndex);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:23,代碼來源:HHXORErasureDecodingStep.java

示例4: prepareDecodingStep

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
@Override
protected ErasureCodingStep prepareDecodingStep(
    final ECBlockGroup blockGroup) {
  RawErasureDecoder rawDecoder = CodecUtil.createXORRawDecoder(getConf(),
      getNumDataUnits(), getNumParityUnits());

  ECBlock[] inputBlocks = getInputBlocks(blockGroup);

  return new ErasureDecodingStep(inputBlocks,
      getErasedIndexes(inputBlocks),
      getOutputBlocks(blockGroup), rawDecoder);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:13,代碼來源:XORErasureDecoder.java

示例5: ErasureDecodingStep

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
/**
 * The constructor with all the necessary info.
 * @param inputBlocks
 * @param erasedIndexes the indexes of erased blocks in inputBlocks array
 * @param outputBlocks
 * @param rawDecoder
 */
public ErasureDecodingStep(ECBlock[] inputBlocks, int[] erasedIndexes,
                           ECBlock[] outputBlocks,
                           RawErasureDecoder rawDecoder) {
  super(inputBlocks, outputBlocks);
  this.erasedIndexes = erasedIndexes;
  this.rawDecoder = rawDecoder;
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:15,代碼來源:ErasureDecodingStep.java

示例6: prepareDecodingStep

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
@Override
protected ErasureCodingStep prepareDecodingStep(final ECBlockGroup blockGroup) {

  ECBlock[] inputBlocks = getInputBlocks(blockGroup);
  ECBlock[] outputBlocks = getOutputBlocks(blockGroup);

  RawErasureDecoder rawDecoder = checkCreateRSRawDecoder();
  return new ErasureDecodingStep(inputBlocks,
      getErasedIndexes(inputBlocks), outputBlocks, rawDecoder);
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:11,代碼來源:RSErasureDecoder.java

示例7: checkCreateRSRawDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
private RawErasureDecoder checkCreateRSRawDecoder() {
  if (rsRawDecoder == null) {
    rsRawDecoder = CodecUtil.createRSRawDecoder(getConf(),
        getNumDataUnits(), getNumParityUnits());
  }
  return rsRawDecoder;
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:8,代碼來源:RSErasureDecoder.java

示例8: createRSRawDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
/**
 * Create RS raw decoder according to configuration.
 * @param conf configuration possibly with some items to configure the coder
 * @param numDataUnits number of data units in a coding group
 * @param numParityUnits number of parity units in a coding group
 * @return raw decoder
 */
public static RawErasureDecoder createRSRawDecoder(
    Configuration conf, int numDataUnits, int numParityUnits) {
  RawErasureCoder rawCoder = createRawCoder(conf,
      CommonConfigurationKeys.IO_ERASURECODE_CODEC_RS_RAWCODER_KEY,
      false, numDataUnits, numParityUnits);
  if (rawCoder == null) {
    rawCoder = new RSRawDecoder(numDataUnits, numParityUnits);
  }

  return (RawErasureDecoder) rawCoder;
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:19,代碼來源:CodecUtil.java

示例9: createXORRawDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
/**
 * Create XOR raw decoder according to configuration.
 * @param conf configuration possibly with some items to configure the coder
 * @param numDataUnits number of data units in a coding group
 * @param numParityUnits number of parity units in a coding group
 * @return raw decoder
 */
public static RawErasureDecoder createXORRawDecoder(
    Configuration conf, int numDataUnits, int numParityUnits) {
  RawErasureCoder rawCoder = createRawCoder(conf,
      CommonConfigurationKeys.IO_ERASURECODE_CODEC_XOR_RAWCODER_KEY,
      false, numDataUnits, numParityUnits);
  if (rawCoder == null) {
    rawCoder = new XORRawDecoder(numDataUnits, numParityUnits);
  }

  return (RawErasureDecoder) rawCoder;
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:19,代碼來源:CodecUtil.java

示例10: decodeAndFillBuffer

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
/**
 * Decode based on the given input buffers and erasure coding policy.
 */
public static void decodeAndFillBuffer(final byte[][] decodeInputs,
    AlignedStripe alignedStripe, int dataBlkNum, int parityBlkNum,
    RawErasureDecoder decoder) {
  // Step 1: prepare indices and output buffers for missing data units
  int[] decodeIndices = new int[parityBlkNum];
  int pos = 0;
  for (int i = 0; i < dataBlkNum; i++) {
    if (alignedStripe.chunks[i] != null &&
        alignedStripe.chunks[i].state == StripingChunk.MISSING){
      decodeIndices[pos++] = i;
    }
  }
  decodeIndices = Arrays.copyOf(decodeIndices, pos);
  byte[][] decodeOutputs =
      new byte[decodeIndices.length][(int) alignedStripe.getSpanInBlock()];

  // Step 2: decode into prepared output buffers
  decoder.decode(decodeInputs, decodeIndices, decodeOutputs);

  // Step 3: fill original application buffer with decoded data
  for (int i = 0; i < decodeIndices.length; i++) {
    int missingBlkIdx = decodeIndices[i];
    StripingChunk chunk = alignedStripe.chunks[missingBlkIdx];
    if (chunk.state == StripingChunk.MISSING) {
      chunk.copyFrom(decodeOutputs[i]);
    }
  }
}
 
開發者ID:aliyun-beta,項目名稱:aliyun-oss-hadoop-fs,代碼行數:32,代碼來源:StripedBlockUtil.java

示例11: checkCreateRSRawDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
private RawErasureDecoder checkCreateRSRawDecoder() {
  if (rsRawDecoder == null) {
    ErasureCoderOptions coderOptions = new ErasureCoderOptions(
        getNumDataUnits(), getNumParityUnits());
    rsRawDecoder = CodecUtil.createRawDecoder(getConf(),
            ErasureCodeConstants.RS_DEFAULT_CODEC_NAME, coderOptions);
  }
  return rsRawDecoder;
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:10,代碼來源:HHXORErasureDecoder.java

示例12: prepareDecodingStep

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
@Override
protected ErasureCodingStep prepareDecodingStep(
    final ECBlockGroup blockGroup) {
  ErasureCoderOptions coderOptions = new ErasureCoderOptions(
      getNumDataUnits(), getNumParityUnits());
  RawErasureDecoder rawDecoder = CodecUtil.createRawDecoder(getConf(),
      ErasureCodeConstants.XOR_CODEC_NAME, coderOptions);

  ECBlock[] inputBlocks = getInputBlocks(blockGroup);

  return new ErasureDecodingStep(inputBlocks,
      getErasedIndexes(inputBlocks),
      getOutputBlocks(blockGroup), rawDecoder);
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:15,代碼來源:XORErasureDecoder.java

示例13: checkCreateRSRawDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
private RawErasureDecoder checkCreateRSRawDecoder() {
  if (rsRawDecoder == null) {
    // TODO: we should create the raw coder according to codec.
    ErasureCoderOptions coderOptions = new ErasureCoderOptions(
        getNumDataUnits(), getNumParityUnits());
    rsRawDecoder = CodecUtil.createRawDecoder(getConf(),
        ErasureCodeConstants.RS_DEFAULT_CODEC_NAME, coderOptions);
  }
  return rsRawDecoder;
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:11,代碼來源:RSErasureDecoder.java

示例14: createRawDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
/**
 * Create RS raw decoder according to configuration.
 * @param conf configuration
 * @param coderOptions coder options that's used to create the coder
 * @param codec the codec to use. If null, will use the default codec
 * @return raw decoder
 */
public static RawErasureDecoder createRawDecoder(
    Configuration conf, String codec, ErasureCoderOptions coderOptions) {
  Preconditions.checkNotNull(conf);
  Preconditions.checkNotNull(codec);

  String rawCoderFactoryKey = getFactNameFromCodec(conf, codec);

  RawErasureCoderFactory fact = createRawCoderFactory(conf,
      rawCoderFactoryKey);

  return fact.createDecoder(coderOptions);
}
 
開發者ID:hopshadoop,項目名稱:hops,代碼行數:20,代碼來源:CodecUtil.java

示例15: newDecoder

import org.apache.hadoop.io.erasurecode.rawcoder.RawErasureDecoder; //導入依賴的package包/類
private RawErasureDecoder newDecoder(int numDataUnits, int numParityUnits) {
  return CodecUtil.createRSRawDecoder(conf, numDataUnits, numParityUnits);
}
 
開發者ID:aliyun-beta,項目名稱:aliyun-oss-hadoop-fs,代碼行數:4,代碼來源:ErasureCodingWorker.java


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