mirror of
https://github.com/MillironX/SequenceVariation.jl.git
synced 2024-11-22 13:29:56 +00:00
Add translate function for Haplotypes
This commit is contained in:
parent
e251b292a7
commit
a61a80d586
1 changed files with 20 additions and 0 deletions
|
@ -198,3 +198,23 @@ function reconstruct(h::Haplotype)
|
||||||
end
|
end
|
||||||
return seq
|
return seq
|
||||||
end
|
end
|
||||||
|
|
||||||
|
"""
|
||||||
|
translate(hap::Haplotype{S,T}, aln::PairwiseAlignment{S,S}) where {S,T}
|
||||||
|
|
||||||
|
Convert the variations in `hap` to a new reference sequence based upon `aln`. The alignment
|
||||||
|
rules follow the conventions of
|
||||||
|
[`translate(::Variation, PairwiseAlignment)`](@ref translate(::Variation{S,T}, ::PairwiseAlignment{S,S}) where {S,T}).
|
||||||
|
Indels at the beginning or end may not be preserved. Returns a new
|
||||||
|
[`Haplotype`](@ref)
|
||||||
|
"""
|
||||||
|
function translate(hap::Haplotype{S,T}, aln::PairwiseAlignment{S,S}) where {S,T}
|
||||||
|
vars = variations(hap)
|
||||||
|
new_ref = BA.sequence(aln)
|
||||||
|
translated_vars = Variation{S,T}[]
|
||||||
|
for v in vars
|
||||||
|
new_v = translate(v, aln)
|
||||||
|
isnothing(new_v) || push!(translated_vars, new_v)
|
||||||
|
end
|
||||||
|
return Haplotype(new_ref, translated_vars)
|
||||||
|
end
|
||||||
|
|
Loading…
Reference in a new issue