- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经阅读了很多文档和问题,但我仍然对此感到困惑。
在 Profiling文档的部分建议首先在 REPL 中运行目标函数一次,以便它在被分析之前已经编译。但是,如果脚本相当复杂并且打算在命令行中运行并接受参数怎么办?当julia
进程完成,我第二次运行脚本,是否再次执行编译?像 https://stackoverflow.com/a/42040763/1460448 这样的帖子, Julia compiles the script every time?给出相互矛盾的答案。当 Julia 不断发展时,它们似乎也很老了。
在我看来,根据我的经验,第二次运行所花费的时间与第一次运行的时间完全相同。启动时间相当长。我应该如何优化这样的程序?添加 __precompile__()
似乎根本没有改变执行时间。
另外,当我想分析这样的程序时应该怎么做?所有关于分析的资源都在 REPL 中讨论了这样做。
最佳答案
如果我错了,请纠正我,但听起来你写了一些很长的脚本,比如说,myfile.jl
,然后从您的操作系统命令行调用 julia myfile.jl args...
.它是否正确?此外,它听起来像 myfile.jl
在函数的方式上没有定义太多,而只是一个命令序列。它是否正确?如果是这样,那么正如对该问题的评论中所建议的那样,这不是 Julia 的典型工作流程,原因有两个:
1) 从命令行调用julia,即julia myfile.jl args...
相当于打开一个 REPL,运行 include
命令 myfile.jl
,然后关闭 REPL。首次调用 include
将编译 myfile.jl
中的操作所需的任何方法,这需要时间。但是由于您是从命令行运行的,一旦 include
完成后,REPL 自动关闭,所有编译后的代码都被丢弃。这就是 DNF 的意思,他说推荐的工作流程是在单个 REPL session 中工作,并且在您完成一天之前不要关闭它,或者除非您有意重新编译您正在使用的所有方法。
2) 即使您在单个 REPL session 中工作,将您所做的几乎所有事情都包装在函数中也非常重要(这与 Matlab 等语言的工作流程非常不同)。如果您这样做,Julia 将为每个函数编译专门针对您正在使用的输入参数类型的方法。这基本上就是 Julia 速度快的原因。一旦一个方法被编译一次,它在整个 REPL session 中仍然可用,但在你关闭 REPL 时被释放。至关重要的是,如果您不将操作包装在函数中,则不会发生这种专门的编译,因此您可能会遇到非常慢的代码。在 Julia 中,我们称之为“在全局范围内工作”。请注意,Julia 的这一特性鼓励一种编码风格,即把你的任务分解成许多小的专用函数,而不是一个由 1000 行代码组成的庞然大物。这是一个好主意,原因有很多。 (在我自己的代码库中,很多函数都是单行的,大多数是 5 行或更少)
如果您在 Julia 中工作,以上两点对于理解这一点绝对至关重要。但是,一旦您对它们感到满意,我建议您实际上将所有功能放入 modules ,然后在需要时从事件的 REPL session 中调用您的模块。这有一个额外的好处,你可以添加一个 __precompile__()
声明在您的模块顶部,然后 julia 将预编译该模块中的一些(但不一定是全部)代码。完成此操作后,关闭 REPL 时模块中的预编译代码不会消失,因为它以 .ji 文件的形式存储在硬盘驱动器上。所以你可以开始一个新的 REPL session ,输入 using MyModule
,并且您的预编译代码立即可用。如果你改变了模块的内容,它只需要重新编译(这一切都是自动发生的)。
关于compilation - 如果从命令行运行 Julia 脚本,是否每次都需要重新编译?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50608970/
使用 julia 控制台时,您输入如下内容: [10,20]*[1:100,1:100]' 你会得到这样的输出: 2x200 Array{Int64,2}: 10 20 30 40 50
Julia Computing 提供的 Julia 和 Julia Pro 有什么区别? Julia Pro 是否有任何在 Julia 中不可用的企业库? 最佳答案 正如您在 project desc
我最近将我的一个模拟移植到 Julia 中,我仅在运行时发现了几个类型错误。我希望静态分析我的 Julia 代码。 MATLAB 也有类似的问题,只在运行时发现很多错误。 我发现的唯一工具 ( Typ
是否有一种简单的方法来监控 julia 和所有 julia 包的提交和开发?我知道 https://github.com/JuliaLang/julia/commits/master 最佳答案 如果您
我正在从 R 迁移,我使用 head() function很多。我在 Julia 中找不到类似的方法,所以我为 Julia Arrays 写了一个。我还将其他几个 R 函数移植到 Julia。 我需要
在某些语言(如 Python)中,有函数装饰器,它们看起来像宏,位于函数定义之上。装饰器为函数本身提供了一些额外的功能。 Julia 是否以任何方式支持函数装饰器的想法?是否可以使用宏来实现相同的目标
我用Julia中的pmap()函数写了一段并行代码。 然后我在集群上保护了四个核心并运行了一个脚本: julia -p 12 my_parallel_program.jl 我现在应该取消我的工作吗?现
谁能帮我理解接下来的事情: 1)为什么我们需要在制作链表的同时制作一个 future 结构的新抽象类? 2) 为什么有参数 T? 3)这个操作符是干什么的 struct BrokenList
我在 Julia 中有一个数组 Z,它表示二维高斯函数的图像。 IE。 Z[i,j] 是像素 i,j 处的高斯高度。我想确定高斯的参数(均值和协方差),大概是通过某种曲线拟合。 我研究了各种拟合 Z
假设,我们有如下数据结构 struct MyStruct{T} t :: Union{Nothing, T} end 并且我们希望允许用户在不添加任何数据的情况下初始化结构,例如 MyStru
我有一个包含相同类型字段的结构,我无法在创建时分配该字段。 Julia 似乎不喜欢以下内容。 (它吐出一个循环引用投诉。)我打算将问题归结为它的本质 mutable struct Test t
我正在尝试使用最大似然估计 Julia 中的正态线性模型。根据 Optim 文档中关于不更改的值,我使用以下代码通过拦截和匿名函数来模拟该过程: using Optim nobs = 500 nvar
有没有办法从命令行更新 Julia?我浏览了 documentation ,但我找不到任何东西。 最佳答案 我建议尝试 asdf如果您使用的是 MacOS、Linux 或 Linux 的 Window
我想对维度为 n 乘以 n 的矩阵 A 中的所有元素求和。该矩阵是对称的并且对角线上有 0。我发现最快的方法就是求和(A)。然而,这似乎很浪费,因为它没有使用我只需要计算矩阵的下三角这一事实。但是,s
假设你有一个向量元组 $a$,我想在 julia 中定义一个函数 p(x)=x^a。 例如,如果 a=(1,2,3),则结果函数将为 x^1 *y^2 * z^3。 我想为任何元组提供一个通用方法,但
例如,我希望能够按照以下方式做一些事情: abstract Tree abstract SupervisedModel type DecisionTree <: Tree, SupervisedMod
在 Julia 中构建复杂表达式时,是否可以使用列表推导式之类的东西? 例如,假设我有一些符号和类型,并想从它们构建一个类型。现在,我必须做类似的事情。 syms = [:a, :b, :c] typ
在 MATLAB 中,[N,edges,bin] = histcounts (___) 可以获得相应元素的 bin 索引。 Julia 有什么等价的功能吗?谢谢! 我已经尝试过 StatsBase.j
我有一个 Julia 脚本,它反复调用 C++ 程序来执行优化。 C++ 程序写入一个文本文件,然后我让 Julia 读取结果并决定下一步做什么。问题是偶尔(可能是 1000 多次)C++ 程序卡住(
我使用了一些需要特定版本的 Julia 包(即 ≥ v0.3 和 0.4 ≤)。我找不到编译 Julia 的方法来自特定版本的源代码(我正在使用 Linux )。有没有办法做到这一点,我不知道? Gi
我是一名优秀的程序员,十分优秀!