diag codePerformance: Difference between revisions
| Lou Montana (talk | contribs) m (Some wiki formatting) | Lou Montana (talk | contribs)  | ||
| (7 intermediate revisions by 2 users not shown) | |||
| Line 12: | Line 12: | ||
| Engine alternative to [[BIS_fnc_codePerformance]]. | Engine alternative to [[BIS_fnc_codePerformance]]. | ||
| |mp= For security purposes, this command will only run for 1 cycle in multiplayer, unless in-game [[Arma 3: Debug Console|debug console]] is available via [[Description.ext|description.ext]] option or [[Eden]] attribute setting. | |mp= For security purposes, this command will only run for 1 cycle in multiplayer, unless in-game [[Arma 3: Debug Console|debug console]] is available via [[Description.ext|description.ext]] option or [[:Category:Eden Editor|Eden]] attribute setting. | ||
| |s1= [[diag_codePerformance]] [code, arguments, cycles] | |s1= [[diag_codePerformance]] [code, arguments, cycles] | ||
| Line 21: | Line 21: | ||
| |p3= cycles: [[Number]] - (Optional, default 100000) wanted number of cycles to run the given code. > 1000 is recommended | |p3= cycles: [[Number]] - (Optional, default 100000) wanted number of cycles to run the given code. > 1000 is recommended | ||
| |p4= ignoreTimeLimit: [[Boolean]] - (Optional, default false) - ignore the 1 second timelimit, and always run the provided number of cycles (except in multiplayer) | |||
| |p4since= arma3 2.14 | |||
| |r1= [[Array]] format [duration, cycles], where: | |r1= [[Array]] format [duration, cycles], where: | ||
| Line 26: | Line 29: | ||
| * cycles: [[Number]] - actual number of cycles executed | * cycles: [[Number]] - actual number of cycles executed | ||
| |x1= < | |x1= <sqf>private _result = diag_codePerformance [{ private _a = 123; }, 0, 10000];</sqf> | ||
| |seealso= [[diag_log]] | |seealso= [[diag_log]] [[BIS_fnc_codePerformance]] [[Code Optimisation]] | ||
| }} | }} | ||
Latest revision as of 13:22, 9 July 2023
Description
- Description:
- Attempts to run given code with given arguments given number of cycles in unscheduled environment and returns average time it took to run the code as well as actual number of executions performed. The command will return as soon as possible if the tested code is slow and the duration of the command exceeds 1 second. Engine alternative to BIS_fnc_codePerformance.
- Multiplayer:
- For security purposes, this command will only run for 1 cycle in multiplayer, unless in-game debug console is available via description.ext option or Eden attribute setting.
- Groups:
- DiagnosticPerformance Profiling
Syntax
- Syntax:
- diag_codePerformance [code, arguments, cycles]
- Parameters:
- code: Code - code to compare performance
- arguments: Anything - (Optional, default nil) arguments to pass to the code in _this variable. Default: nil
- cycles: Number - (Optional, default 100000) wanted number of cycles to run the given code. > 1000 is recommended
- since  2.14 2.14
- ignoreTimeLimit: Boolean - (Optional, default false) - ignore the 1 second timelimit, and always run the provided number of cycles (except in multiplayer)
- Return Value:
- Array format [duration, cycles], where:
Examples
- Example 1:
Additional Information
- See also:
- diag_log BIS_fnc_codePerformance Code Optimisation
Notes
- 
Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
 Only post proven facts here! Add Note
 
	