MalwareSourceCode/MSIL/Trojan-Ransom/Win32/G/Trojan-Ransom.Win32.Gimemo.ayt-624a52079bf1703bcd3bcc9d2d3716b6126fd05655e25289d19142f9aae02eb5/Compression/RangeCoder/BitTreeEncoder.cs

118 lines
3.2 KiB
C#
Raw Normal View History

2022-08-18 11:28:56 +00:00
// Decompiled with JetBrains decompiler
// Type: SevenZip.Compression.RangeCoder.BitTreeEncoder
// Assembly: P4CTEMP, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
// MVID: 7BE4E538-8555-4C2E-974B-99E556F5462C
// Assembly location: C:\Users\Administrateur\Downloads\Virusshare-00000-msil\Trojan-Ransom.Win32.Gimemo.ayt-624a52079bf1703bcd3bcc9d2d3716b6126fd05655e25289d19142f9aae02eb5.exe
using System;
namespace SevenZip.Compression.RangeCoder
{
internal struct BitTreeEncoder
{
private BitEncoder[] Models;
private int NumBitLevels;
public BitTreeEncoder(int numBitLevels)
{
this.NumBitLevels = numBitLevels;
this.Models = new BitEncoder[1 << numBitLevels];
}
public void Init()
{
for (uint index = 1; (long) index < (long) (1 << this.NumBitLevels); ++index)
this.Models[(IntPtr) index].Init();
}
public void Encode(Encoder rangeEncoder, uint symbol)
{
uint index = 1;
int numBitLevels = this.NumBitLevels;
while (numBitLevels > 0)
{
--numBitLevels;
uint symbol1 = symbol >> numBitLevels & 1U;
this.Models[(IntPtr) index].Encode(rangeEncoder, symbol1);
index = index << 1 | symbol1;
}
}
public void ReverseEncode(Encoder rangeEncoder, uint symbol)
{
uint index1 = 1;
for (uint index2 = 0; (long) index2 < (long) this.NumBitLevels; ++index2)
{
uint symbol1 = symbol & 1U;
this.Models[(IntPtr) index1].Encode(rangeEncoder, symbol1);
index1 = index1 << 1 | symbol1;
symbol >>= 1;
}
}
public uint GetPrice(uint symbol)
{
uint price = 0;
uint index = 1;
int numBitLevels = this.NumBitLevels;
while (numBitLevels > 0)
{
--numBitLevels;
uint symbol1 = symbol >> numBitLevels & 1U;
price += this.Models[(IntPtr) index].GetPrice(symbol1);
index = (index << 1) + symbol1;
}
return price;
}
public uint ReverseGetPrice(uint symbol)
{
uint price = 0;
uint index = 1;
for (int numBitLevels = this.NumBitLevels; numBitLevels > 0; --numBitLevels)
{
uint symbol1 = symbol & 1U;
symbol >>= 1;
price += this.Models[(IntPtr) index].GetPrice(symbol1);
index = index << 1 | symbol1;
}
return price;
}
public static uint ReverseGetPrice(
BitEncoder[] Models,
uint startIndex,
int NumBitLevels,
uint symbol)
{
uint price = 0;
uint num = 1;
for (int index = NumBitLevels; index > 0; --index)
{
uint symbol1 = symbol & 1U;
symbol >>= 1;
price += Models[(IntPtr) (startIndex + num)].GetPrice(symbol1);
num = num << 1 | symbol1;
}
return price;
}
public static void ReverseEncode(
BitEncoder[] Models,
uint startIndex,
Encoder rangeEncoder,
int NumBitLevels,
uint symbol)
{
uint num = 1;
for (int index = 0; index < NumBitLevels; ++index)
{
uint symbol1 = symbol & 1U;
Models[(IntPtr) (startIndex + num)].Encode(rangeEncoder, symbol1);
num = num << 1 | symbol1;
symbol >>= 1;
}
}
}
}