- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为一些函数添加类型,即速度和清晰度。我对此有几个问题。我在这里问他们所有人,因为我看到其他帖子这样做了。问题以粗体显示,以便于识别。
有一个函数我想添加类型来计算向量中负值的数量。我想让它与 Int 和 Float 兼容,就像无类型函数一样。虽然方便,但 Chris Rackauckas 建议不要这样做,请参阅 How to declare array type that can have int and floats 的第一条评论,
Do you want Ints and Floats at the same time? That's not advised due to performance reasons. But if you want to, you can use Union{Int64,Float64} as the type.
Union
向参数添加类型。 .但是,对于这种特殊情况,使用
Number
和
Real
是
Int64
的父类(super class)型和
Float64
,我认为这些会比无类型版本稍快。
Any
, 和两个类型
Number
和
Real
,
Float64
的两个父类(super class)型和
Int64
.
notypes
median time: 1.006 ms (0.00% GC)
mean time: 1.152 ms (12.60% GC)
any
median time: 1.054 ms (0.00% GC)
mean time: 1.197 ms (12.05% GC)
union
median time: 1.062 ms (0.00% GC)
mean time: 1.210 ms (12.09% GC)
number
median time: 1.110 ms (0.00% GC)
mean time: 1.315 ms (14.18% GC)
real
median time: 1.015 ms (0.00% GC)
mean time: 1.168 ms (12.70% GC)
float
median time: 728.131 μs (0.00% GC)
mean time: 829.031 μs (11.53% GC)
显然,无类型函数与类型为
Any
的函数之间没有显着改进。和
Number
.
Real
功能似乎有非常细微的改进,而
Float64
功能是唯一有明显改进的。
Int
键入的函数和 Float
通常比没有类型的更快?
Union{Int64,Float64}
是只有两种类型的父类(super class)型,不像
Number
和
Real
跨越更多。这就是为什么我认为
Union
函数会比其他函数更快(除了
Float
版本)。
是 Union
s 和无类型一样慢?
Number
)的函数是否有任何性能改进和 Float
, 与让它们保持无类型相比?
Int64
和
Float64
.
abstract type IF64 <: Union{Int64,Float64} end
但出现错误
invalid subtyping in definition of IF64
另外,
N
是什么?在函数的定义中是什么意思? (例如
where {T<:Union{Int64,Float64},N}
中的
countMPvec_arrUnion
定义如下)。
Float
函数比其他函数占用更少的内存? (
609.06 KiB
v.
921.56 KiB
)(这是基准测试的输出;代码如下)
all other functions
memory estimate: 921.56 KiB
allocs estimate: 38979
float
memory estimate: 609.06 KiB
allocs estimate: 28979
测试的完整代码:
#= -------------------
The different versions of the function
-------------------
=#
function countMPvec_notypes(vec)
nneg = 0
lvec = length(vec)
for i in 1:lvec
if (vec[i] < 0)
nneg += 1
end
end
npos = lvec - nneg
return (nneg,npos)
end
function countMPvec_any(vec :: Any)
nneg = 0
lvec = length(vec)
for i in 1:lvec
if (vec[i] < 0)
nneg += 1
end
end
npos = lvec - nneg
return (nneg,npos)
end
# Works with Int and Float !!!
function countMPvec_arrUnion(vec :: Array{T,1}) where {T<:Union{Int64,Float64},N}
nneg = 0
lvec = length(vec)
for i in 1:lvec
if (vec[i] < 0)
nneg += 1
end
end
npos = lvec - nneg
return (nneg,npos)
end
# Works with Int and Float !!!
function countMPvec_arrNumber(vec :: Array{T,1}) where {T<:Number,N}
nneg = 0
lvec = length(vec)
for i in 1:lvec
if (vec[i] < 0)
nneg += 1
end
end
npos = lvec - nneg
return (nneg,npos)
end
# Works with Int and Float !!!
function countMPvec_arrReal(vec :: Array{T,1}) where {T<:Real,N}
nneg = 0
lvec = length(vec)
for i in 1:lvec
if (vec[i] < 0)
nneg += 1
end
end
npos = lvec - nneg
return (nneg,npos)
end
function countMPvec_arrFloat(vec :: Array{Float64,1})
nneg = 0
lvec = length(vec)
for i in 1:lvec
if (vec[i] < 0)
nneg += 1
end
end
npos = lvec - nneg
return (nneg,npos)
end
#= -------------------
Functions for benchmark
-------------------
=#
nums = [1.3; -2; 5]
nitertest = 10000
function test_notypes()
for i in 1:nitertest
countMPvec_notypes(nums)
end
end
function test_any()
for i in 1:nitertest
countMPvec_any(nums)
end
end
function test_arrUnion()
for i in 1:nitertest
countMPvec_arrUnion(nums)
end
end
function test_arrNumber()
for i in 1:nitertest
countMPvec_arrNumber(nums)
end
end
function test_arrReal()
for i in 1:nitertest
countMPvec_arrReal(nums)
end
end
function test_arrFloat()
for i in 1:nitertest
countMPvec_arrFloat(nums)
end
end
然后是基准单元。每一个都应该单独运行。此外,最后给出了每个单元格的完整输出:
import BenchmarkTools
println("notypes")
@BenchmarkTools.benchmark test_notypes()
println("any")
@BenchmarkTools.benchmark test_any()
println("union")
@BenchmarkTools.benchmark test_arrUnion()
println("number")
@BenchmarkTools.benchmark test_arrNumber()
println("real")
@BenchmarkTools.benchmark test_arrReal()
println("float")
@BenchmarkTools.benchmark test_arrFloat()
#= -------------------
Output of the benchmarks
-------------------
=#
notypes
BenchmarkTools.Trial:
memory estimate: 921.56 KiB
allocs estimate: 38979
--------------
minimum time: 855.070 μs (0.00% GC)
median time: 1.006 ms (0.00% GC)
mean time: 1.152 ms (12.60% GC)
maximum time: 31.515 ms (91.59% GC)
--------------
samples: 4314
evals/sample: 1
any
BenchmarkTools.Trial:
memory estimate: 921.56 KiB
allocs estimate: 38979
--------------
minimum time: 905.317 μs (0.00% GC)
median time: 1.054 ms (0.00% GC)
mean time: 1.197 ms (12.05% GC)
maximum time: 30.355 ms (96.33% GC)
--------------
samples: 4152
evals/sample: 1
union
BenchmarkTools.Trial:
memory estimate: 921.56 KiB
allocs estimate: 38979
--------------
minimum time: 914.563 μs (0.00% GC)
median time: 1.062 ms (0.00% GC)
mean time: 1.210 ms (12.09% GC)
maximum time: 32.472 ms (90.09% GC)
--------------
samples: 4111
evals/sample: 1
number
BenchmarkTools.Trial:
memory estimate: 921.56 KiB
allocs estimate: 38979
--------------
minimum time: 926.189 μs (0.00% GC)
median time: 1.110 ms (0.00% GC)
mean time: 1.315 ms (14.18% GC)
maximum time: 42.545 ms (97.21% GC)
--------------
samples: 3788
evals/sample: 1
real
BenchmarkTools.Trial:
memory estimate: 921.56 KiB
allocs estimate: 38979
--------------
minimum time: 863.699 μs (0.00% GC)
median time: 1.015 ms (0.00% GC)
mean time: 1.168 ms (12.70% GC)
maximum time: 31.847 ms (96.50% GC)
--------------
samples: 4257
evals/sample: 1
float
BenchmarkTools.Trial:
memory estimate: 609.06 KiB
allocs estimate: 28979
--------------
minimum time: 625.845 μs (0.00% GC)
median time: 728.131 μs (0.00% GC)
mean time: 829.031 μs (11.53% GC)
maximum time: 30.811 ms (97.38% GC)
--------------
samples: 5989
evals/sample: 1
最佳答案
所有与性能相关的问题都有一个答案:类型注释提高了结构的性能,但通常不会提高函数的性能。您从 Chris 那里读到的帖子涉及数组(结构)的元素类型,即使它出现在函数可接受的类型方面。你应该在那个上下文中解释它。
在 Julia 中,您应该对函数参数进行类型注释以控制调度,而不是为了性能。为什么?因为编译器将为您传递给它的每个具体类型专门化每个函数,从某种意义上说,会自动生成您正在考虑手动编写的所有那些专门化。所以添加类型注解的唯一原因是控制调用哪个方法:
is_this_a_number(x::Number) = true
is_this_a_number(x) = false
结构是另一回事。您可以在
Performance tips 中阅读有关结构中类型注释的更多信息。手册的部分。
Union
s 的具体类型(如果不确定,请使用
isconcretetype
检查每个)。
what does the N mean in the function's definition
关于performance - julia:关于函数中泛型类型的几个问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69322423/
使用 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
我是一名优秀的程序员,十分优秀!