Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
@operational/frame
Advanced tools
⚠️ This is highly experimental package and doesn't follow semantic versioning yet.
yarn add @operational/frame
Frame represents multidimensional data. It is similar to SQL table or CSV file or Pandas DataFrame or n-dimensional space described by Cartesian coordinates (x,y,z...).
DataFrame has two parameters:
schema
- name of dimensions (as well called columns), order of dimensions and type of dimensionsdata
- actual data, represented as list of lists. Technically speaking it is list of tuples for row-oriented implemntation and tuple of lists for column-oriented implementation.Frames are used as medium for passing and working with multidimensional data. It can be consumed by <PivotGrid />
to show pivot table or by visual components to show charts.
+--------+
|Id|Name |
+--------+
| 1|Hilda|
| 2|David|
| 3|Frida|
| | |
...
type Schema<Name extends string> = Array<{ name: Name; type?: any }>;
At the moment of writing type is not used, it is here for future extension. It is up to library consumer how to use it, that is why it is marked as any
. For example, it can be "string" | "number" | "boolean"
or types from io-ts.
const schema = [{ name: "Id" as "Id", type: "number" }, { name: "Character" as "Character", type: "string" }];
At the moment of writing Frames are implemented as row-oriented storages, this should not affect consumer of the library and we can switch to column-oriented storage in the future. Now for simplicity shape of data is as well expected to be row-oriented.
For example:
const data = [[1, "Hilda"], [2, "David"], [3, "Frida"]];
All Frames are immutable. As soon they were created they do no mutate internal values, but at the moment of writing they do not have any protection against mutation from the outside, for example you can mutate array of data if it was passed as variable and you still have access to this variable, we leave it to developers to not violate immutability of internals.
Because Frames are immutable, they share the same data and scheme - passed as reference, not copied.
Where it makes sense, Frames use lazy calculations, for example PivotFrame indexes lazily calculated.
DataFrame - is the Frame that developer would use as starting point, to construct first frame, all other Frames would be possible to get from it.
import { DataFrame } from "@operational/frame";
const dataFrame = new DataFrame(schema, data);
PivotFrame is the special case of Frame designed for <PivotGrid />
to show pivot table. In addition to data and scheme it has two indexes - one for columns and one for rows.
+----------+
|Columns |
+----------------+
|Rows |Cells |
| | |
| | |
| | |
+-----+----------+
To get the PivotFrame you need to use pivot
method on DataFrame
instance.
const pivotedFrame = dataFrame.pivot({ rows: ["A", "B"], columns: ["C", "D"] });
rows
and columns
indexes counstructed by taking vertical slice of DataFrame with corresponding columns and collecting unique rows in those DataFrames. This operation corresponds to following SQL statement
SELECT DISTINCT column_name, column_name FROM table_name;
For example, if we have following DataFrame and want to build index for rows (rows: ["A", "B"]
):
A | B | C | D | E |
---|---|---|---|---|
Q | W | z | x | 1 |
E | R | z | x | 2 |
E | R | c | v | 3 |
Vertical slice with A, B columns would look like
A | B |
---|---|
Q | W |
E | R |
E | R |
After leaving out only unique combinations
A | B |
---|---|
Q | W |
E | R |
pivotedFrame.rowsIndex(); // [["Q", "W"], ["E", "R"]];
To access data via index we can use row
, column
or cell
methods, which will return new Frame with corresponding horizontal slices of the data (FragmentFrame).
pivotedFrame.row(1); // FragmentFrame<[["E", "R", "z", "x", 2], ["E", "R", "c", "v", 3]]>
pivotedFrame.cell(1, 0); // FragmentFrame<[["E", "R", "z", "x", 2]]>
FragmentFrame - limited version of DataFrame. Maybe in the future we will remove it in favour of DataFrame. Having it separated from DataFrame simplifies code, most likely this will change as soon as we will add more code.
At the moment of writing it exposes:
peak
method to select value of column from the first row of frame (assumes there is only one row in the frame). Used for the <PivotGrid />
FAQs
Contiamo DataFrame.
The npm package @operational/frame receives a total of 39 weekly downloads. As such, @operational/frame popularity was classified as not popular.
We found that @operational/frame demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.