/*******************************************************************************
* Copyright 2014 University of Southern California
*
* 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.
*
* This code was developed by the Information Integration Group as part
* of the Karma project at the Information Sciences Institute of the
* University of Southern California. For more information, publications,
* and related projects, please see: http://www.isi.edu/integration
******************************************************************************/
package edu.isi.karma.kr2rml.planning;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import edu.isi.karma.controller.command.selection.SuperSelection;
import edu.isi.karma.kr2rml.PredicateObjectMap;
import edu.isi.karma.kr2rml.URIFormatter;
import edu.isi.karma.kr2rml.exception.HNodeNotFoundKarmaException;
import edu.isi.karma.kr2rml.mapping.KR2RMLMapping;
import edu.isi.karma.kr2rml.mapping.KR2RMLMappingColumnNameHNodeTranslator;
import edu.isi.karma.kr2rml.template.ColumnTemplateTerm;
import edu.isi.karma.kr2rml.template.DoublyAnchoredTemplateTermSetPopulator;
import edu.isi.karma.kr2rml.template.PartiallyPopulatedTermSet;
import edu.isi.karma.kr2rml.template.PopulatedTemplateTermSet;
import edu.isi.karma.kr2rml.template.SinglyAnchoredTemplateTermSetPopulatorPlan;
import edu.isi.karma.kr2rml.template.TemplateTermSet;
import edu.isi.karma.kr2rml.template.TemplateTermSetPopulator;
import edu.isi.karma.kr2rml.writer.KR2RMLRDFWriter;
import edu.isi.karma.rep.HNodePath;
import edu.isi.karma.rep.RepFactory;
import edu.isi.karma.rep.Row;
public abstract class PredicateObjectMappingPlan extends MapPlan {
public PredicateObjectMappingPlan(KR2RMLMapping kr2rmlMapping,
URIFormatter uriFormatter, RepFactory factory,
KR2RMLMappingColumnNameHNodeTranslator translator,
SuperSelection sel) {
super(kr2rmlMapping, uriFormatter, factory, translator, sel);
}
protected SinglyAnchoredTemplateTermSetPopulatorPlan complicatedPlan;
protected DoublyAnchoredTemplateTermSetPopulator predicatePlan;
protected Map<ColumnTemplateTerm, HNodePath> combinedSubjectObjectTermsToPaths ;
protected TemplateTermSetPopulator objectTemplateTermSetPopulator;
protected TemplateTermSetPopulator predicateTemplateTermSetPopulator;
protected boolean isFlipped = false;
protected boolean isLiteral;
protected String literalTemplateValue;
protected String literalLanguage;
protected PredicateObjectMap pom;
protected void generateInternal(TemplateTermSet subjectMapTemplate,
PredicateObjectMap pom,
Map<ColumnTemplateTerm, HNodePath> subjectTermsToPaths)
throws HNodeNotFoundKarmaException {
this.pom = pom;
combinedSubjectObjectTermsToPaths = new HashMap<>();
combinedSubjectObjectTermsToPaths.putAll(subjectTermsToPaths);
Map<ColumnTemplateTerm, HNodePath> objectTermsToPaths = new HashMap<>();
populateTermsToPathForSubject(objectTermsToPaths, objectTemplateTermSetPopulator.getTerms());
combinedSubjectObjectTermsToPaths.putAll(objectTermsToPaths);
LinkedList<ColumnTemplateTerm> objectColumnTerms = new LinkedList<>();
objectColumnTerms.addAll(objectTemplateTermSetPopulator.getTerms().getAllColumnNameTermElements());
complicatedPlan = new SinglyAnchoredTemplateTermSetPopulatorPlan(combinedSubjectObjectTermsToPaths, objectColumnTerms, subjectMapTemplate.getAllColumnNameTermElements(), selection);
generatePredicatesForPom(pom);
}
protected void generatePredicatesForPom(PredicateObjectMap pom) throws HNodeNotFoundKarmaException {
this.pom = pom;
List<ColumnTemplateTerm> subjectAndObjectTemplateTerms = new LinkedList<>();
subjectAndObjectTemplateTerms.addAll(this.combinedSubjectObjectTermsToPaths.keySet());
LinkedList<ColumnTemplateTerm> predicateColumnTemplateTerms = new LinkedList<>();
predicateColumnTemplateTerms.addAll(pom.getPredicate().getTemplate().getAllColumnNameTermElements());
predicateTemplateTermSetPopulator = new TemplateTermSetPopulator(pom.getPredicate().getTemplate(), new StringBuilder(), uriFormatter, true, true);
Map<ColumnTemplateTerm, HNodePath> combinedSubjectObjectPredicateTermsToPaths = new HashMap<>();
combinedSubjectObjectPredicateTermsToPaths.putAll(combinedSubjectObjectTermsToPaths);
Map<ColumnTemplateTerm, HNodePath> predicateTermsToPaths = new HashMap<>();
populateTermsToPathForSubject(predicateTermsToPaths, pom.getPredicate().getTemplate());
combinedSubjectObjectTermsToPaths.putAll(predicateTermsToPaths);
predicatePlan = new DoublyAnchoredTemplateTermSetPopulator(combinedSubjectObjectTermsToPaths, predicateColumnTemplateTerms, subjectAndObjectTemplateTerms, selection);
}
public Map<PopulatedTemplateTermSet, List<PartiallyPopulatedTermSet>> execute(Row r, List<PopulatedTemplateTermSet> subjects)
{
Map<PopulatedTemplateTermSet, List<PartiallyPopulatedTermSet>> subjectsToObjects = complicatedPlan.execute(r, subjects);
return subjectsToObjects;
}
public void outputTriples(List<KR2RMLRDFWriter> outWriters, Map<PopulatedTemplateTermSet, List<PartiallyPopulatedTermSet>> subjectsToObjects, Row r)
{
for(Entry<PopulatedTemplateTermSet, List<PartiallyPopulatedTermSet>> subjectToObjects : subjectsToObjects.entrySet())
{
PopulatedTemplateTermSet subject = subjectToObjects.getKey();
List<PopulatedTemplateTermSet> objects = objectTemplateTermSetPopulator.generatePopulatedTemplatesFromPartials( subjectToObjects.getValue());
for(PopulatedTemplateTermSet object : objects )
{
List<PopulatedTemplateTermSet> predicates = predicateTemplateTermSetPopulator.generatePopulatedTemplatesFromPartials(predicatePlan.execute(r, subject, object));
for(PopulatedTemplateTermSet predicate : predicates)
{
for(KR2RMLRDFWriter outWriter : outWriters)
{
outputTriple(outWriter, subject, predicate, object);
}
}
}
}
}
protected abstract void outputTriple(KR2RMLRDFWriter outWriter, PopulatedTemplateTermSet subject,
PopulatedTemplateTermSet predicate, PopulatedTemplateTermSet object);
}