org.metacsp.examples.meta.TestTrajectoryEnvelopeSchedulerThree Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of meta-csp-framework Show documentation
Show all versions of meta-csp-framework Show documentation
A Java API for Meta-CSP based reasoning
package org.metacsp.examples.meta;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.Arrays;
import org.metacsp.framework.ConstraintNetwork;
import org.metacsp.framework.Variable;
import org.metacsp.meta.spatioTemporal.paths.Map;
import org.metacsp.meta.spatioTemporal.paths.TrajectoryEnvelopeScheduler;
import org.metacsp.multi.allenInterval.AllenIntervalConstraint;
import org.metacsp.multi.spatial.DE9IM.DE9IMRelationSolver;
import org.metacsp.multi.spatial.DE9IM.GeometricShapeDomain;
import org.metacsp.multi.spatioTemporal.paths.Trajectory;
import org.metacsp.multi.spatioTemporal.paths.PoseSteering;
import org.metacsp.multi.spatioTemporal.paths.TrajectoryEnvelope;
import org.metacsp.multi.spatioTemporal.paths.TrajectoryEnvelopeSolver;
import org.metacsp.time.APSPSolver;
import org.metacsp.time.Bounds;
import org.metacsp.utility.UI.JTSDrawingPanel;
import com.vividsolutions.jts.geom.Coordinate;
import com.vividsolutions.jts.geom.Geometry;
import com.vividsolutions.jts.geom.GeometryFactory;
import com.vividsolutions.jts.geom.Point;
public class TestTrajectoryEnvelopeSchedulerThree {
public static void printInfo(TrajectoryEnvelope te) {
double[] teDTs = te.getTrajectory().getDTs();
double[] teCTs = te.getCTs();
DecimalFormat df = new DecimalFormat("#0.00");
df.setRoundingMode(RoundingMode.HALF_DOWN);
System.out.println("------------------------------------------\n" + te + "\nGround env: " + te.getGroundEnvelopes() + "\nDTs and CTs\n------------------------------------------");
for (int i = 0; i < teDTs.length; i++) {
System.out.println(i + ": " + df.format(teDTs[i]) + " \t " + df.format(teCTs[i]));
}
}
public static void main(String[] args) {
TrajectoryEnvelopeScheduler metaSolver = new TrajectoryEnvelopeScheduler(0, 100000);
TrajectoryEnvelopeSolver solver = (TrajectoryEnvelopeSolver)metaSolver.getConstraintSolvers()[0];
Variable[] vars = solver.createVariables(3);
TrajectoryEnvelope var0 = (TrajectoryEnvelope)vars[0];
TrajectoryEnvelope var1 = (TrajectoryEnvelope)vars[1];
TrajectoryEnvelope var2 = (TrajectoryEnvelope)vars[2];
Trajectory traj0 = new Trajectory("paths/newpath1.path");
var0.setFootprint(1.3, 3.5, 0.0, 0.0);
var0.setTrajectory(traj0);
Trajectory traj1 = new Trajectory("paths/newpath2.path");
var1.setFootprint(1.3, 3.5, 0.0, 0.0);
var1.setTrajectory(traj1);
Trajectory traj2 = new Trajectory("paths/newpath3.path");
var2.setFootprint(1.3, 3.5, 0.0, 0.0);
var2.setTrajectory(traj2);
var0.setRobotID(1);
var1.setRobotID(2);
var2.setRobotID(3);
System.out.println(var0 + " has domain " + var0.getDomain());
System.out.println(var1 + " has domain " + var1.getDomain());
System.out.println(var2 + " has domain " + var2.getDomain());
Map map = new Map(null, null);
metaSolver.addMetaConstraint(map);
JTSDrawingPanel.drawConstraintNetwork("Geometries before refinement",solver.getConstraintNetwork());
ConstraintNetwork refined1 = metaSolver.refineTrajectoryEnvelopes();
System.out.println("REFINED 1: "+ refined1);
ConstraintNetwork refined2 = metaSolver.refineTrajectoryEnvelopes();
System.out.println("REFINED 2: "+ refined2);
System.out.println("====================\n== BEFORE SOLVING ==\n====================");
printInfo(var0);
printInfo(var1);
printInfo(var2);
boolean solved = metaSolver.backtrack();
System.out.println("Solved? " + solved);
if (solved) System.out.println("Added resolvers:\n" + Arrays.toString(metaSolver.getAddedResolvers()));
System.out.println("===================\n== AFTER SOLVING ==\n===================");
printInfo(var0);
printInfo(var1);
printInfo(var2);
JTSDrawingPanel.drawConstraintNetwork("Geometries after refinement",refined1);
ConstraintNetwork.draw(solver.getConstraintNetwork());
}
}