Profiling/fr: Difference between revisions

From FreeCAD Documentation
(Created page with "Pour profiler le code Python, utilisez le module standard {{incode|cProfile}} pour définir les points de début et de fin du profil dans le code.")
(Created page with "Ensuite, installez et utilisez {{incode|pyprof2calltree}} pour convertir la sortie du profil en entrée cachegrind.")
Line 19: Line 19:
}}
}}


Then install and use {{incode|pyprof2calltree}} to convert the profile output into cachegrind input.
Ensuite, installez et utilisez {{incode|pyprof2calltree}} pour convertir la sortie du profil en entrée cachegrind.
{{Code|code=
{{Code|code=
pyprof2calltree -i /tmp/profile.cprof -o /tmp/callgrind.out
pyprof2calltree -i /tmp/profile.cprof -o /tmp/callgrind.out

Revision as of 20:19, 12 August 2020

Other languages:

Description

Le profilage du code de FreeCAD permet de trouver des goulots d'étranglement dans les algorithmes utilisés pour créer ou manipuler des objets.

Pour profiler le code Python, utilisez le module standard cProfile pour définir les points de début et de fin du profil dans le code.

import cProfile
pr = cProfile.Profile()
pr.enable()

# --------------------------------------
# Lines of code that you want to profile
# --------------------------------------

pr.disable()
pr.dump_stats("/tmp/profile.cprof")

Ensuite, installez et utilisez pyprof2calltree pour convertir la sortie du profil en entrée cachegrind.

pyprof2calltree -i /tmp/profile.cprof -o /tmp/callgrind.out

Then visualize this information with kcachegrind for Linux or qcachegrind for Windows.

kcachegrind /tmp/callgrind.out

Resources