Installation |
Command |
API |
Examples |
Citation
Check out our latest release to find a plethora of prebuilt binaries for various architectures (AMD64, ARM64) and operating systems (Windows, Linux, MacOS). Simply downloading what fits you should work since everything is compiled into a single file.
include(FetchContent)
# Use GIT_TAG to request the tag (or branch) you would like
FetchContent_Declare(measure GIT_REPOSITORY https://github.com/tira-io/measure.git GIT_TAG v0.0.1)
FetchContent_MakeAvailable(measure)
target_link_libraries(<yourtarget> measure::measureapi)
Generally, measure
offers two ways of measuring programs: a commandline interface and a C-API that can be called from and integrated into other languages easily. Please also have a look at the examples to see how it can be used.
Type measurecmd --help
to get a full description of the supported commandline arguments. Generally, you only need to call
measurecmd "<command>"
to measure everything, you may want to know about the shell command <command>
.
#include <measureapi.h>
int main(int argc, char* argv[]) {
const char* provider[] = {"git", "system", "gpu", "energy", NULL};
char* outputJson;
mapiConfig config = {.provider = provider, .monitor = true, .pollIntervallMs = 1000};
mapiMeasure* measure = mapiStartMeasure(config);
/** Measure your code here **/
mapiStopMeasure(handle, &outputJson);
/** The collected data is serialized into outputJson and needs to be freed by the caller **/
}
Timeseries datatypes are denoted T...
, where T
is the datatype of each entry. Similarly, arrays are denoted as [T]
.
Name | Type | Description | Status |
---|---|---|---|
git > isrepo |
Boolean | Checks if the current working directory is (part of) a Git repository | Implemented |
git > tag |
String | Retrieves the tag or branch name that is checked out | Implemented |
git > last commit |
String | Holds the hash identifying the latest commit | Implemented |
git > remote > origin |
String | Contains the URL to the origin remote if such a remote exists |
Implemented |
git > up to date |
Boolean | True if no changes to files in the repository are uncommitted | Implemented |
git > untracked files |
Boolean | True if files exist that are not ignored by the .gitignore and are not checked into the repository |
Implemented |
git > hash |
String | The hash of all files checked into the repository | Planned |
Name | Type | Description | Status |
---|---|---|---|
elapsed time > wallclock (ms) |
Float | The wallclock ("real") time the program took to run | Implemented |
elapsed time > user (ms) |
Float | The total time the program spent in user mode | Implemented |
elapsed time > system (ms) |
Float | The total time the program spent in system mode | Implemented |
resources > RAM Used (KB) |
UInt... | The time series of RAM utilization | Implemented |
resources > Max RAM Used (KB) |
UInt | The most amount of RAM the program used at any one point | Implemented |
resources > CPU Utilization (%) |
UInt... | The time series of process' CPU utilization of the | Planned |
system > num cores |
UInt | The total number of CPU cores installed in the system | Implemented |
system > RAM (MB) |
UInt | The total amount of RAM installed in the system | Implemented |
system > RAM Used (MB) |
UInt... | The time series of entire system's RAM utilization | Planned |
system > CPU Utilization (%) |
Float... | The time series of entire system's CPU utilization | Planned |
Name | Type | Description | Status |
---|---|---|---|
energy > CPU |
Float... | Planned | |
energy > GPU |
Float... | Planned | |
energy > DRAM |
Float... | Planned |
Name | Type | Description | Status |
---|---|---|---|
resources > VRAM Used (MB) |
[UInt]... | Planned | |
resources > Max VRAM Used (MB) |
[UInt] | Planned | |
resources > GPU Utilization (%) |
[Float]... | Planned | |
resources > Max GPU Utilization (%) |
[Float] | Planned | |
system > VRAM (MB) |
[UInt] | Implemented | |
system > Max VRAM Used (MB) |
[UInt] | Implemented | |
system > VRAM Used (MB) |
[UInt]... | Planned |
TODO