/*
* Copyright 2015 MiLaboratory.com
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.milaboratory.core.alignment.kaligner2;
import com.milaboratory.core.alignment.batch.AlignmentResult;
import com.milaboratory.core.alignment.kaligner1.KMappingResult;
import com.milaboratory.core.sequence.NucleotideSequence;
import java.util.List;
/**
* Created by dbolotin on 26/10/15.
*/
public final class KAlignmentResult2<P> implements AlignmentResult<KAlignmentHit2<P>> {
/**
* Link to according {@link KMappingResult}
*/
final KMappingResult2 mappingResult;
/**
* List of hits
*/
final List<KAlignmentHit2<P>> hits;
/**
* Target sequence to be aligned
*/
final NucleotideSequence target;
/**
* Range of target sequence to be aligned
*/
final int targetFrom, targetTo;
public KAlignmentResult2(KMappingResult2 mappingResult, List<KAlignmentHit2<P>> hits,
NucleotideSequence target, int targetFrom, int targetTo) {
this.mappingResult = mappingResult;
this.hits = hits;
this.target = target;
this.targetFrom = targetFrom;
this.targetTo = targetTo;
}
@Override
public List<KAlignmentHit2<P>> getHits() {
return hits;
}
@Override
public final KAlignmentHit2<P> getBestHit() {
return hits.isEmpty() ? null : hits.get(0);
}
@Override
public boolean hasHits() {
return !hits.isEmpty();
}
}