org.protempa.SequentialTemporalPatternDefinition Maven / Gradle / Ivy
/*
* #%L
* Protempa Framework
* %%
* Copyright (C) 2012 - 2013 Emory University
* %%
* 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.
* #L%
*/
package org.protempa;
import java.io.Serializable;
import java.util.HashSet;
import java.util.Set;
import org.apache.commons.lang3.builder.ReflectionToStringBuilder;
import org.protempa.proposition.interval.Relation;
public class SequentialTemporalPatternDefinition extends AbstractAbstractionDefinition {
private static final long serialVersionUID = 456697454379224533L;
private static final SubsequentTemporalExtendedPropositionDefinition[] DEFAULT_REL = new SubsequentTemporalExtendedPropositionDefinition[0];
private boolean solid;
private TemporalPatternOffset temporalOffset;
private boolean concatenable;
private TemporalExtendedPropositionDefinition firstTemporalExtendedPropositionDefinition;
private SubsequentTemporalExtendedPropositionDefinition[] subsequentTemporalExtendedPropositionDefinitions;
private boolean allowPartialMatches;
public static class SubsequentTemporalExtendedPropositionDefinition implements Serializable {
private static final long serialVersionUID = 1;
private final Relation relation;
private final TemporalExtendedPropositionDefinition relatedTemporalExtendedPropositionDefinition;
public SubsequentTemporalExtendedPropositionDefinition(Relation relation,
TemporalExtendedPropositionDefinition relatedTemporalExtendedPropositionDefinition) {
this.relation = relation;
this.relatedTemporalExtendedPropositionDefinition = relatedTemporalExtendedPropositionDefinition;
}
public Relation getRelation() {
return relation;
}
public TemporalExtendedPropositionDefinition getRelatedTemporalExtendedPropositionDefinition() {
return relatedTemporalExtendedPropositionDefinition;
}
}
public SequentialTemporalPatternDefinition(String id) {
super(id);
this.concatenable = true;
this.solid = true;
this.subsequentTemporalExtendedPropositionDefinitions = DEFAULT_REL;
}
public TemporalExtendedPropositionDefinition getFirstTemporalExtendedPropositionDefinition() {
return firstTemporalExtendedPropositionDefinition;
}
public void setFirstTemporalExtendedPropositionDefinition(TemporalExtendedPropositionDefinition firstTemporalExtendedPropositionDefinition) {
this.firstTemporalExtendedPropositionDefinition = firstTemporalExtendedPropositionDefinition;
}
public SubsequentTemporalExtendedPropositionDefinition[] getSubsequentTemporalExtendedPropositionDefinitions() {
return subsequentTemporalExtendedPropositionDefinitions;
}
public void setSubsequentTemporalExtendedPropositionDefinitions(
SubsequentTemporalExtendedPropositionDefinition[] subsequentTemporalExtendedPropositionDefinitions) {
if (subsequentTemporalExtendedPropositionDefinitions == null) {
this.subsequentTemporalExtendedPropositionDefinitions = DEFAULT_REL;
} else {
this.subsequentTemporalExtendedPropositionDefinitions =
subsequentTemporalExtendedPropositionDefinitions.clone();
}
}
@Override
public Set getAbstractedFrom() {
HashSet set = new HashSet<>();
if (this.firstTemporalExtendedPropositionDefinition != null) {
set.add(
this.firstTemporalExtendedPropositionDefinition
.getPropositionId());
}
for (SubsequentTemporalExtendedPropositionDefinition rel :
this.subsequentTemporalExtendedPropositionDefinitions) {
set.add(
rel.getRelatedTemporalExtendedPropositionDefinition()
.getPropositionId());
}
return set;
}
@Override
public boolean isConcatenable() {
return this.concatenable;
}
/**
* Sets whether this type of high-level abstraction is concatenable.
*
* @param concatenable true
if concatenable, false
* if not.
*/
public void setConcatenable(boolean concatenable) {
this.concatenable = concatenable;
}
/**
* Returns whether intervals of this type are solid, i.e., never hold over
* properly overlapping intervals. By default, pair abstraction intervals
* are solid.
*
* @return true
or false
.
*/
@Override
public boolean isSolid() {
return this.solid;
}
/**
* Sets whether intervals of this type are solid, i.e., never hold over
* properly overlapping intervals.
*
* @param solid true
or false
.
*/
public void setSolid(boolean solid) {
this.solid = solid;
}
/**
* Returns whether an interval will be generated if only the first, first
* and second, etc. propositions are present.
* @return true
or false
.
*/
public boolean isAllowPartialMatches() {
return allowPartialMatches;
}
/**
* Sets whether to match if only the first, first and second, etc.
* propositions are present.
*
* @param allowPartialMatches true
or false
.
*/
public void setAllowPartialMatches(boolean allowPartialMatches) {
this.allowPartialMatches = allowPartialMatches;
}
@Override
public void accept(PropositionDefinitionVisitor visitor) {
if (visitor == null) {
throw new IllegalArgumentException("processor cannot be null.");
}
visitor.visit(this);
}
@Override
public void acceptChecked(PropositionDefinitionCheckedVisitor visitor)
throws ProtempaException {
if (visitor == null) {
throw new IllegalArgumentException("processor cannot be null.");
}
visitor.visit(this);
}
public TemporalPatternOffset getTemporalOffset() {
return temporalOffset;
}
public void setTemporalOffset(TemporalPatternOffset temporalOffset) {
this.temporalOffset = temporalOffset;
}
@Override
public void reset() {
super.reset();
this.concatenable = true;
this.solid = true;
this.subsequentTemporalExtendedPropositionDefinitions = DEFAULT_REL;
this.temporalOffset = null;
this.firstTemporalExtendedPropositionDefinition = null;
}
@Override
protected void recalculateChildren() {
Set abstractedFrom = getAbstractedFrom();
String[] inverseIsA = getInverseIsA();
if (inverseIsA != null) {
for (String propId : inverseIsA) {
abstractedFrom.add(propId);
}
}
this.children =
abstractedFrom.toArray(new String[abstractedFrom.size()]);
}
@Override
public String toString() {
return ReflectionToStringBuilder.reflectionToString(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy