gDEBugger 一个不错的openg调试工具

gDEBugger usage tips

https://web.archive.org/web/20160814150017/http://www.gremedy.com/download.php

https://github.com/derekhe/blog/blob/master/source/_posts/2010-04-01-gdebugger-5-x-crack-patch.markdown

http://swiborg.com/download/software/gDEBugger-5_8_1.msi

免费Free gDEBugger license file

http://www.klayge.org/2010/12/08/gdebugger%E7%BB%88%E4%BA%8E%E5%85%8D%E8%B4%B9%E4%BA%86/

How do I clean up my OpenGL usage? First, it is best to find and remove all OpenGL errors your application generates. OpenGL error-causing commands are usually not executed and slow down the render performance. This process is explained in this guide's Debug Mode section. After removing those, you might also want to remove detected errors. The Debug Mode section also explains how to locate detected errors. Next, you should find any unrecommended OpenGL functions, and follow the instruction gDEBugger supplies for each one. You can find an explanation on finding these functions and getting alternatives for them under the Debug Mode section. You might also want to remove any software fallbacks from your application. If you are using NVIDIA hardware with GLExpert support, you can follow the instructions presented in the Debug Mode section to locate them. When your application is clean of all problematic function calls, you should try to see if your application has any graphic memory leaks. Follow the instructions in the Debug Mode section to locate any leaking objects in your application. Drawing with small vertex batches uses up many API calls for a small visual effect, so it is a good idea to view vertex batch information as described in the Debug Mode section. If you wish your application to be compatible with future OpenGL versions, you might want to check if your application is using any deprecated functions or features. It is best to look for these deprecations in Analyze Mode, as described in this guide's Analyze Mode section.

How do I find unneeded OpenGL function calls in my code? First, you should see if your code contains any unrecommended OpenGL function calls, and follow the instructions given for each of them. This is explained in this guide's Debug Mode section. While looking at gDEBugger's OpenGL Calls Statistics View (in the Statistics viewer), you might also notice functions which are called an exceptionally high number of times. While this could be normal for draw functions, if these are state change functions, there is a good chance there are redundant calls among them. You should try to have fewer calls in either case. gDEBugger has a mechanism which makes finding redundant state changes much simpler. An explanation of how to do it is found in the Analyze Mode section. For draw functions, you might want to have a look to see how they affect the draw buffers and try to remove calls that have no effect. The Debug Mode section is an explanation on how to view each function's effect on the buffers.

How do I measure my application's performance? The best way to measure your application's performance is to use gDEBugger's performance counters. The Profile Mode Section contains an explanation on how to work with them. For the closest measurements as possible to the real results which will be obtained by your application, it is recommended to use an optimized ("release") build of your application together with gDEBugger's Profile Mode Profile Mode. By saving the performance counters' data you can compare the change in various performance metrics to perform regression test (between different versions of your application) or to test your application on different graphics hardware and driver configurations.

How do I optimize my OpenGL application performance? There are two steps to optimizing your OpenGL performance: The first is to locate OpenGL pipeline bottlenecks. The Profile Mode section explains how to do this. Since the OpenGL pipeline always runs as fast as its slowest stage, the second step is to lower the workload on the current bottleneck. Now repeat these steps until you are either satisfied with your current results or until you can not improve the performance any more.

How do I peer inside OpenGL? The OpenGL API is designed to maximize graphic performance and not to make debugging easy. When developers work with OpenGL, they see the graphic system as a "black box": the program issues thousands of API calls into it and "magically" an image comes out of the system. There are many ways gDEBugger can help you transform the debugging task into a "white box" model: gDEBugger can help you view and understand the impact of each draw function on the draw buffers. This is explained under the Debug Mode section. You can use gDEBugger to view OpenGL state variables and changes made to them. The Debug Mode section explains how. If your program uses textures or buffer objects, you can view the detailed information gDEBugger collects about them as also explained in the Debug Mode section. If your application uses shaders and shading programs, their information and source code can be viewed and changed as explained in the Debug Mode section. To get a broader view of your OpenGL usage, you might prefer to view statistical information about it, as the Debug Mode section describes. To view the details of your application's graphic memory consumption, as well as view the calls stack for the creation of any graphic memory allocated objects, follow the explanations in the Debug Mode section. Using all these features together can help you understand better how OpenGL works to create an image from the commands you give it and eliminate the "mystery" behind the works.

How do I know which execution mode to use? For most of the tasks that can be performed using gDEBugger, Debug ModeDebug Mode is the best choice of execution mode. Nearly all of gDEBugger's features are enabled in this mode, and while it slightly lowers performance, in most cases it is suitable for debugging the application. Use Profile ModeProfile Mode when you need the closest estimation of actual performance possible. While this mode disables many of gDEBugger's debugging features, the debugged application's performance will usually be better than in Debug Mode. Thus, Profile Mode is best suited for performance measurements and for profiling. Analyze Mode causes significant slowdown on most OpenGL applications, making it unsuitable for most tasks. Use Analyze ModeAnalyze Mode only for its unique features - getting information about OpenGL State change functions usage, detection of redundant state changes and getting in-depth information about deprecated function usage. Because of its "heaviness", Analyze Mode is better used on a per-frame basis, using Frame Step Frame Step (Ctrl+F11) rather than Run Go (F5).
To find out if a certain feature is available in one of the execution modes, look at the execution modes comparison table. If you are still unsure of which of the modes suits your needs, try looking at the sections in this guide dedicated to each execution mode, to see if the task you wish to perform is found under one of them.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值