awslabs / ml-io
Components & Dependencies

An overview of source code logical components.

Intro

Logical decomposition is a representation of the organization of the main source code, where every and each file is put in exactly one logical component.

  • A software system can have one or more logical decompositions.
  • A logical decomposition can be defined in two ways in Sokrates.
  • First approach is based on the folders structure. Components are mapped to folders at defined folder depth relative to the source code root.
  • Second approach is based on explicit definition of each component. In such explicit definitions, components are explicitly named and their files are selected based on explicitly defined path and content filters.
  • A logical decomposition is considered invalid if a file is selected into two or more components.This constraint is introduced in order to facilitate measuring of dependencies among components.
  • Files not assigned to any component are put into a special "Unclassified" component.
Learn more...
Logical Decompositions Overview

Analyzed system has 1 logical decomposition:

  • primary (24 components)

Logical Decomposition #1: PRIMARY

The decompositions is based on the folder structure (relative to the source code root), with automatically defined folder depth to have at least 10 components.

Bubble Chart | Tree Map
Components
The "primary" logical decomposition has 24 components.
  • 243 files, 16,244 lines of code (100.0% vs. main code).
  • "src/mlio-py/mlio" is biggest, containing 34.83% of code.
  • "include/mlio/integ" is smallest, containing 0.07% of code.


src/mlio-py/mlio5658 LOC (34%) 47 files
src/mlio3177 LOC (19%) 34 files
include/mlio1943 LOC (11%) 32 files
src/mlio/record_readers850 LOC (5%) 23 files
src/mlio/streams750 LOC (4%) 13 files
src/mlio/instance_readers658 LOC (4%) 14 files
include/mlio/memory421 LOC (2%) 10 files
src/mlio/data_stores408 LOC (2%) 9 files
include/mlio/streams360 LOC (2%) 9 files
src/mlio/memory342 LOC (2%) 10 files
src/mlio/detail293 LOC (1%) 10 files
include/mlio/data_stores226 LOC (1%) 6 files
include/mlio/record_readers216 LOC (1%) 7 files
src/mlio/util158 LOC (<1%) 2 files
packaging/conda/recipe150 LOC (<1%) 3 files
include/mlio/util148 LOC (<1%) 4 files
src/mlio/integ135 LOC (<1%) 1 files
cmake97 LOC (<1%) 2 files
include/mlio/detail71 LOC (<1%) 1 files
include66 LOC (<1%) 1 files
src/mlio-py61 LOC (<1%) 2 files
src22 LOC (<1%) 1 files
ROOT22 LOC (<1%) 1 files
include/mlio/integ12 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-01-31 19:15