WOLFRAM

gives a binary representation of any expression expr as a ByteArray object.

Details and Options

Examples

open allclose all

Basic Examples  (2)Summary of the most common use cases

Serialize an expression:

Out[1]=1

Serialize a graphic:

Out[1]=1

Convert the serialized form back to an expression:

Out[2]=2

Scope  (7)Survey of the scope of standard use cases

Apply BinarySerialize to symbolic expressions:

Out[1]=1

Serialize an image:

Out[1]=1

Note that the size of the serialized form roughly equals the byte count of the expression:

Out[2]=2

BinarySerialize efficiently stores machine integers:

Out[1]=1
Out[2]=2
Out[3]=3

BinarySerialize efficiently stores machine reals:

Out[1]=1

Compare with an arbitrary-precision real:

Out[2]=2

BinarySerialize efficiently stores strings:

Out[2]=2
Out[3]=3

BinarySerialize supports ByteArray:

Out[1]=1

BinarySerialize supports packed arrays:

Out[2]=2
Out[3]=3

Options  (4)Common values & functionality for each option

Method  (3)

Create a packed array of integer values:

By default, BinarySerialize uses the smallest integer type that fits the data:

Out[2]=2

Serialize the packed array using a bigger integer type:

Out[3]=3

Create a packed array of real values:

Out[1]=1

Serialize the array:

Out[2]=2

Serialize the array using machine floats, trading precision for a smaller output:

Out[3]=3

Create a packed array of complex values:

Out[1]=1

Serialize the array:

Out[2]=2

Serialize the array using lower precision:

Out[3]=3

PerformanceGoal  (1)

Serialize a Dataset:

Out[2]=2

Serialize the same Dataset with PerformanceGoal set to "Size":

Out[3]=3

Both forms represent the same expression:

Out[4]=4

Applications  (1)Sample problems that can be solved with this function

Serialize a trained neural network:

Out[1]=1

Create a new file:

Open an output binary stream:

Out[3]=3

Write the serialized expression to the file:

Out[4]=4

Read the data from the file:

Out[6]=6

Plot the prediction of the net as a function of the input:

Out[7]=7

Properties & Relations  (4)Properties of the function, and connections to other functions

Using PerformanceGoal->"Speed" is faster but produces larger outputs:

Out[2]=2

Using PerformanceGoal->"Size" is slower but produces smaller outputs:

Out[3]=3

BinarySerialize encodes strings as UTF-8:

Out[1]=1
Out[2]=2

BinaryDeserialize is the inverse of BinarySerialize:

Out[1]=1

DumpSave stores definitions attached to a symbol in a file:

Using Get will return Null but restore the value of f:

Out[3]=3

BinarySerialize only stores the input expression, which can be restored by BinaryDeserialize:

Out[4]=4

Possible Issues  (2)Common pitfalls and unexpected behavior

From small expressions, PerformanceGoal->"Size" may not produce smaller outputs:

Out[1]=1
Out[2]=2

The Method parameter "PackedArrayIntegerType" must be chosen consistently with the data:

Out[1]=1

These values require 32-bit integers:

Out[2]=2

A setting of Automatic will always use a size that fits the data:

Out[3]=3
Wolfram Research (2017), BinarySerialize, Wolfram Language function, https://reference.wolfram.com/language/ref/BinarySerialize.html (updated 2018).
Wolfram Research (2017), BinarySerialize, Wolfram Language function, https://reference.wolfram.com/language/ref/BinarySerialize.html (updated 2018).

Text

Wolfram Research (2017), BinarySerialize, Wolfram Language function, https://reference.wolfram.com/language/ref/BinarySerialize.html (updated 2018).

Wolfram Research (2017), BinarySerialize, Wolfram Language function, https://reference.wolfram.com/language/ref/BinarySerialize.html (updated 2018).

CMS

Wolfram Language. 2017. "BinarySerialize." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2018. https://reference.wolfram.com/language/ref/BinarySerialize.html.

Wolfram Language. 2017. "BinarySerialize." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2018. https://reference.wolfram.com/language/ref/BinarySerialize.html.

APA

Wolfram Language. (2017). BinarySerialize. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/BinarySerialize.html

Wolfram Language. (2017). BinarySerialize. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/BinarySerialize.html

BibTeX

@misc{reference.wolfram_2025_binaryserialize, author="Wolfram Research", title="{BinarySerialize}", year="2018", howpublished="\url{https://reference.wolfram.com/language/ref/BinarySerialize.html}", note=[Accessed: 06-April-2025 ]}

@misc{reference.wolfram_2025_binaryserialize, author="Wolfram Research", title="{BinarySerialize}", year="2018", howpublished="\url{https://reference.wolfram.com/language/ref/BinarySerialize.html}", note=[Accessed: 06-April-2025 ]}

BibLaTeX

@online{reference.wolfram_2025_binaryserialize, organization={Wolfram Research}, title={BinarySerialize}, year={2018}, url={https://reference.wolfram.com/language/ref/BinarySerialize.html}, note=[Accessed: 06-April-2025 ]}

@online{reference.wolfram_2025_binaryserialize, organization={Wolfram Research}, title={BinarySerialize}, year={2018}, url={https://reference.wolfram.com/language/ref/BinarySerialize.html}, note=[Accessed: 06-April-2025 ]}