Static performance analysis service

US11269604B1 · US · B1

Patent metadata
FieldValue
Publication numberUS-11269604-B1
Application numberUS-202117349038-A
CountryUS
Kind codeB1
Filing dateJun 16, 2021
Priority dateJun 16, 2021
Publication dateMar 8, 2022
Grant dateMar 8, 2022

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A system and method for analyzing a performance of computer code. A method includes scanning a graph to identify a plurality of calls to executable code, individual nodes of the graph representing different calls to be taken by the executable code; determining a score for individual nodes of the graph based on resources required to perform the call represented by that node, the call being one that consumes substantial resources of a computing system to accomplish an operation; adjusting the score of individual nodes that are associated with repetitive action nodes in the graph; and generating recommendations to improve performance of the computer code based on scores indicative of substantial resource consumption.

First claim

Opening claim text (preview).

What is claimed is: 1. A system, comprising: a memory; and a processor coupled to the memory and configured to provide a performance analysis of computer code, including: scanning a graph to identify a plurality of calls to executable code, individual nodes of the graph representing different calls to be taken by the executable code; determining a score for individual nodes of the graph based on resources required to perform the call represented by that node, the call being one that consumes substantial resources of a computing system to accomplish an operation; adjusting the score of individual nodes that are associated with repetitive action nodes in the graph; and generating recommendations to improve performance of the computer code based on scores indicative of substantial resource consumption. 2. The system of claim 1 , wherein calls that consume substantial resources include database calls, disk input/output (IO) calls, memory allocations and network IO calls. 3. The system of claim 1 , wherein the graph includes a call graph and calls that consume substantial resources are identified by evaluating call names. 4. The system of claim 1 , wherein repetitive action nodes include loop nodes, and the score for a given node associated with at least one loop node is adjusted by multiplying the score with a multiplier value for each loop within which the given node resides. 5. The system of claim 4 , wherein a graph score is a sum of all of the scores in the graph. 6. The system of claim 1 , wherein the analysis further includes generating at least one graph from the computer code. 7. The system of claim 1 , wherein the analysis further includes receiving as input a specified portion of the computer code to be analyzed, wherein the specified portion includes one of a method, a class or a branch. 8. The system of claim 1 , wherein the computer code includes source code stored in a code repository. 9. The system of claim 1 , wherein the score for each node is commensurate with a cost to execute each associated call during runtime. 10. The system of claim 1 , wherein generating recommendations includes outputting proposed modifications to the computer code. 11. A computerized method to provide a performance analysis of computer code, the method comprising: scanning a graph to identify a plurality of calls to executable code, individual nodes of the graph representing different calls to be taken by the executable code; determining a score for individual nodes of the graph based on resources required to perform the call represented by that node, the call being one that consumes substantial resources of a computing system to accomplish an operation; adjusting the score of individual nodes that are associated with repetitive action nodes in the graph; and generating recommendations to improve performance of the computer code based on scores indicative of substantial resource consumption. 12. The method of claim 11 , wherein calls that consume substantial resources include database calls, disk input/output (IO) calls, memory allocations and network IO calls. 13. The method of claim 11 , wherein the graph includes a call graph and calls that consume substantial resources are identified by evaluating call names. 14. The method of claim 11 , wherein repetitive action nodes include loop nodes, and the score for a given node associated with at least one loop node is adjusted by multiplying the score with a multiplier value for each loop within which the given node resides. 15. The method of claim 14 , wherein a graph score is a sum of all of the scores in the graph. 16. The method of claim 11 , further comprising generating at least one graph from the computer code. 17. The method of claim 11 , further including receiving as input a specified portion of the computer code to be analyzed, wherein the specified portion includes one of a method, a class or a branch. 18. The method of claim 11 , wherein the computer code includes source code stored in a code repository. 19. The method of claim 11 , wherein the score for each node is commensurate with a cost to execute each associated call during runtime. 20. The method of claim 11 , wherein generating recommendations includes outputting proposed modifications to the computer code.

Assignees

Inventors

Classifications

  • Analysis of software for verifying properties of programs (testing of software G06F11/3668) · CPC title

  • Performance evaluation by tracing or monitoring · CPC title

  • Monitoring of software · CPC title

  • by runtime analysis (performance monitoring G06F11/3466) · CPC title

  • Software metrics · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US11269604B1 cover?
A system and method for analyzing a performance of computer code. A method includes scanning a graph to identify a plurality of calls to executable code, individual nodes of the graph representing different calls to be taken by the executable code; determining a score for individual nodes of the graph based on resources required to perform the call represented by that node, the call being one t…
Who is the assignee on this patent?
Citrix Systems Inc
What technology area does this patent fall under?
Primary CPC classification G06F11/3466. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Mar 08 2022 00:00:00 GMT+0000 (Coordinated Universal Time) (B1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 3 related publications on this page (citations in our corpus or others sharing the same primary CPC).