- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我会在 Linux 桌面上测量程序执行时间,比如计算斐波那契数。测量方法可以使用代码中的 time 命令或 clock() 函数,无论如何。我确信在我的电脑上只有这个程序在运行,没有其他重要的程序在运行。我的问题是,如何确保我的测量准确且不受后台程序的影响,例如操作系统中断、调度、桌面渲染等。
我的第一个想法是观察可能干扰测量的每个可疑方面。
如果我担心中断,我应该在我的程序运行期间收集所有中断,并分析它们的开销。
如果我担心调度,我应该分析调度行为,以确保调度程序不会产生额外的开销。
如果我担心桌面渲染,因为我的程序使用 GPU,桌面渲染也使用 GPU,最好禁用此渲染程序。
这有意义吗?或者有什么更好的方法?
相关问题:
How to get an accurate performance measure?
Getting reliable performance measurements for short bits of code
最佳答案
你说得很好,操作系统中断、调度和许多其他事情都会影响程序的性能。但请记住这一点:
当用时间来衡量复杂性之类的东西时,您并不是在寻找具体的衡量标准。假设您有一个在 O(n) 时间内运行的简单 for 循环,您想检查它运行了多长时间。如果您还没有看到时间复杂度,想象一下程序的复杂度与大小成正比,例如 10 个元素应该比 1 个元素“长”10 倍才能完成运行时间。当我说您不是在寻找特定的测量值时,我的意思是您是在寻找计算特定输入尺寸所需的时间与其他输入尺寸相比
所以当你担心操作系统中断之类的事情时,我的建议是做这样的事情:
如果您担心程序的效率,您可以测量它在多次运行过程中所花费的时间,并针对多种输入大小。
例如,计算斐波那契数 100 次(相同的输入),并计算完成每次运行所花费的平均时间。
现在,将输入的大小增加到原始大小的两倍,然后再次进行一系列运行以获得平均运行时间。您会发现,平均而言,更大的输入将花费更长的时间来计算。对所有大小的输入继续这样做,您实际上可以绘制每个输入大小的平均运行时间,这条曲线将粗略地代表您的算法复杂性。它不会是完美的,因为大多数实际函数都不能用 O(n)、O(n^2) 来表示,会有一些系数可能会使曲线看起来很奇怪。
我希望这是有道理的,最后请记住,您应该指定您实际要查找的内容。听起来您正在尝试查找程序的运行时间,但如果您不查看不同的输入大小,那又有什么意义呢?在没有比较的情况下查看特定时间(以实际秒为单位)有什么意义?在没有上下文的情况下显示程序运行了 1 秒是毫无意义的,所以我希望这篇文章能让您更深入地了解如何以更传统的方式显示程序的性能。
关于linux - 如何准确衡量性能,排除后台程序干扰?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40008725/
当然,您可以将剩余文件大小除以当前下载速度,但如果您的下载速度波动(而且它会波动),这不会产生很好的结果。有什么更好的算法可以产生更平滑的倒计时? 最佳答案 安exponential moving a
对于一个业余项目,我正在尝试对齐照片并创建 3D 图片。我基本上在一个钻机上有 2 个相机,我用来拍照。我会自动尝试以您获得 3D SBS 图像的方式对齐图像。 它们是高分辨率图像,这意味着需要处理大
当然,您可以将剩余的文件大小除以当前的下载速度,但如果您的下载速度波动(而且会波动),这不会产生很好的结果。什么是产生更平滑倒计时的更好算法? 最佳答案 安exponential moving ave
我有一个数据集,其中包含患有糖尿病和未患有糖尿病的人。我想使用这些数据训练一个模型来计算糖尿病状况未知的人的风险概率。我知道在培训中没有被诊断出糖尿病的人大多数都没有糖尿病,但很可能其中一些人可能患有
let parent = path[row-1] let child = path[row] let indexOfChild = matrix[parent.obje
我正在编写一些使用 Element.getBoundingClientRect 的代码(gBCR),加上内联样式更新,以执行计算。 这不适用于一般网站,我不关心或不感兴趣是否有“更好的 CSS 方式”
我有一个很大的 csv 文件,其中包含大量脏数据,我想通过消除所有不是绝对必要的值来稍微清理一下它。 Here是我正在谈论的文件。 它有以下组件: 网站,标题,开始日期,开始日期,雇主,地点,纬度,
有谁知道一个库,它为 Java 提供了一个错误不高于 1-2 毫秒的 Thread.sleep()? 我尝试了 sleep 、错误测量和 BusyWait 的混合,但在不同的 Windows 机器上我
UiApp有DateBox和 DateTimeFormat 对于那个类(class)。但是,不存在诸如 TimePicker 或 TimeBox 这样的东西,用户可以通过明确指定的方式(例如通过使用
因此,我使用 sklearn 的 svm.SVC 模块编写了一个程序来学习 mnist 数据集,出于某种原因,每当我计算其准确性为 100% 时。这似乎好得令人难以置信,这是预期的吗? from sk
我当前找到了 gpytorch ( https://github.com/cornellius-gp/gpytorch )。它似乎是将 GPR 集成到 pytorch 中的一个很棒的包。第一次测试也呈
我正在使用 QT Creator 5.9 创建一个简单的 Web 浏览器模型,我的 EditLine/Text Box 有问题: 1.如何在转到不同的网站/页面后自动更新显示的 URL 字符串。 2。
我在 Linux 上尝试 time -p 命令,我写了一些代码来浪费 CPU 周期: #include using namespace std; int main() { long int c;
亲爱的程序员/脚本编写者/工程师/其他人, 问题:我目前正在为 Android 3.2 平板电脑开发增强现实应用程序,但在获取准确的罗盘读数方面遇到一些问题。我需要确切地知道平板电脑所面向的 (z)
我最近一直在尝试了解 Apache Spark 作为 Scikit Learn 的替代品,但在我看来,即使在简单的情况下,Scikit 收敛到准确模型的速度也远远快于 Spark。例如,我使用以下脚本
如果不是,它的准确性如何? 我想在下载之前知道图片的大小。 最佳答案 HTTP Content-length header 是否格式错误?是的。 您是否应该相信它能公平地表示消息正文的大小?是的。 关
这是一个关于 ngram 线性回归的问题,使用 Tf-IDF(术语频率 - 逆文档频率)。为此,我使用 numpy 稀疏矩阵和 sklearn 进行线性回归。 使用一元语法时,我有 53 个案例和 6
对于某些给定的固定宽度,如何计算特定标签 (NSTextField) 中字符串的高度? 我用谷歌搜索了各种方法并尝试了 this method from Apple .它的工作原理,除了高度变成一行对
我是一名优秀的程序员,十分优秀!