UNPKG

@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
"use strict"; 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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"}