@oaklean/profiler-core
Version:
Part of the @oaklean suite. It provides all basic functions to work with the `.oak` file format. It allows parsing the `.oak` file format as well as tools for analyzing the measurement values. It also provides all necessary capabilities required for prec
194 lines • 21.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.StateMachineLogger = void 0;
const LoggerHelper_1 = require("../LoggerHelper");
class StateMachineLogger {
static logState(depth, cpuNode, currentState) {
var _a;
/*
[STATE] moduleFunction_fileA_0 (./fileA.js)
├─ Depth : 1
├─ CPU Node : 001
├─ ReportID : 1
├─ SourceNodeID : 3
├─ Scope : module
├─ Type : intern
├─ Headless : false
├─ Profiler Hits : 2
├─ CPU Time : self=20 µs | total=30 µs
├─ CPU Energy : self=0 mJ | total=0 mJ
├─ RAM Energy : self=0 mJ | total=0 mJ
*/
if (currentState.callIdentifier.sourceNode === null) {
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.successString('[STATE]'), '(root)');
return;
}
const sourceNodeIndex = (_a = currentState.callIdentifier.sourceNode) === null || _a === void 0 ? void 0 : _a.getIndex();
if (sourceNodeIndex === undefined) {
throw new Error('InsertCPUProfileStateMachine.logState: sourceNode has no index');
}
const sensorValues = currentState.callIdentifier.sourceNode.sensorValues;
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.successString('[STATE]'), `${sourceNodeIndex.functionName}`, `(${sourceNodeIndex.pathIndex.identifier})`, '\n' +
StateMachineLogger.formatState({
Depth: depth.toString(),
'CPU Node': String(cpuNode.index).padStart(3, '0'),
ReportID: currentState.callIdentifier.report.internID.toString(),
SourceNodeID: currentState.callIdentifier.sourceNode.id.toString(),
Scope: currentState.scope,
Type: currentState.type,
Headless: currentState.headless.toString(),
'Profiler Hits': `${sensorValues.profilerHits}`,
'CPU Time': `self=${sensorValues.selfCPUTime} µs | total=${sensorValues.aggregatedCPUTime} µs | l=${sensorValues.langInternalCPUTime} µs | i=${sensorValues.internCPUTime} µs | e=${sensorValues.externCPUTime} µs`,
'CPU Energy': `self=${sensorValues.selfCPUEnergyConsumption} mJ | total=${sensorValues.aggregatedCPUEnergyConsumption} mJ | l=${sensorValues.langInternalCPUEnergyConsumption} mJ | i=${sensorValues.internCPUEnergyConsumption} mJ | e=${sensorValues.externCPUEnergyConsumption} mJ `,
'RAM Energy': `self=${sensorValues.selfRAMEnergyConsumption} mJ | total=${sensorValues.aggregatedRAMEnergyConsumption} mJ | l=${sensorValues.langInternalRAMEnergyConsumption} mJ | i=${sensorValues.internRAMEnergyConsumption} mJ | e=${sensorValues.externRAMEnergyConsumption} mJ`
}));
const iterators = {
LANG_INTERNAL: currentState.callIdentifier.sourceNode.lang_internal.values(),
INTERN: currentState.callIdentifier.sourceNode.intern.values(),
EXTERN: currentState.callIdentifier.sourceNode.extern.values()
};
for (const [type, iterator] of Object.entries(iterators)) {
let hasEntries = false;
for (const referenceSourceNode of iterator) {
if (hasEntries === false) {
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.warnString(`${type} REFERENCES`));
hasEntries = true;
}
StateMachineLogger.logSourceNodeReference(referenceSourceNode);
}
}
}
static logSourceNodeReference(referenceSourceNode) {
LoggerHelper_1.LoggerHelper.log(`SourceNodeID: ${referenceSourceNode.id.toString()}\n` +
StateMachineLogger.formatReference({
'CPU Time': `self=${referenceSourceNode.sensorValues.selfCPUTime} µs | total=${referenceSourceNode.sensorValues.aggregatedCPUTime} µs`,
'CPU Energy': `self=${referenceSourceNode.sensorValues.selfCPUEnergyConsumption} mJ | total=${referenceSourceNode.sensorValues.aggregatedCPUEnergyConsumption} mJ`,
'RAM Energy': `self=${referenceSourceNode.sensorValues.selfRAMEnergyConsumption} mJ | total=${referenceSourceNode.sensorValues.aggregatedRAMEnergyConsumption} mJ`
}));
}
static logLeaveTransition(currentState, nextState) {
var _a, _b;
const currentSourceNodeIndex = (_a = currentState.callIdentifier.sourceNode) === null || _a === void 0 ? void 0 : _a.getIndex();
const currentSourceNodeName = currentSourceNodeIndex !== undefined
? currentSourceNodeIndex.functionName
: '(root)';
const nextSourceNodeIndex = (_b = nextState.callIdentifier.sourceNode) === null || _b === void 0 ? void 0 : _b.getIndex();
const nextSourceNodeName = nextSourceNodeIndex !== undefined
? nextSourceNodeIndex.functionName
: '(root)';
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.errorString('[LEAVE TRANSITION]'), `${currentSourceNodeName}`, `-> ${nextSourceNodeName}`);
}
static logTransition(cpuNode, transition, accountingInfo, currentState, nextState) {
var _a, _b;
/*
[TRANSITION] (root) -> moduleFunction_fileA_0
├─ CPU Node : 000
├─ Transition : toModule
├─ AccountingType : accountToExtern
├─ FirstTimeVisited : true
├─ Accounted Hits : 2
├─ Accounted CPU Time : self=20 µs | total=30 µs
├─ Accounted CPU Energy : self=0 mJ | total=0 mJ
├─ Accounted RAM Energy : self=0 mJ | total=0 mJ
*/
const currentSourceNodeIndex = (_a = currentState.callIdentifier.sourceNode) === null || _a === void 0 ? void 0 : _a.getIndex();
const currentSourceNodeName = currentSourceNodeIndex !== undefined
? currentSourceNodeIndex.functionName
: '(root)';
const nextSourceNodeIndex = (_b = nextState.callIdentifier.sourceNode) === null || _b === void 0 ? void 0 : _b.getIndex();
const nextSourceNodeName = nextSourceNodeIndex !== undefined
? nextSourceNodeIndex.functionName
: '(root)';
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.warnString('[TRANSITION]'), `${currentSourceNodeName} -> ${nextSourceNodeName}`, '\n' +
StateMachineLogger.formatTransition({
'CPU Node': String(cpuNode.index).padStart(3, '0'),
Transition: transition.transition,
'Create Link': transition.options.createLink.toString(),
AccountingType: accountingInfo.type,
FirstTimeVisited: accountingInfo.accountedSourceNode.firstTimeVisited.toString(),
'Accounted Hits': `${cpuNode.profilerHits}`,
'Accounted CPU Time': `self=${(accountingInfo === null || accountingInfo === void 0 ? void 0 : accountingInfo.accountedSensorValues.selfCPUTime) || 0} µs | total=${(accountingInfo === null || accountingInfo === void 0 ? void 0 : accountingInfo.accountedSensorValues.aggregatedCPUTime) || 0} µs`,
'Accounted CPU Energy': `self=${(accountingInfo === null || accountingInfo === void 0 ? void 0 : accountingInfo.accountedSensorValues.selfCPUEnergyConsumption) || 0} mJ | total=${(accountingInfo === null || accountingInfo === void 0 ? void 0 : accountingInfo.accountedSensorValues.aggregatedCPUEnergyConsumption) || 0} mJ`,
'Accounted RAM Energy': `self=${(accountingInfo === null || accountingInfo === void 0 ? void 0 : accountingInfo.accountedSensorValues.selfRAMEnergyConsumption) || 0} mJ | total=${(accountingInfo === null || accountingInfo === void 0 ? void 0 : accountingInfo.accountedSensorValues.aggregatedRAMEnergyConsumption) || 0} mJ`
}));
}
static logCompensation(depth, cpuNode, currentState, compensation, title) {
/*
[CREATE COMPENSATION | APPLY COMPENSATION] 2 moduleFunction_fileA_0 (./fileA.js)
├─ Depth : 2
├─ CPU Node : 002
├─ ReportID : 1
├─ SourceNodeID : 5
├─ Scope : module
├─ Type : intern
├─ Headless : false
├─ Compensated CPU Time : self=30 µs | total=0 µs
├─ Compensated CPU Energy : self=0 mJ | total=0 mJ
├─ Compensated RAM Energy : self=0 mJ | total=0 mJ
*/
if (currentState.callIdentifier.sourceNode === null) {
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.errorString(`[${title}]`), compensation.id.toString(), `(${cpuNode.sourceLocation.rawFunctionName})`, '~', '(root)');
return;
}
const sourceNodeIndex = currentState.callIdentifier.sourceNode.getIndex();
if (sourceNodeIndex === undefined) {
throw new Error('InsertCPUProfileStateMachine.logCompensation: sourceNode has no index');
}
const createdComp = compensation.createdComp;
const carriedComp = compensation.carriedComp;
LoggerHelper_1.LoggerHelper.log(LoggerHelper_1.LoggerHelper.errorString(`[${title}]`), compensation.id.toString(), `(${cpuNode.sourceLocation.rawFunctionName})`, '~', `${sourceNodeIndex.functionName}`, `(${sourceNodeIndex.pathIndex.identifier})`, '\n' +
StateMachineLogger.formatCompensation({
'Compensation ID': compensation.id.toString(),
Depth: depth.toString(),
'CPU Node': String(cpuNode.index).padStart(3, '0'),
ReportID: currentState.callIdentifier.report.internID.toString(),
SourceNodeID: currentState.callIdentifier.sourceNode.id.toString(),
Scope: currentState.scope,
Type: currentState.type,
Headless: currentState.headless.toString(),
'Compensated CPU Time': `created=${createdComp === null || createdComp === void 0 ? void 0 : createdComp.aggregatedCPUTime} µs | carried=${carriedComp === null || carriedComp === void 0 ? void 0 : carriedComp.aggregatedCPUTime} µs`,
'Compensated CPU Energy': `created=${createdComp === null || createdComp === void 0 ? void 0 : createdComp.aggregatedCPUEnergyConsumption} mJ | carried=${carriedComp === null || carriedComp === void 0 ? void 0 : carriedComp.aggregatedCPUEnergyConsumption} mJ`,
'Compensated RAM Energy': `created=${createdComp === null || createdComp === void 0 ? void 0 : createdComp.aggregatedRAMEnergyConsumption} mJ | carried=${carriedComp === null || carriedComp === void 0 ? void 0 : carriedComp.aggregatedRAMEnergyConsumption} mJ`
}));
}
}
exports.StateMachineLogger = StateMachineLogger;
StateMachineLogger.formatReference = LoggerHelper_1.LoggerHelper.treeStyleKeyValues(['CPU Time', 'CPU Energy', 'RAM Energy'], 29);
StateMachineLogger.formatState = LoggerHelper_1.LoggerHelper.treeStyleKeyValues([
'Depth',
'CPU Node',
'ReportID',
'SourceNodeID',
'Scope',
'Type',
'Headless',
'Profiler Hits',
'CPU Time',
'CPU Energy',
'RAM Energy'
], 29);
StateMachineLogger.formatTransition = LoggerHelper_1.LoggerHelper.treeStyleKeyValues([
'CPU Node',
'Transition',
'Create Link',
'AccountingType',
'FirstTimeVisited',
'Accounted Hits',
'Accounted CPU Time',
'Accounted CPU Energy',
'Accounted RAM Energy'
], 29);
StateMachineLogger.formatCompensation = LoggerHelper_1.LoggerHelper.treeStyleKeyValues([
'Compensation ID',
'Depth',
'CPU Node',
'ReportID',
'SourceNodeID',
'Scope',
'Type',
'Headless',
'Compensated CPU Time',
'Compensated CPU Energy',
'Compensated RAM Energy'
], 29);
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StateMachineLogger.js","sourceRoot":"","sources":["../../../../src/helper/InsertCPUProfileHelper/StateMachineLogger.ts"],"names":[],"mappings":"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"}