Basic information about a data frame#
using DataFrames
Let’s start by creating a DataFrame
object, x
, so that we can learn how to get information on that data frame.
x = DataFrame(A=[1, 2], B=[1.0, missing], C=["a", "b"])
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 1 | 1.0 | a |
2 | 2 | missing | b |
The standard size
function works to get dimensions of the DataFrame
,
size(x), size(x, 1), size(x, 2)
((2, 3), 2, 3)
as well as nrow
and ncol
from R.
nrow(x), ncol(x)
(2, 3)
describe
gives basic summary statistics of data in your DataFrame
(check out the help of describe
for information on how to customize shown statistics).
describe(x)
Row | variable | mean | min | median | max | nmissing | eltype |
---|---|---|---|---|---|---|---|
Symbol | Union… | Any | Union… | Any | Int64 | Type | |
1 | A | 1.5 | 1 | 1.5 | 2 | 0 | Int64 |
2 | B | 1.0 | 1.0 | 1.0 | 1.0 | 1 | Union{Missing, Float64} |
3 | C | a | b | 0 | String |
you can limit the columns shown by describe
using cols
keyword argument
describe(x, cols=1:2)
Row | variable | mean | min | median | max | nmissing | eltype |
---|---|---|---|---|---|---|---|
Symbol | Float64 | Real | Float64 | Real | Int64 | Type | |
1 | A | 1.5 | 1 | 1.5 | 2 | 0 | Int64 |
2 | B | 1.0 | 1.0 | 1.0 | 1.0 | 1 | Union{Missing, Float64} |
names
will return the names of all columns as strings
names(x)
3-element Vector{String}:
"A"
"B"
"C"
you can also get column names with a given element type (eltype
):
names(x, String)
1-element Vector{String}:
"C"
use propertynames
to get a vector of Symbol
s:
propertynames(x)
3-element Vector{Symbol}:
:A
:B
:C
eltype
on eachcol(x)
returns element types of columns:
eltype.(eachcol(x))
3-element Vector{Type}:
Int64
Union{Missing, Float64}
String
Here we create some large DataFrame
y = DataFrame(rand(1:10, 1000, 10), :auto)
Row | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 |
---|---|---|---|---|---|---|---|---|---|---|
Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | |
1 | 4 | 1 | 2 | 3 | 6 | 1 | 6 | 5 | 2 | 3 |
2 | 3 | 3 | 4 | 5 | 3 | 5 | 9 | 8 | 3 | 1 |
3 | 8 | 6 | 7 | 8 | 6 | 3 | 6 | 4 | 3 | 1 |
4 | 6 | 1 | 5 | 2 | 7 | 4 | 4 | 3 | 4 | 7 |
5 | 10 | 1 | 8 | 2 | 4 | 4 | 9 | 5 | 8 | 1 |
6 | 4 | 2 | 9 | 4 | 8 | 1 | 9 | 10 | 2 | 4 |
7 | 5 | 1 | 3 | 5 | 10 | 1 | 4 | 10 | 3 | 6 |
8 | 1 | 2 | 10 | 10 | 1 | 2 | 1 | 7 | 3 | 10 |
9 | 5 | 7 | 8 | 9 | 9 | 5 | 10 | 7 | 9 | 6 |
10 | 6 | 2 | 2 | 4 | 8 | 2 | 10 | 2 | 7 | 6 |
11 | 4 | 8 | 1 | 4 | 5 | 3 | 4 | 9 | 1 | 8 |
12 | 6 | 1 | 9 | 1 | 8 | 8 | 7 | 8 | 7 | 1 |
13 | 2 | 2 | 4 | 8 | 4 | 9 | 8 | 2 | 9 | 1 |
⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ |
989 | 7 | 2 | 5 | 5 | 6 | 10 | 7 | 10 | 4 | 9 |
990 | 10 | 2 | 10 | 4 | 3 | 10 | 5 | 10 | 10 | 4 |
991 | 5 | 9 | 2 | 2 | 5 | 1 | 1 | 6 | 8 | 8 |
992 | 6 | 9 | 3 | 2 | 9 | 3 | 4 | 2 | 1 | 8 |
993 | 7 | 1 | 1 | 1 | 8 | 3 | 8 | 4 | 8 | 3 |
994 | 10 | 5 | 8 | 6 | 5 | 3 | 9 | 9 | 3 | 5 |
995 | 7 | 6 | 9 | 8 | 10 | 9 | 2 | 8 | 2 | 8 |
996 | 7 | 8 | 1 | 1 | 5 | 10 | 3 | 10 | 6 | 7 |
997 | 1 | 9 | 5 | 10 | 3 | 3 | 7 | 10 | 9 | 1 |
998 | 6 | 4 | 3 | 2 | 1 | 9 | 9 | 10 | 3 | 2 |
999 | 5 | 6 | 6 | 1 | 6 | 7 | 4 | 4 | 2 | 2 |
1000 | 2 | 3 | 8 | 2 | 4 | 2 | 2 | 10 | 3 | 3 |
and then we can use first
to peek into its first few rows
first(y, 5)
Row | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 |
---|---|---|---|---|---|---|---|---|---|---|
Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | |
1 | 4 | 1 | 2 | 3 | 6 | 1 | 6 | 5 | 2 | 3 |
2 | 3 | 3 | 4 | 5 | 3 | 5 | 9 | 8 | 3 | 1 |
3 | 8 | 6 | 7 | 8 | 6 | 3 | 6 | 4 | 3 | 1 |
4 | 6 | 1 | 5 | 2 | 7 | 4 | 4 | 3 | 4 | 7 |
5 | 10 | 1 | 8 | 2 | 4 | 4 | 9 | 5 | 8 | 1 |
and last
to see its bottom rows.
last(y, 3)
Row | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 |
---|---|---|---|---|---|---|---|---|---|---|
Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | |
1 | 6 | 4 | 3 | 2 | 1 | 9 | 9 | 10 | 3 | 2 |
2 | 5 | 6 | 6 | 1 | 6 | 7 | 4 | 4 | 2 | 2 |
3 | 2 | 3 | 8 | 2 | 4 | 2 | 2 | 10 | 3 | 3 |
Using first
and last
without number of rows will return a first/last DataFrameRow
in the DataFrame
first(y)
Row | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 |
---|---|---|---|---|---|---|---|---|---|---|
Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | |
1 | 4 | 1 | 2 | 3 | 6 | 1 | 6 | 5 | 2 | 3 |
last(y)
Row | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 |
---|---|---|---|---|---|---|---|---|---|---|
Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | Int64 | |
1000 | 2 | 3 | 8 | 2 | 4 | 2 | 2 | 10 | 3 | 3 |
Displaying large data frames#
Create a wide and tall data frame:
df = DataFrame(rand(100, 100), :auto)
Row | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 | x11 | x12 | x13 | x14 | x15 | x16 | x17 | x18 | x19 | x20 | x21 | x22 | x23 | x24 | x25 | x26 | x27 | x28 | x29 | x30 | x31 | x32 | x33 | x34 | x35 | x36 | x37 | x38 | x39 | x40 | x41 | x42 | x43 | x44 | x45 | x46 | x47 | x48 | x49 | x50 | x51 | x52 | x53 | x54 | x55 | x56 | x57 | x58 | x59 | x60 | x61 | x62 | x63 | x64 | x65 | x66 | x67 | x68 | x69 | x70 | x71 | x72 | x73 | x74 | x75 | x76 | x77 | x78 | x79 | x80 | x81 | x82 | x83 | x84 | x85 | x86 | x87 | x88 | x89 | x90 | x91 | x92 | x93 | x94 | x95 | x96 | x97 | x98 | x99 | x100 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | Float64 | |
1 | 0.868306 | 0.380515 | 0.657908 | 0.809605 | 0.0818846 | 0.504407 | 0.100429 | 0.280353 | 0.837374 | 0.0278786 | 0.872717 | 0.160118 | 0.257644 | 0.316538 | 0.68689 | 0.0861048 | 0.836218 | 0.934653 | 0.944053 | 0.392336 | 0.169155 | 0.70687 | 0.552391 | 0.375184 | 0.353161 | 0.970312 | 0.933621 | 0.0157079 | 0.0728528 | 0.700317 | 0.170098 | 0.990677 | 0.0268101 | 0.70014 | 0.803022 | 0.0398784 | 0.553713 | 0.393242 | 0.436224 | 0.695285 | 0.952417 | 0.854844 | 0.443986 | 0.414717 | 0.431175 | 0.436951 | 0.0018846 | 0.583649 | 0.32511 | 0.694777 | 0.353723 | 0.872447 | 0.51135 | 0.0549463 | 0.0639635 | 0.830518 | 0.63315 | 0.342743 | 0.505723 | 0.993752 | 0.0847322 | 0.796206 | 0.180922 | 0.183977 | 0.542623 | 0.755013 | 0.750986 | 0.329903 | 0.463566 | 0.350237 | 0.162125 | 0.104535 | 0.97842 | 0.656167 | 0.0782072 | 0.856228 | 0.02726 | 0.364295 | 0.989808 | 0.198487 | 0.720151 | 0.46557 | 0.583285 | 0.106751 | 0.332545 | 0.647077 | 0.0877689 | 0.198738 | 0.305578 | 0.820774 | 0.613791 | 0.207603 | 0.217725 | 0.0903472 | 0.404008 | 0.140559 | 0.926137 | 0.156521 | 0.815888 | 0.177271 |
2 | 0.255153 | 0.139716 | 0.118619 | 0.0135367 | 0.94598 | 0.0836783 | 0.362626 | 0.126453 | 0.129716 | 0.350421 | 0.953987 | 0.213925 | 0.265803 | 0.326817 | 0.536237 | 0.158839 | 0.876193 | 0.250371 | 0.966075 | 0.032881 | 0.61406 | 0.723633 | 0.189194 | 0.756455 | 0.514057 | 0.478587 | 0.708734 | 0.0510587 | 0.613855 | 0.95397 | 0.148451 | 0.888 | 0.817581 | 0.615265 | 0.34452 | 0.283992 | 0.620631 | 0.219882 | 0.621519 | 0.444608 | 0.802019 | 0.989782 | 0.470175 | 0.463831 | 0.205931 | 0.121677 | 0.293606 | 0.8189 | 0.0098777 | 0.551654 | 0.616459 | 0.720726 | 0.494976 | 0.0420966 | 0.172689 | 0.801869 | 0.520275 | 0.531359 | 0.521295 | 0.764829 | 0.607004 | 0.589423 | 0.914992 | 0.482027 | 0.381686 | 0.135755 | 0.108765 | 0.51421 | 0.548422 | 0.668991 | 0.338508 | 0.771376 | 0.532474 | 0.493047 | 0.727691 | 0.344768 | 0.298733 | 0.548999 | 0.278084 | 0.465309 | 0.27387 | 0.237929 | 0.153841 | 0.769594 | 0.796522 | 0.0861407 | 0.492239 | 0.911951 | 0.730661 | 0.929419 | 0.436776 | 0.0974624 | 0.628901 | 0.921587 | 0.880616 | 0.239897 | 0.532453 | 0.182894 | 0.54108 | 0.189981 |
3 | 0.753006 | 0.0915741 | 0.623762 | 0.991628 | 0.799652 | 0.479883 | 0.580553 | 0.146457 | 0.41399 | 0.0193083 | 0.146696 | 0.765276 | 0.921818 | 0.287214 | 0.830389 | 0.653359 | 0.402326 | 0.445098 | 0.114724 | 0.935568 | 0.909281 | 0.474664 | 0.519241 | 0.456251 | 0.479062 | 0.609057 | 0.867585 | 0.510557 | 0.380457 | 0.883944 | 0.90355 | 0.835202 | 0.16576 | 0.048521 | 0.968687 | 0.465748 | 0.156985 | 0.544491 | 0.169367 | 0.357541 | 0.774505 | 0.518858 | 0.45119 | 0.39777 | 0.0463166 | 0.081 | 0.0937706 | 0.251462 | 0.650517 | 0.577768 | 0.167412 | 0.247597 | 0.449681 | 0.732948 | 0.539047 | 0.269396 | 0.404281 | 0.922201 | 0.110523 | 0.707422 | 0.104062 | 0.887815 | 0.502509 | 0.999936 | 0.659106 | 0.960268 | 0.762738 | 0.688999 | 0.668501 | 0.964083 | 0.143164 | 0.380553 | 0.84123 | 0.371966 | 0.484779 | 0.465756 | 0.691759 | 0.448678 | 0.698153 | 0.050442 | 0.553426 | 0.998334 | 0.0683516 | 0.58739 | 0.584378 | 0.0137223 | 0.845575 | 0.230051 | 0.205173 | 0.746477 | 0.573215 | 0.558139 | 0.11026 | 0.164691 | 0.290142 | 0.411774 | 0.875486 | 0.922225 | 0.57677 | 0.552365 |
4 | 0.304959 | 0.511311 | 0.171886 | 0.432466 | 0.438148 | 0.197351 | 0.172034 | 0.0600194 | 0.833879 | 0.835836 | 0.987725 | 0.428561 | 0.669939 | 0.156035 | 0.551692 | 0.383234 | 0.0213868 | 0.693446 | 0.515831 | 0.0146793 | 0.726204 | 0.85854 | 0.431398 | 0.459804 | 0.985127 | 0.263412 | 0.982029 | 0.556722 | 0.776608 | 0.000407978 | 0.489013 | 0.618856 | 0.418444 | 0.454505 | 0.0903449 | 0.706268 | 0.069915 | 0.533302 | 0.877481 | 0.109502 | 0.186472 | 0.293992 | 0.84841 | 0.293875 | 0.86844 | 0.596285 | 0.774619 | 0.332079 | 0.58742 | 0.166044 | 0.259351 | 0.47394 | 0.0690131 | 0.152148 | 0.00343749 | 0.507096 | 0.953784 | 0.27584 | 0.670065 | 0.120644 | 0.471484 | 0.83224 | 0.664858 | 0.42784 | 0.663476 | 0.667471 | 0.634285 | 0.0495127 | 0.652732 | 0.741252 | 0.382751 | 0.433401 | 0.284524 | 0.187022 | 0.474924 | 0.646492 | 0.371184 | 0.25162 | 0.293145 | 0.778964 | 0.775156 | 0.763864 | 0.182448 | 0.593774 | 0.268257 | 0.351753 | 0.99284 | 0.51045 | 0.175955 | 0.658268 | 0.415242 | 0.755822 | 0.411757 | 0.636733 | 0.387181 | 0.452065 | 0.459887 | 0.684663 | 0.11967 | 0.558536 |
5 | 0.786784 | 0.798934 | 0.410196 | 0.41525 | 0.818259 | 0.267427 | 0.0163449 | 0.970744 | 0.343864 | 0.550151 | 0.765287 | 0.806424 | 0.6629 | 0.270874 | 0.107336 | 0.464896 | 0.804152 | 0.658107 | 0.137072 | 0.393007 | 0.508524 | 0.0197904 | 0.54265 | 0.446085 | 0.339874 | 0.461985 | 0.208748 | 0.395264 | 0.69134 | 0.165036 | 0.616692 | 0.974795 | 0.0546958 | 0.773068 | 0.487201 | 0.40863 | 0.392692 | 0.560809 | 0.136182 | 0.949733 | 0.650142 | 0.529737 | 0.921117 | 0.748685 | 0.871725 | 0.324182 | 0.314453 | 0.973579 | 0.469261 | 0.222489 | 0.765145 | 0.559816 | 0.526449 | 0.402695 | 0.28001 | 0.200764 | 0.522301 | 0.0140026 | 0.543105 | 0.659529 | 0.326429 | 0.950603 | 0.0892684 | 0.162339 | 0.65971 | 0.972061 | 0.333376 | 0.781518 | 0.806224 | 0.260022 | 0.99692 | 0.155832 | 0.738558 | 0.61139 | 0.59464 | 0.908304 | 0.902233 | 0.157161 | 0.604014 | 0.548685 | 0.170641 | 0.425251 | 0.642487 | 0.308007 | 0.899122 | 0.32513 | 0.848494 | 0.510764 | 0.118911 | 0.53513 | 0.51222 | 0.1124 | 0.832155 | 0.32412 | 0.802947 | 0.569618 | 0.354802 | 0.814295 | 0.869871 | 0.16904 |
6 | 0.430183 | 0.238679 | 0.103721 | 0.279513 | 0.492935 | 0.249933 | 0.373061 | 0.780416 | 0.460724 | 0.641172 | 0.722328 | 0.248222 | 0.245194 | 0.265075 | 0.681198 | 0.995285 | 0.426913 | 0.742874 | 0.0781239 | 0.418848 | 0.909279 | 0.872931 | 0.315265 | 0.272788 | 0.97724 | 0.446829 | 0.641601 | 0.801451 | 0.324617 | 0.707387 | 0.999194 | 0.0654121 | 0.518156 | 0.260412 | 0.858762 | 0.0716054 | 0.643542 | 0.513421 | 0.866007 | 0.490019 | 0.837809 | 0.760126 | 0.601489 | 0.314009 | 0.147592 | 0.704126 | 0.533211 | 0.0163203 | 0.93958 | 0.197303 | 0.208533 | 0.330907 | 0.798366 | 0.778582 | 0.346687 | 0.0862512 | 0.894622 | 0.0291909 | 0.705336 | 0.93176 | 0.837625 | 0.308981 | 0.262264 | 0.0170214 | 0.138784 | 0.25122 | 0.876857 | 0.825749 | 0.0163348 | 0.0980736 | 0.88022 | 0.423695 | 0.953555 | 0.781852 | 0.702623 | 0.537325 | 0.822962 | 0.228998 | 0.764699 | 0.19036 | 0.783607 | 0.681001 | 0.369043 | 0.821603 | 0.0484352 | 0.200062 | 0.302467 | 0.290097 | 0.122813 | 0.550607 | 0.221689 | 0.00402049 | 0.220936 | 0.748371 | 0.676892 | 0.592931 | 0.451576 | 0.964421 | 0.940102 | 0.482321 |
7 | 0.996555 | 0.971884 | 0.883225 | 0.0778357 | 0.613666 | 0.151542 | 0.723508 | 0.056745 | 0.17589 | 0.273554 | 0.953294 | 0.50649 | 0.331208 | 0.211243 | 0.252209 | 0.00832874 | 0.622568 | 0.696092 | 0.086723 | 0.508548 | 0.777544 | 0.410464 | 0.172958 | 0.540887 | 0.233951 | 0.499491 | 0.851739 | 0.642036 | 0.970293 | 0.353182 | 0.710722 | 0.943751 | 0.398039 | 0.473772 | 0.501438 | 0.349002 | 0.249168 | 0.575039 | 0.372356 | 0.556992 | 0.645575 | 0.566774 | 0.0389206 | 0.478149 | 0.878968 | 0.764284 | 0.744204 | 0.315232 | 0.166617 | 0.0302283 | 0.213753 | 0.170582 | 0.77602 | 0.568494 | 0.623433 | 0.327295 | 0.935216 | 0.671758 | 0.238777 | 0.891594 | 0.323232 | 0.96299 | 0.531626 | 0.879196 | 0.478452 | 0.83501 | 0.669828 | 0.0473969 | 0.604424 | 0.40554 | 0.369116 | 0.706401 | 0.872977 | 0.551101 | 0.955988 | 0.346552 | 0.441964 | 0.177026 | 0.170869 | 0.0841737 | 0.649201 | 0.60762 | 0.724618 | 0.369459 | 0.839238 | 0.89494 | 0.72433 | 0.217593 | 0.0587148 | 0.79683 | 0.586608 | 0.507157 | 0.08913 | 0.965265 | 0.826272 | 0.647953 | 0.0686044 | 0.972089 | 0.623779 | 0.852593 |
8 | 0.816955 | 0.911997 | 0.127832 | 0.694393 | 0.00874892 | 0.923932 | 0.526796 | 0.00343153 | 0.85091 | 0.099981 | 0.656786 | 0.558121 | 0.948025 | 0.699086 | 0.517791 | 0.208852 | 0.0348319 | 0.486852 | 0.949836 | 0.0309556 | 0.778731 | 0.638226 | 0.498061 | 0.273319 | 0.839728 | 0.897641 | 0.623571 | 0.678636 | 0.258504 | 0.710125 | 0.136622 | 0.173631 | 0.444628 | 0.682808 | 0.954346 | 0.882731 | 0.794243 | 0.260379 | 0.744822 | 0.411058 | 0.382965 | 0.428702 | 0.320316 | 0.559853 | 0.642588 | 0.290248 | 0.758524 | 0.146816 | 0.924888 | 0.180372 | 0.161206 | 0.384262 | 0.342697 | 0.475571 | 0.207416 | 0.440166 | 0.706747 | 0.11121 | 0.39697 | 0.945648 | 0.880853 | 0.44748 | 0.381668 | 0.591815 | 0.913283 | 0.221528 | 0.758099 | 0.968678 | 0.532034 | 0.538382 | 0.177169 | 0.381406 | 0.0600127 | 0.876267 | 0.829866 | 0.0114219 | 0.394713 | 0.0602286 | 0.0956392 | 0.387565 | 0.148122 | 0.444802 | 0.948492 | 0.999086 | 0.330349 | 0.851749 | 0.609427 | 0.586486 | 0.291636 | 0.760887 | 0.140255 | 0.121368 | 0.122303 | 0.912696 | 0.830693 | 0.16875 | 0.202563 | 0.15154 | 0.143765 | 0.323015 |
9 | 0.810187 | 0.379592 | 0.2698 | 0.04548 | 0.591613 | 0.405583 | 0.0558649 | 0.923944 | 0.936605 | 0.471244 | 0.882472 | 0.799644 | 0.567106 | 0.435697 | 0.437332 | 0.574811 | 0.694038 | 0.371456 | 0.443789 | 0.766675 | 0.990727 | 0.0913779 | 0.875153 | 0.587263 | 0.240798 | 0.578013 | 0.454798 | 0.827547 | 0.244809 | 0.426493 | 0.95172 | 0.722522 | 0.132097 | 0.180918 | 0.299012 | 0.726522 | 0.944807 | 0.876654 | 0.0299032 | 0.96755 | 0.89427 | 0.214439 | 0.675613 | 0.998791 | 0.396796 | 0.618752 | 0.935547 | 0.898981 | 0.876398 | 0.916883 | 0.415347 | 0.842188 | 0.127338 | 0.539545 | 0.0540355 | 0.64879 | 0.00160929 | 0.356903 | 0.493596 | 0.360167 | 0.701598 | 0.788398 | 0.255928 | 0.869382 | 0.0458254 | 0.192662 | 0.0972501 | 0.936898 | 0.498557 | 0.051703 | 0.31847 | 0.711139 | 0.729681 | 0.0675389 | 0.158932 | 0.96224 | 0.0421302 | 0.769298 | 0.974494 | 0.705715 | 0.610143 | 0.480311 | 0.459069 | 0.938422 | 0.0630678 | 0.239589 | 0.320363 | 0.873249 | 0.201335 | 0.190293 | 0.318774 | 0.267897 | 0.361433 | 0.458151 | 0.871808 | 0.267494 | 0.177501 | 0.104631 | 0.618015 | 0.0424579 |
10 | 0.401728 | 0.250398 | 0.0156542 | 0.679797 | 0.217092 | 0.955373 | 0.537762 | 0.0560864 | 0.776053 | 0.484357 | 0.272044 | 0.455136 | 0.444782 | 0.918556 | 0.675249 | 0.324197 | 0.881874 | 0.799955 | 0.939852 | 0.286728 | 0.347235 | 0.755757 | 0.0550933 | 0.383349 | 0.473929 | 0.287972 | 0.610742 | 0.658411 | 0.142278 | 0.0860539 | 0.243921 | 0.741186 | 0.516669 | 0.2689 | 0.943747 | 0.478714 | 0.134143 | 0.285758 | 0.640038 | 0.0839787 | 0.370658 | 0.406699 | 0.637027 | 0.466352 | 0.52088 | 0.697991 | 0.291743 | 0.496877 | 0.103871 | 0.973859 | 0.0677266 | 0.410921 | 0.168204 | 0.954426 | 0.209432 | 0.631032 | 0.371666 | 0.177393 | 0.0942961 | 0.837743 | 0.0932237 | 0.143987 | 0.111793 | 0.963288 | 0.412559 | 0.343904 | 0.14689 | 0.416357 | 0.624195 | 0.144135 | 0.290967 | 0.209354 | 0.763328 | 0.94026 | 0.199448 | 0.364641 | 0.572324 | 0.685312 | 0.936729 | 0.0910423 | 0.50348 | 0.721929 | 0.765657 | 0.542842 | 0.973425 | 0.0332549 | 0.460504 | 0.214584 | 0.327178 | 0.165733 | 0.082553 | 0.613928 | 0.196282 | 0.29042 | 0.292025 | 0.967653 | 0.437291 | 0.398921 | 0.656021 | 0.629152 |
11 | 0.961738 | 0.30562 | 0.0286117 | 0.176245 | 0.716738 | 0.563613 | 0.547998 | 0.563687 | 0.976899 | 0.369308 | 0.549334 | 0.563936 | 0.52917 | 0.413796 | 0.262737 | 0.358193 | 0.459702 | 0.336488 | 0.141339 | 0.646274 | 0.437036 | 0.151023 | 0.223489 | 0.244345 | 0.00865324 | 0.453573 | 0.67587 | 0.82215 | 0.324718 | 0.615089 | 0.522575 | 0.22805 | 0.713165 | 0.450351 | 0.34374 | 0.713496 | 0.980846 | 0.0114336 | 0.893986 | 0.267844 | 0.402851 | 0.608898 | 0.831269 | 0.0491084 | 0.127582 | 0.596324 | 0.973412 | 0.694919 | 0.125834 | 0.480534 | 0.848849 | 0.879991 | 0.349703 | 0.0623912 | 0.633794 | 0.114135 | 0.841488 | 0.910746 | 0.813094 | 0.9502 | 0.0597621 | 0.230378 | 0.919547 | 0.573892 | 0.186963 | 0.747165 | 0.48749 | 0.451025 | 0.874844 | 0.627592 | 0.111577 | 0.527653 | 0.156499 | 0.171093 | 0.255254 | 0.237372 | 0.771544 | 0.127523 | 0.539173 | 0.247228 | 0.641739 | 0.796846 | 0.151959 | 0.25029 | 0.429782 | 0.722281 | 0.870353 | 0.596796 | 0.290819 | 0.76545 | 0.048927 | 0.751237 | 0.636111 | 0.687101 | 0.365675 | 0.513285 | 0.194616 | 0.492509 | 0.977692 | 0.987123 |
12 | 0.0178274 | 0.49358 | 0.84486 | 0.447295 | 0.432964 | 0.952484 | 0.121884 | 0.460708 | 0.655238 | 0.169994 | 0.105236 | 0.17193 | 0.656645 | 0.524268 | 0.997296 | 0.785243 | 0.871204 | 0.823256 | 0.393409 | 0.338695 | 0.974009 | 0.549518 | 0.619206 | 0.769909 | 0.233689 | 0.924317 | 0.0236291 | 0.185684 | 0.159503 | 0.789497 | 0.638211 | 0.647343 | 0.281781 | 0.0429943 | 0.614603 | 0.550931 | 0.00556496 | 0.852999 | 0.435796 | 0.92805 | 0.222529 | 0.835809 | 0.750361 | 0.556488 | 0.118593 | 0.447267 | 0.619032 | 0.299986 | 0.551296 | 0.804748 | 0.925894 | 0.627006 | 0.418006 | 0.00964323 | 0.595186 | 0.607962 | 0.260272 | 0.1299 | 0.64525 | 0.159583 | 0.051517 | 0.680559 | 0.791262 | 0.574792 | 0.277798 | 0.749454 | 0.789265 | 0.027398 | 0.14251 | 0.387886 | 0.880692 | 0.244488 | 0.841722 | 0.586285 | 0.99733 | 0.151249 | 0.565944 | 0.76487 | 0.764691 | 0.957521 | 0.561505 | 0.722431 | 0.407034 | 0.120252 | 0.11975 | 0.509966 | 0.604088 | 0.563474 | 0.391759 | 0.97337 | 0.951984 | 0.0226747 | 0.817501 | 0.0335038 | 0.225089 | 0.0964695 | 0.279844 | 0.589996 | 0.438049 | 0.506583 |
13 | 0.920143 | 0.786883 | 0.673709 | 0.49005 | 0.865904 | 0.860597 | 0.92987 | 0.575165 | 0.322766 | 0.581353 | 0.182853 | 0.392355 | 0.215359 | 0.67058 | 0.580471 | 0.424685 | 0.619339 | 0.670443 | 0.281696 | 0.73621 | 0.132173 | 0.46567 | 0.749057 | 0.504529 | 0.570821 | 0.45316 | 0.222215 | 0.806947 | 0.505548 | 0.461994 | 0.521016 | 0.621319 | 0.520355 | 0.600036 | 0.157987 | 0.455391 | 0.575924 | 0.729929 | 0.298837 | 0.400886 | 0.651078 | 0.764883 | 0.0710604 | 0.740565 | 0.531466 | 0.725219 | 0.046919 | 0.896857 | 0.0923352 | 0.0286678 | 0.310355 | 0.632609 | 0.643456 | 0.509307 | 0.777172 | 0.304045 | 0.841906 | 0.796775 | 0.238209 | 0.323248 | 0.847498 | 0.872927 | 0.390636 | 0.848055 | 0.281089 | 0.143445 | 0.124694 | 0.661218 | 0.853716 | 0.227996 | 0.673234 | 0.21907 | 0.189138 | 0.323811 | 0.289983 | 0.280507 | 0.811696 | 0.663177 | 0.595313 | 0.95271 | 0.400955 | 0.369172 | 0.767391 | 0.867965 | 0.473889 | 0.184452 | 0.970689 | 0.648066 | 0.504488 | 0.676569 | 0.970155 | 0.688446 | 0.649754 | 0.0753387 | 0.0438846 | 0.508501 | 0.129474 | 0.849712 | 0.883823 | 0.417718 |
⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ | ⋮ |
89 | 0.269311 | 0.904451 | 0.596499 | 0.374805 | 0.925915 | 0.602337 | 0.458919 | 0.347064 | 0.0118513 | 0.90056 | 0.684995 | 0.284709 | 0.108633 | 0.368048 | 0.341533 | 0.82045 | 0.132917 | 0.165059 | 0.47953 | 0.781977 | 0.372105 | 0.0390839 | 0.452068 | 0.391307 | 0.575141 | 0.532759 | 0.801479 | 0.908988 | 0.209228 | 0.352539 | 0.430643 | 0.512119 | 0.782444 | 0.660528 | 0.732559 | 0.0587829 | 0.118165 | 0.318899 | 0.210567 | 0.522131 | 0.516921 | 0.627748 | 0.149479 | 0.329712 | 0.23896 | 0.274187 | 0.114855 | 0.658874 | 0.0400687 | 0.64066 | 0.769901 | 0.306155 | 0.486555 | 0.691356 | 0.763935 | 0.535341 | 0.864884 | 0.0476858 | 0.517319 | 0.345729 | 0.709627 | 0.893746 | 0.261317 | 0.177555 | 0.489828 | 0.891331 | 0.280904 | 0.910205 | 0.470579 | 0.296067 | 0.663321 | 0.0522744 | 0.849165 | 0.177088 | 0.290927 | 0.761563 | 0.796346 | 0.768635 | 0.693807 | 0.329614 | 0.222488 | 0.750879 | 0.209687 | 0.40239 | 0.318841 | 0.382286 | 0.676896 | 0.43454 | 0.282028 | 0.632566 | 0.220568 | 0.290192 | 0.528709 | 0.106593 | 0.583776 | 0.122462 | 0.595078 | 0.678528 | 0.466864 | 0.200539 |
90 | 0.611564 | 0.42169 | 0.658694 | 0.564322 | 0.791517 | 0.901151 | 0.0756545 | 0.135641 | 0.860526 | 0.555931 | 0.216633 | 0.691168 | 0.642184 | 0.414692 | 0.225143 | 0.923674 | 0.106693 | 0.513614 | 0.0869903 | 0.451269 | 0.238319 | 0.0183832 | 0.779572 | 0.678598 | 0.269125 | 0.727794 | 0.0426694 | 0.311046 | 0.0645674 | 0.247989 | 0.160969 | 0.505046 | 0.0532524 | 0.0900843 | 0.106085 | 0.594647 | 0.690253 | 0.488804 | 0.415414 | 0.194411 | 0.271071 | 0.0625419 | 0.188133 | 0.791638 | 0.903016 | 0.308733 | 0.339522 | 0.559164 | 0.312916 | 0.404273 | 0.31003 | 0.0993818 | 0.591333 | 0.974179 | 0.748061 | 0.828328 | 0.126407 | 0.19699 | 0.40525 | 0.643535 | 0.742069 | 0.172895 | 0.284471 | 0.29181 | 0.751278 | 0.143042 | 0.292325 | 0.900304 | 0.116598 | 0.321627 | 0.041856 | 0.751213 | 0.140046 | 0.87949 | 0.339453 | 0.704227 | 0.563186 | 0.294349 | 0.672322 | 0.0613965 | 0.722724 | 0.595944 | 0.382471 | 0.869679 | 0.245379 | 0.0302124 | 0.901562 | 0.0480033 | 0.743903 | 0.681883 | 0.178091 | 0.879018 | 0.960179 | 0.411599 | 0.748237 | 0.127313 | 0.833857 | 0.0204533 | 0.373607 | 0.689869 |
91 | 0.375506 | 0.362921 | 0.811209 | 0.719832 | 0.211768 | 0.734179 | 0.639197 | 0.393977 | 0.168119 | 0.7413 | 0.47055 | 0.922607 | 0.220888 | 0.97318 | 0.412847 | 0.222991 | 0.691479 | 0.581241 | 0.262556 | 0.922228 | 0.225144 | 0.259149 | 0.460931 | 0.256836 | 0.750916 | 0.166512 | 0.02925 | 0.315686 | 0.787271 | 0.865228 | 0.836046 | 0.63899 | 0.971496 | 0.0193864 | 0.550121 | 0.0606081 | 0.256586 | 0.938329 | 0.341638 | 0.783375 | 0.814086 | 0.740063 | 0.974045 | 0.779448 | 0.775008 | 0.798352 | 0.385856 | 0.792848 | 0.76823 | 0.750472 | 0.0487512 | 0.938877 | 0.72513 | 0.428906 | 0.241807 | 0.886165 | 0.433654 | 0.519012 | 0.764227 | 0.624349 | 0.791283 | 0.124945 | 0.0197959 | 0.697019 | 0.344718 | 0.4395 | 0.201712 | 0.632412 | 0.639618 | 0.228921 | 0.846998 | 0.559357 | 0.993575 | 0.515177 | 0.603754 | 0.105691 | 0.807134 | 0.255913 | 0.578056 | 0.495667 | 0.888912 | 0.273627 | 0.701844 | 0.498617 | 0.0647188 | 0.0348115 | 0.873896 | 0.367598 | 0.928037 | 0.50171 | 0.519917 | 0.208978 | 0.884601 | 0.0728106 | 0.278092 | 0.284935 | 0.937443 | 0.781108 | 0.862116 | 0.701986 |
92 | 0.762334 | 0.220067 | 0.347023 | 0.957494 | 0.22812 | 0.999467 | 0.973135 | 0.244465 | 0.0101484 | 0.230082 | 0.109062 | 0.65486 | 0.0264835 | 0.904145 | 0.804642 | 0.465101 | 0.688207 | 0.119605 | 0.892802 | 0.917713 | 0.225091 | 0.67144 | 0.22618 | 0.654758 | 0.50422 | 0.476194 | 0.18283 | 0.945699 | 0.939416 | 0.613648 | 0.293771 | 0.858145 | 0.129107 | 0.608375 | 0.362287 | 0.172677 | 0.666423 | 0.495363 | 0.904466 | 0.267665 | 0.254997 | 0.0443995 | 0.0446347 | 0.345407 | 0.138458 | 0.649483 | 0.992011 | 0.663119 | 0.748008 | 0.551811 | 0.763992 | 0.210181 | 0.579223 | 0.81332 | 0.34836 | 0.922445 | 0.12247 | 0.490795 | 0.424302 | 0.120766 | 0.892966 | 0.922136 | 0.433296 | 0.944465 | 0.794233 | 0.0623328 | 0.387254 | 0.958287 | 0.32741 | 0.344178 | 0.304494 | 0.989704 | 0.356856 | 0.70207 | 0.626874 | 0.466545 | 0.862964 | 0.791286 | 0.193242 | 0.754617 | 0.871622 | 0.846128 | 0.640863 | 0.762847 | 0.815479 | 0.347327 | 0.191246 | 0.550986 | 0.869687 | 0.164958 | 0.576934 | 0.0199307 | 0.422689 | 0.776889 | 0.527771 | 0.842317 | 0.45979 | 0.644228 | 0.00274102 | 0.150896 |
93 | 0.136345 | 0.88837 | 0.824329 | 0.219235 | 0.997592 | 0.0772966 | 0.968601 | 0.169473 | 0.33029 | 0.457537 | 0.874104 | 0.638415 | 0.955432 | 0.262067 | 0.793209 | 0.0595982 | 0.0901374 | 0.651668 | 0.969358 | 0.00489993 | 0.0754505 | 0.896987 | 0.511216 | 0.475477 | 0.503582 | 0.0860828 | 0.0547553 | 0.461234 | 0.181954 | 0.0726793 | 0.193559 | 0.77315 | 0.393442 | 0.664186 | 0.659851 | 0.150673 | 0.705529 | 0.105387 | 0.40537 | 0.740722 | 0.0332993 | 0.699813 | 0.690286 | 0.226804 | 0.506032 | 0.460255 | 0.854692 | 0.207863 | 0.334707 | 0.00271585 | 0.836004 | 0.388226 | 0.238078 | 0.700655 | 0.92384 | 0.407787 | 0.152155 | 0.378538 | 0.143906 | 0.621203 | 0.268995 | 0.834833 | 0.632686 | 0.35808 | 0.656038 | 0.45634 | 0.442143 | 0.727497 | 0.316382 | 0.946219 | 0.842994 | 0.131431 | 0.227156 | 0.305945 | 0.123914 | 0.514728 | 0.641622 | 0.874825 | 0.384457 | 0.997607 | 0.615283 | 0.553193 | 0.360829 | 0.887621 | 0.28654 | 0.55651 | 0.059058 | 0.641622 | 0.459027 | 0.211348 | 0.990484 | 0.871446 | 0.450593 | 0.967217 | 0.13895 | 0.227965 | 0.359436 | 0.388076 | 0.708926 | 0.453114 |
94 | 0.0158156 | 0.633832 | 0.781835 | 0.68029 | 0.0329445 | 0.736726 | 0.872594 | 0.091663 | 0.474104 | 0.331748 | 0.0449875 | 0.593458 | 0.811662 | 0.623303 | 0.657177 | 0.740964 | 0.595319 | 0.516588 | 0.102649 | 0.156836 | 0.515385 | 0.29578 | 0.462242 | 0.155946 | 0.468196 | 0.912184 | 0.0845146 | 0.00925977 | 0.699644 | 0.0734457 | 0.276204 | 0.26871 | 0.538888 | 0.99363 | 0.480439 | 0.832978 | 0.959809 | 0.976093 | 0.453268 | 0.973331 | 0.0823945 | 0.379021 | 0.974293 | 0.26908 | 0.169391 | 0.312781 | 0.545532 | 0.641316 | 0.702061 | 0.659741 | 0.54136 | 0.691007 | 0.361349 | 0.157117 | 0.217413 | 0.333297 | 0.685257 | 0.174708 | 0.915718 | 0.363146 | 0.628953 | 0.474267 | 0.699903 | 0.952568 | 0.0820167 | 0.900185 | 0.0429531 | 0.212827 | 0.628063 | 0.746622 | 0.118373 | 0.539678 | 0.748068 | 0.961209 | 0.0980194 | 0.371906 | 0.972589 | 0.870746 | 0.17895 | 0.352511 | 0.246384 | 0.185658 | 0.240653 | 0.266355 | 0.141423 | 0.454866 | 0.977867 | 0.929905 | 0.316267 | 0.828365 | 0.386196 | 0.384208 | 0.374794 | 0.0508551 | 0.341236 | 0.213431 | 0.134129 | 0.212028 | 0.667322 | 0.324541 |
95 | 0.945359 | 0.699973 | 0.622769 | 0.540021 | 0.236269 | 0.0751601 | 0.542248 | 0.0253301 | 0.803904 | 0.251383 | 0.733401 | 0.137531 | 0.143021 | 0.42197 | 0.736055 | 0.554266 | 0.864942 | 0.20904 | 0.628913 | 0.536632 | 0.520705 | 0.293135 | 0.353635 | 0.7347 | 0.626226 | 0.968074 | 0.546254 | 0.0387836 | 0.529944 | 0.604007 | 0.593621 | 0.817104 | 0.247805 | 0.0732189 | 0.292952 | 0.847092 | 0.475016 | 0.994994 | 0.091848 | 0.358471 | 0.489586 | 0.714769 | 0.562273 | 0.000626919 | 0.528073 | 0.491235 | 0.551917 | 0.938966 | 0.701734 | 0.452923 | 0.156206 | 0.991342 | 0.443748 | 0.151352 | 0.814841 | 0.830261 | 0.772459 | 0.534016 | 0.67215 | 0.0796134 | 0.819705 | 0.757717 | 0.595576 | 0.403722 | 0.234429 | 0.464878 | 0.266834 | 0.843296 | 0.535599 | 0.202782 | 0.899215 | 0.32932 | 0.668328 | 0.212915 | 0.510784 | 0.317206 | 0.0412203 | 0.918896 | 0.628934 | 0.61368 | 0.161025 | 0.571529 | 0.764452 | 0.434456 | 0.489504 | 0.603362 | 0.127036 | 0.58497 | 0.342794 | 0.686805 | 0.550471 | 0.780596 | 0.842515 | 0.841179 | 0.0667528 | 0.288047 | 0.799288 | 0.495506 | 0.425755 | 0.392719 |
96 | 0.0229929 | 0.280951 | 0.607385 | 0.781411 | 0.111574 | 0.143178 | 0.509535 | 0.922395 | 0.153332 | 0.738159 | 0.803896 | 0.62097 | 0.778997 | 0.556704 | 0.544714 | 0.814013 | 0.761532 | 0.616406 | 0.283712 | 0.299266 | 0.868318 | 0.35026 | 0.389976 | 0.136907 | 0.573304 | 0.318063 | 0.454461 | 0.738995 | 0.490752 | 0.299984 | 0.732843 | 0.721944 | 0.253916 | 0.684864 | 0.216962 | 0.85623 | 0.288352 | 0.888769 | 0.479709 | 0.787301 | 0.692928 | 0.932172 | 0.819243 | 0.794253 | 0.257425 | 0.106184 | 0.94706 | 0.139697 | 0.772222 | 0.41608 | 0.995589 | 0.289756 | 0.324292 | 0.00792133 | 0.057081 | 0.315955 | 0.415868 | 0.329661 | 0.479533 | 0.147409 | 0.37862 | 0.457078 | 0.931177 | 0.408307 | 0.20903 | 0.583968 | 0.761892 | 0.185535 | 0.0362761 | 0.140998 | 0.34648 | 0.900525 | 0.856197 | 0.294471 | 0.0727637 | 0.643428 | 0.0273025 | 0.141792 | 0.0924465 | 0.288061 | 0.301581 | 0.675579 | 0.317263 | 0.759492 | 0.487782 | 0.612095 | 0.377571 | 0.00321362 | 0.606809 | 0.433375 | 0.812961 | 0.327601 | 0.614918 | 0.318815 | 0.271426 | 0.631325 | 0.749559 | 0.772984 | 0.487052 | 0.517475 |
97 | 0.433131 | 0.543554 | 0.7726 | 0.794146 | 0.227171 | 0.746017 | 0.650968 | 0.825616 | 0.160258 | 0.90806 | 0.99092 | 0.815567 | 0.946953 | 0.526314 | 0.13987 | 0.260715 | 0.379914 | 0.499196 | 0.602648 | 0.697737 | 0.561949 | 0.161073 | 0.3924 | 0.0489393 | 0.487369 | 0.782283 | 0.18922 | 0.0891678 | 0.882443 | 0.457121 | 0.468955 | 0.595306 | 0.573501 | 0.268853 | 0.949176 | 0.616435 | 0.734401 | 0.375482 | 0.761297 | 0.460481 | 0.780322 | 0.916341 | 0.915449 | 0.882616 | 0.831101 | 0.687153 | 0.809392 | 0.416771 | 0.842343 | 0.293387 | 0.0921781 | 0.781365 | 0.953642 | 0.340595 | 0.554325 | 0.958002 | 0.831885 | 0.487815 | 0.179448 | 0.924443 | 0.038647 | 0.518215 | 0.871832 | 0.238139 | 0.386271 | 0.160826 | 0.156681 | 0.740655 | 0.180663 | 0.564312 | 0.278453 | 0.758523 | 0.79302 | 0.512035 | 0.726539 | 0.775916 | 0.546157 | 0.850793 | 0.766792 | 0.599228 | 0.0165184 | 0.1581 | 0.0280536 | 0.254412 | 0.304772 | 0.97899 | 0.121683 | 0.426145 | 0.0298111 | 0.838277 | 0.977399 | 0.530228 | 0.790503 | 0.92585 | 0.856429 | 0.748144 | 0.572517 | 0.918033 | 0.143058 | 0.702311 |
98 | 0.869619 | 0.0555949 | 0.0318486 | 0.709146 | 0.63083 | 0.592444 | 0.810994 | 0.0303389 | 0.803651 | 0.91932 | 0.343448 | 0.948045 | 0.962833 | 0.960167 | 0.518905 | 0.66293 | 0.633429 | 0.661832 | 0.283223 | 0.588355 | 0.094703 | 0.882157 | 0.0498134 | 0.301957 | 0.818455 | 0.111347 | 0.0181757 | 0.541536 | 0.0763182 | 0.300399 | 0.056612 | 0.983155 | 0.828346 | 0.737777 | 0.625891 | 0.30695 | 0.0166727 | 0.674993 | 0.807781 | 0.820713 | 0.220895 | 0.784529 | 0.964737 | 0.664262 | 0.904968 | 0.908153 | 0.741152 | 0.611167 | 0.854252 | 0.759731 | 0.737287 | 0.499929 | 0.401776 | 0.0262078 | 0.3322 | 0.643432 | 0.959909 | 0.605112 | 0.730366 | 0.0993901 | 0.649526 | 0.112271 | 0.0610474 | 0.607262 | 0.322734 | 0.394604 | 0.437716 | 0.252384 | 0.399161 | 0.910359 | 0.31712 | 0.747211 | 0.668496 | 0.0564397 | 0.81446 | 0.910205 | 0.711441 | 0.939491 | 0.930247 | 0.291938 | 0.0488213 | 0.710405 | 0.288698 | 0.540349 | 0.315111 | 0.779968 | 0.806155 | 0.162673 | 0.599859 | 0.811899 | 0.849365 | 0.462997 | 0.631802 | 0.73325 | 0.391421 | 0.746609 | 0.25695 | 0.259309 | 0.316008 | 0.927874 |
99 | 0.13305 | 0.135136 | 0.26552 | 0.956448 | 0.199567 | 0.906343 | 0.569336 | 0.592827 | 0.0379673 | 0.831907 | 0.142565 | 0.756968 | 0.173521 | 0.118779 | 0.568862 | 0.0437033 | 0.894534 | 0.337584 | 0.437253 | 0.408534 | 0.362262 | 0.737233 | 0.869281 | 0.644731 | 0.208085 | 0.130726 | 0.159655 | 0.0712457 | 0.80799 | 0.300658 | 0.0794387 | 0.658602 | 0.784628 | 0.0558377 | 0.857013 | 0.44251 | 0.948263 | 0.508329 | 0.719586 | 0.558919 | 0.253305 | 0.153016 | 0.255748 | 0.851215 | 0.0669983 | 0.28314 | 0.28994 | 0.306653 | 0.662155 | 0.00359091 | 0.22232 | 0.24429 | 0.564036 | 0.347404 | 0.667293 | 0.807969 | 0.198947 | 0.758581 | 0.871046 | 0.963682 | 0.619251 | 0.145509 | 0.238922 | 0.17581 | 0.953074 | 0.374189 | 0.242029 | 0.338471 | 0.483978 | 0.365152 | 0.0532596 | 0.101752 | 0.705438 | 0.689481 | 0.0204376 | 0.878013 | 0.643157 | 0.96958 | 0.863947 | 0.363679 | 0.251242 | 0.410193 | 0.368199 | 0.744824 | 0.616705 | 0.0495284 | 0.224624 | 0.506634 | 0.919439 | 0.553034 | 0.173774 | 0.834669 | 0.123312 | 0.852623 | 0.275414 | 0.353386 | 0.919929 | 0.433747 | 0.828176 | 0.226691 |
100 | 0.558299 | 0.901219 | 0.763849 | 0.417315 | 0.738941 | 0.423358 | 0.228483 | 0.418635 | 0.256782 | 0.964993 | 0.0587869 | 0.827805 | 0.253593 | 0.584741 | 0.0614619 | 0.632876 | 0.882085 | 0.115376 | 0.046288 | 0.276332 | 0.715355 | 0.949477 | 0.735478 | 0.85174 | 0.564371 | 0.291316 | 0.475809 | 0.433264 | 0.926144 | 0.513091 | 0.623026 | 0.779111 | 0.868375 | 0.980566 | 0.588499 | 0.254105 | 0.258102 | 0.266725 | 0.876868 | 0.950617 | 0.982882 | 0.67731 | 0.251895 | 0.891319 | 0.40898 | 0.779017 | 0.980126 | 0.42333 | 0.574415 | 0.847564 | 0.466023 | 0.56034 | 0.885708 | 0.294494 | 0.267984 | 0.983816 | 0.0977562 | 0.255569 | 0.355142 | 0.994539 | 0.85351 | 0.83745 | 0.0749992 | 0.855517 | 0.123701 | 0.739452 | 0.501353 | 0.579769 | 0.330581 | 0.195715 | 0.196698 | 0.441714 | 0.743273 | 0.754156 | 0.023031 | 0.496328 | 0.0325996 | 0.442387 | 0.233977 | 0.550164 | 0.151497 | 0.417525 | 0.902371 | 0.5659 | 0.644214 | 0.168648 | 0.765826 | 0.872552 | 0.736725 | 0.279124 | 0.60392 | 0.32334 | 0.895874 | 0.374463 | 0.855634 | 0.818621 | 0.588076 | 0.487043 | 0.669601 | 0.473727 |
we can see that 92 of its columns were not printed. Also we get its first 30 rows. You can easily change this behavior by changing the value of ENV["LINES"]
and ENV["COLUMNS"]
.
withenv("LINES" => 10, "COLUMNS" => 200) do
show(df)
end
100×100 DataFrame
Row │ x1 x2 x3 x4 x5 x6 x7 x8 x9 x10 x11 x12 x13 x14 x15 x16 x17 x18 ⋯
│ Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 Float64 ⋯
─────┼──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
1 │ 0.868306 0.380515 0.657908 0.809605 0.0818846 0.504407 0.100429 0.280353 0.837374 0.0278786 0.872717 0.160118 0.257644 0.316538 0.68689 0.0861048 0.836218 0.934653 ⋯
⋮ │ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋱
82 columns and 99 rows omitted
Most elementary get and set operations#
Given the DataFrame
x
we have created earlier, here are various ways to grab one of its columns as a Vector
.
x = DataFrame(A=[1, 2], B=[1.0, missing], C=["a", "b"])
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 1 | 1.0 | a |
2 | 2 | missing | b |
all get the vector stored in our DataFrame without copying it
x.A, x[!, 1], x[!, :A]
([1, 2], [1, 2], [1, 2])
the same using string indexing
x."A", x[!, "A"]
([1, 2], [1, 2])
note that this creates a copy
x[:, 1]
2-element Vector{Int64}:
1
2
x[:, 1] === x[:, 1]
false
To grab one row as a DataFrame
, we can index as follows.
x[1:1, :]
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 1 | 1.0 | a |
this produces a DataFrameRow which is treated as 1-dimensional object similar to a NamedTuple
x[1, :]
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 1 | 1.0 | a |
We can grab a single cell or element with the same syntax to grab an element of an array.
x[1, 1]
1
or a new DataFrame
that is a subset of rows and columns
x[1:2, 1:2]
Row | A | B |
---|---|---|
Int64 | Float64? | |
1 | 1 | 1.0 |
2 | 2 | missing |
You can also use Regex
to select columns and Not
from InvertedIndices.jl both to select rows and columns
x[Not(1), r"A"]
Row | A |
---|---|
Int64 | |
1 | 2 |
!
indicates that underlying columns are not copied
x[!, Not(1)]
Row | B | C |
---|---|---|
Float64? | String | |
1 | 1.0 | a |
2 | missing | b |
:
means that the columns will get copied
x[:, Not(1)]
Row | B | C |
---|---|---|
Float64? | String | |
1 | 1.0 | a |
2 | missing | b |
Assignment of a scalar to a data frame can be done in ranges using broadcasting:
x[1:2, 1:2] .= 1
x
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 1 | 1.0 | a |
2 | 1 | 1.0 | b |
Assignment of a vector of length equal to the number of assigned rows using broadcasting
x[1:2, 1:2] .= [1, 2]
x
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 1 | 1.0 | a |
2 | 2 | 2.0 | b |
Assignment or of another data frame of matching size and column names, again using broadcasting:
x[1:2, 1:2] .= DataFrame([5 6; 7 8], [:A, :B])
x
Row | A | B | C |
---|---|---|---|
Int64 | Float64? | String | |
1 | 5 | 6.0 | a |
2 | 7 | 8.0 | b |
Caution
With df[!, :col]
and df.col
syntax you get a direct (non copying) access to a column of a data frame.
This is potentially unsafe as you can easily corrupt data in the df
data frame if you resize, sort, etc. the column obtained in this way.
Therefore such access should be used with caution.
Similarly df[!, cols]
when cols
is a collection of columns produces a new data frame that holds the same (not copied) columns as the source df
data frame. Similarly, modifying the data frame obtained via df[!, cols]
might cause problems with the consistency of df
.
The df[:, :col]
and df[:, cols]
syntaxes always copy columns so they are safe to use (and should generally be preferred except for performance or memory critical use cases).
Here are examples of how Cols
and Between
can be used to select columns of a data frame.
x = DataFrame(rand(4, 5), :auto)
Row | x1 | x2 | x3 | x4 | x5 |
---|---|---|---|---|---|
Float64 | Float64 | Float64 | Float64 | Float64 | |
1 | 0.82831 | 0.181792 | 0.661018 | 0.956517 | 0.179727 |
2 | 0.521771 | 0.384806 | 0.570405 | 0.540328 | 0.545185 |
3 | 0.69988 | 0.0934056 | 0.730775 | 0.0464271 | 0.307018 |
4 | 0.553744 | 0.96443 | 0.884003 | 0.316823 | 0.593356 |
x[:, Between(:x2, :x4)]
Row | x2 | x3 | x4 |
---|---|---|---|
Float64 | Float64 | Float64 | |
1 | 0.181792 | 0.661018 | 0.956517 |
2 | 0.384806 | 0.570405 | 0.540328 |
3 | 0.0934056 | 0.730775 | 0.0464271 |
4 | 0.96443 | 0.884003 | 0.316823 |
x[:, Cols("x1", Between("x2", "x4"))]
Row | x1 | x2 | x3 | x4 |
---|---|---|---|---|
Float64 | Float64 | Float64 | Float64 | |
1 | 0.82831 | 0.181792 | 0.661018 | 0.956517 |
2 | 0.521771 | 0.384806 | 0.570405 | 0.540328 |
3 | 0.69988 | 0.0934056 | 0.730775 | 0.0464271 |
4 | 0.553744 | 0.96443 | 0.884003 | 0.316823 |
Views#
You can simply create a view of a DataFrame
(it is more efficient than creating a materialized selection). Here are the possible return value options.
@view x[1:2, 1]
2-element view(::Vector{Float64}, 1:2) with eltype Float64:
0.8283104100114852
0.5217713809440678
@view x[1, 1]
0-dimensional view(::Vector{Float64}, 1) with eltype Float64:
0.8283104100114852
a DataFrameRow, the same as for x[1, 1:2] without a view
@view x[1, 1:2]
Row | x1 | x2 |
---|---|---|
Float64 | Float64 | |
1 | 0.82831 | 0.181792 |
a SubDataFrame
@view x[1:2, 1:2]
Row | x1 | x2 |
---|---|---|
Float64 | Float64 | |
1 | 0.82831 | 0.181792 |
2 | 0.521771 | 0.384806 |
Adding new columns to a data frame#
df = DataFrame()
using setproperty!
(element assignment)
x = [1, 2, 3]
df.a = x
df
Row | a |
---|---|
Int64 | |
1 | 1 |
2 | 2 |
3 | 3 |
no copy is performed (sharing the same memory address)
df.a === x
true
using setindex!
df[!, :b] = x
df[:, :c] = x
df
Row | a | b | c |
---|---|---|---|
Int64 | Int64 | Int64 | |
1 | 1 | 1 | 1 |
2 | 2 | 2 | 2 |
3 | 3 | 3 | 3 |
no copy is performed
df.b === x
true
With copying
!
and :
has different effects
df.c === x
false
Element-wise assignment
df[!, :d] .= x
df[:, :e] .= x
df
Row | a | b | c | d | e |
---|---|---|---|---|---|
Int64 | Int64 | Int64 | Int64 | Int64 | |
1 | 1 | 1 | 1 | 1 | 1 |
2 | 2 | 2 | 2 | 2 | 2 |
3 | 3 | 3 | 3 | 3 | 3 |
both copy, so in this case !
and :
has the same effect
df.d === x, df.e === x
(false, false)
note that in our data frame columns :a
and :b
store the vector x
(not a copy)
df.a === df.b === x
true
This can lead to silent errors. For example this code leads to a bug (note that calling pairs
on eachcol(df)
creates an iterator of (column name, column) pairs):
try
for (n, c) in pairs(eachcol(df))
println("$n: ", pop!(c))
end
catch e
show(e)
end
a: 3
b: 2
c: 3
d: 3
e: 3
note that for column :b
we printed 2
as 3
was removed from it when we used pop!
on column :a
.
Such mistakes sometimes happen. Because of this DataFrames.jl performs consistency checks before doing an expensive operation (most notably before showing a data frame).
try
show(df)
catch e
show(e)
end
AssertionError("Data frame is corrupt: length of column :c (2) does not match length of column 1 (1). The column vector has likely been resized unintentionally (either directly or because it is shared with another data frame).")
We can investigate the columns to find out what happened:
collect(pairs(eachcol(df)))
5-element Vector{Pair{Symbol, AbstractVector}}:
:a => [1]
:b => [1]
:c => [1, 2]
:d => [1, 2]
:e => [1, 2]
The output confirms that the data frame df
got corrupted.
DataFrames.jl supports a complete set of getindex
, getproperty
, setindex!
, setproperty!
, view
, broadcasting, and broadcasting assignment operations. The details are explained here: http://juliadata.github.io/DataFrames.jl/latest/lib/indexing/.
Comparisons#
using DataFrames
df = DataFrame(rand(2, 3), :auto)
Row | x1 | x2 | x3 |
---|---|---|---|
Float64 | Float64 | Float64 | |
1 | 0.561917 | 0.116202 | 0.888651 |
2 | 0.82727 | 0.63633 | 0.381904 |
df2 = copy(df)
Row | x1 | x2 | x3 |
---|---|---|---|
Float64 | Float64 | Float64 | |
1 | 0.561917 | 0.116202 | 0.888651 |
2 | 0.82727 | 0.63633 | 0.381904 |
compares column names and contents
df == df2
true
create a minimally different data frame and use isapprox
for comparison
df3 = df2 .+ eps()
Row | x1 | x2 | x3 |
---|---|---|---|
Float64 | Float64 | Float64 | |
1 | 0.561917 | 0.116202 | 0.888651 |
2 | 0.82727 | 0.63633 | 0.381904 |
df == df3
false
isapprox(df, df3)
true
isapprox(df, df3, atol=eps() / 2)
false
missings
are handled as in Julia Base
df = DataFrame(a=missing)
Row | a |
---|---|
Missing | |
1 | missing |
Equality test shows missing.
df == df
missing
The same object?
df === df
true
isequal(df, df)
true
This notebook was generated using Literate.jl.