AUTH's THMMY "Parallel and distributed systems" course assignments.
25개 이상의 토픽을 선택하실 수 없습니다.
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
- # distributed bitonic sort using elbow merge locally except for the first step
- function distbitonic!(p)
-
- q = Int(log2(p))
-
- pid = 0:p-1
- ascending = mod.(pid,2) .== 0
- println("ascending: $ascending")
- # local full sort here
- for k = 1:q
- kk = 1 << k
- for j = k-1:-1:0
- jj = 1 << j
- partnerid = pid .⊻ jj
- direction = (pid .& kk) .== 0 .& (pid .< partnerid)
- keepsmall = ((pid .< partnerid) .& direction) .| ((pid .> partnerid) .& .!direction)
- println("k: $k | j: $j | partner: $partnerid | keepsmall: $keepsmall")
- # exchange with partner and keep small or large
- end
- ascending = (pid .& kk) .== 0
- println("ascending: $ascending")
- # local elbowmerge here
- end
-
- nothing
- end
-
|