#include <iostream>
#include <vector>
#include <bitset>
#include <math.h>
#include <climits>
using namespace std;
/*
static string ToBinaryString(float value) {
int bitCount = sizeof(float) * 8; // never rely on your knowledge of the size
char[] result = new char[bitCount]; // better not use string, to avoid ineffective string concatenation repeated in a loop
// now, most important thing: (int)value would be "semantic" cast of the same
// mathematical value (with possible rounding), something we don't want; so:
int intValue = System.BitConverter.ToInt32(BitConverter.GetBytes(value), 0);
for (int bit = 0; bit < bitCount; ++bit) {
int maskedValue = intValue & (1 << bit); // this is how shift and mask is done.
if (maskedValue > 0)
maskedValue = 1;
// at this point, masked value is either int 0 or 1
result[bitCount - bit - 1] = maskedValue.ToString()[0]; // bits go right-to-left in usual Western Arabic-based notation
}
return new string(result); // string from character array
}
*/
void print(int* arr, int n) {
for (int i =0;i<n;i++) {
cout << arr[i] << " ";
}
cout << endl;
}
void permuate(int* arr, int size, int n) {
if (size == 1) {
print(arr, n);
} else {
for( int i = 0; i< size; i++) {
permuate(arr, size - 1, n);
cout << "i = " << i << " n = " << size << endl;
if (size%2==1)
swap(arr[0], arr[size-1]);
else
swap(arr[i], arr[size-1]);
}
}
}
void permute(int a[], int i, int n)
{
int j;
cout << "permute " << i << endl;
if (i == n)
print(a, n);
else
{
for (j = i; j < n; j++)
{
swap(a[i], a[j]);
cout << "swap i = " << i << " j = " << j << endl;
permute(a, i+1, n);
swap(a[i], a[j]);
}
cout << "exit " << i << endl;
}
}
// Convert the 32-bit binary encoding into hexadecimal
int Binary2Hex( std::string Binary )
{
std::bitset<32> set(Binary);
int hex = set.to_ulong();
return hex;
}
string GetBinaryFloat(float flo) {
int integral = flo;
float fraction = flo - integral;
int shift = 0;
uint32_t mantissa = 0;
while(integral > 0) {
if (integral % 2 != 0) {
mantissa |= 1 << shift;
}
integral >>= 1;
shift++;
}
uint32_t exponent = 127 + shift -1;
cout << exponent << endl;
cout << mantissa << endl;
cout << bitset<32>(mantissa).to_string() << endl;
mantissa = mantissa & ~(1 << (shift - 1));
cout << mantissa << endl;
cout << bitset<32>(mantissa).to_string() << endl;
while (fraction > 0) {
fraction *= 2;
if ((int)fraction > 0) {
fraction -=1;
mantissa = (mantissa << 1) ^1 ;
} else {
mantissa = (mantissa << 1);
}
shift++;
}
mantissa = mantissa << (32 - (shift -1) - 9);
uint32_t ieee745 = (exponent << 23 ) | mantissa;
cout << bitset<32>(ieee745).to_string() << endl;
float cross = *(float*)&ieee745;
cout << "shift " << mantissa << endl;
cout << "cross " << cross << endl;
return to_string(shift);
}
// Convert the 32-bit binary into the decimal
float GetFloat32( std::string Binary )
{
int HexNumber = Binary2Hex( Binary );
bool negative = (HexNumber >> 31) != 0;
int exponent = (HexNumber >> 23) & 0xFF;
int sign = negative ? -1 : 1;
// Subtract 127 from the exponent
exponent -= 127;
// Convert the mantissa into decimal using the
// last 23 bits
int power = -1;
float total = 0.0;
for ( int i = 9; i < 32; i++ )
{
int c = Binary[ i ] - '0';
total += (float) c * (float) pow( 2.0, power );
power--;
}
total += 1.0;
float value = sign * (float) pow( 2.0, exponent ) * total;
return value;
}
// Get 32-bit IEEE 754 format of the decimal value
std::string GetBinary32( float value )
{
union
{
float input; // assumes sizeof(float) == sizeof(int)
int output;
} data;
data.input = value;
std::bitset<sizeof(float) * CHAR_BIT> bits(data.output);
std::string mystring = bits.to_string();
return mystring;
}
// To execute C++, please define "int main()"
int main() {
///int arr[] = { 1, 2, 3};
//permute(arr, 0, 3);
// Convert 19.5 into IEEE 754 binary format..
string str = GetBinary32( (float) 210.15 );
cout << "Binary equivalent of 210:" << std::endl;
cout << str << std::endl << std::endl;
// .. and back again
float f = GetFloat32( str );
cout << "Decimal equivalent of " << str << ":" << std::endl;
cout << f << std::endl;
//int power = -1;
//cout << pow( 1.0, power ) << endl;
cout << GetBinaryFloat(210.125) << endl;
return 0;
}