1
0
mirror of https://github.com/kalmarek/Groups.jl.git synced 2025-01-12 06:12:33 +01:00

fix the replace! function in case length(toreplace)= 1

This commit is contained in:
kalmar 2017-07-05 16:18:04 +02:00
parent 5a9d4b4bb6
commit 6c8591b1d4

View File

@ -309,22 +309,35 @@ function findnext(W::GWord, Z::GWord, i::Integer)
end end
function replace!(W::GWord, index, toreplace::GWord, replacement::GWord; check=true) function replace!(W::GWord, index, toreplace::GWord, replacement::GWord; check=true)
n = length(toreplace.symbols) n = length(toreplace.symbols)
if check if n == 0
@assert is_subsymbol(toreplace.symbols[1], W.symbols[index]) return reduce!(W)
@assert W.symbols[index+1:index+n-2] == toreplace.symbols[2:end-1]
@assert is_subsymbol(toreplace.symbols[end], W.symbols[index+n-1])
end
first = change_pow(W.symbols[index], elseif n == 1
if check
@assert is_subsymbol(toreplace.symbols[1], W.symbols[index])
end
first = change_pow(W.symbols[index],
W.symbols[index].pow - toreplace.symbols[1].pow)
last = change_pow(W.symbols[index], 0)
else
if check
@assert is_subsymbol(toreplace.symbols[1], W.symbols[index])
@assert W.symbols[index+1:index+n-2] == toreplace.symbols[2:end-1]
@assert is_subsymbol(toreplace.symbols[end], W.symbols[index+n-1])
end
first = change_pow(W.symbols[index],
W.symbols[index].pow - toreplace.symbols[1].pow) W.symbols[index].pow - toreplace.symbols[1].pow)
last = change_pow(W.symbols[index+n-1],
last = change_pow(W.symbols[index+n-1],
W.symbols[index+n-1].pow - toreplace.symbols[end].pow) W.symbols[index+n-1].pow - toreplace.symbols[end].pow)
end
replacement = first * replacement * last replacement = first * replacement * last
splice!(W.symbols, index:index+n-1, replacement.symbols) splice!(W.symbols, index:index+n-1, replacement.symbols)
return reduce!(W) return reduce!(W)
end end
function replace(W::GWord, index, toreplace::GWord, replacement::GWord) function replace(W::GWord, index, toreplace::GWord, replacement::GWord)