RDD

Parallelism

Serialization and GC

References

How to estimate the size of a Dataset

An approximated calculation for the size of a dataset is:

1

number Of Megabytes = M = (N*V*W) / 1024^2

Copied!

where:

1

N = number of records

2

3

V = number of variables

4

5

W = average width in bytes of a variable

Copied!

In approximating **W**, remember:

Integers, −127 <= x <= 100

1

Integers, 32,767 <= x <= 32,740

2

Integers, -2,147,483,647 <= x <= 2,147,483,620

4

Floats single precision

4

Floats double precision

8

Strings

maximum lenght

Say that you have a 20,000-observation dataset. That dataset contains

1

1 string identifier of length 20 20

2

3

10 small integers (1 byte each) 10

4

5

4 standard integers (2 bytes each) 8

6

7

5 floating-point numbers (4 bytes each) 20

8

9

--------------------------------------------------------

10

11

20 variables total 58

Copied!

Thus the average width of a variable is:

1

W = 58/20 = 2.9 bytes

Copied!

The size of your dataset is:

1

M = 20000*20*2.9/1024^2 = 1.13 megabytes

Copied!

This result slightly understates the size of the dataset because we have not included any variable labels, value labels, or notes that you might add to the data. That does not amount to much. For instance, imagine that you added variable labels to all 20 variables and that the average length of the text of the labels was 22 characters.

That would amount to a total of 20*22=440 bytes or 440/10242=.00042 megabytes.

1

M = 20000*20*2.9/1024^2 = 1.13 megabytes

Copied!

N*V*W is, of course, the total size of the data. The 1,0242 in the denominator rescales the results to megabytes.

Yes, the result is divided by 1,0242 even though 1,0002 = a million. Computer memory comes in binary increments. Although we think of k as standing for kilo, in the computer business, k is really a “binary” thousand, 210 = 1,024. A megabyte is a binary million—a binary k squared:

1

1 MB = 1024 KB = 1024*1024 = 1,048,576 bytes

Copied!

With cheap memory, we sometimes talk about a gigabyte. Here is how a binary gig works:

1

1 GB = 1024 MB = 10243 = 1,073,741,824 bytes

Copied!

Parallelism - Previous

Use the right level of parallelism

Next - Parallelism

How to estimate the number of partitions, executor's and driver's params (YARN Cluster Mode)

Last modified 11mo ago

Copy link

Contents

Explanation of formula