wiki/notebook/computing.endianness.org
Gabriel Arazas b088086b06 Merge evergreen notes into the notebook
Now, it's all under the notebook umbrella. Seems to be appropriate as it
is just my notes after all.

I also updated some notes from there. I didn't keep track of what it is
this time. Something about more learning notes extracted from my
"Learning how to learn" course notes and then some. Lack of time and
hurriness just makes it difficult to track but it should be under
version control already.
2021-07-21 16:28:07 +08:00

1.5 KiB

Endianness

Endianness refers to how bits are read and this depends on the underlying hardware architecture. 1

For example, given the following bit, 11010, this could be read as $(1\times2^{0}) + (1\times2^{1}) + (0\times2^{2}) + (1\times2^{3}) + (0\times2^{4})$ or $11$ with the first bit being the least significant also known as little-endian. On the other hand, this could also be read as $(0\times2^{0}) + (1\times2^{1}) + (0\times2^{2}) + (1\times2^{3}) + (1\times2^{4})$ or $26$ with the last bit being the least significant which we refer to as big-endian. 2

Endianness can have subtle effects on various things — e.g., using binary data formats like FITS and HDF — like having the wrong endianness.

To know the endianness of your machine, you can simply create a test number (preferably in binary) and check for the first few digits if it's little-endian — otherwise, it is big-endian. If you have Python installed, you can simply use sys.byteorder (e.g., python -c 'import sys; print(sys.byteorder)).


1

You can enforce endianness in software but oftentimes, it is not a good idea.

2

Endianness focuses on byte order, not bit order but it is best to give the simplest example.