LogicalPlan plan = null;
LOLoad load = null;
LOForEach foreach = null;
LOFilter filter = null;
LOStore stor = null;
plan = new LogicalPlan();
LogicalSchema schema = new LogicalSchema();
schema.addField(new LogicalSchema.LogicalFieldSchema("name", null, DataType.CHARARRAY));
LogicalSchema bagSchema = new LogicalSchema();
LogicalSchema bagTupleSchema = new LogicalSchema();
bagTupleSchema.addField( new LogicalSchema.LogicalFieldSchema("name", null, DataType.CHARARRAY) );
bagSchema.addField( new LogicalSchema.LogicalFieldSchema( "t", bagTupleSchema, DataType.TUPLE ) );
schema.addField(new LogicalSchema.LogicalFieldSchema("cuisines", bagSchema, DataType.BAG));
load = new LOLoad(null, schema, plan);
load.setAlias("A");
plan.add(load);
foreach = new LOForEach(plan);
LogicalPlan innerPlan = new LogicalPlan();
LOInnerLoad innerLoad = new LOInnerLoad(innerPlan, foreach, 0);
innerPlan.add(innerLoad);
LOInnerLoad innerLoad2 = new LOInnerLoad(innerPlan, foreach, 1);
innerPlan.add(innerLoad2);
LogicalExpressionPlan namePrj = new LogicalExpressionPlan();
ProjectExpression prjName = new ProjectExpression(namePrj, DataType.CHARARRAY, 0, 0);
namePrj.add(prjName);
LogicalExpressionPlan cuisinesPrj = new LogicalExpressionPlan();
ProjectExpression prjCuisines = new ProjectExpression(cuisinesPrj, DataType.BAG, 1, 0);
cuisinesPrj.add(prjCuisines);
List<LogicalExpressionPlan> expPlans = new ArrayList<LogicalExpressionPlan>();
expPlans.add(namePrj);
expPlans.add(cuisinesPrj);
boolean flatten[] = new boolean[2];
flatten[0] = false;
flatten[1] = true;
LOGenerate generate = new LOGenerate(innerPlan, expPlans, flatten);
innerPlan.add(generate);
innerPlan.connect(innerLoad, generate);
innerPlan.connect(innerLoad2, generate);
foreach.setInnerPlan(innerPlan);
foreach.setAlias("B");
plan.add(foreach);
plan.connect(load, foreach);
filter = new LOFilter(plan);
LogicalExpressionPlan filterPlan = new LogicalExpressionPlan();
ProjectExpression namePrj2 = new ProjectExpression(filterPlan, DataType.CHARARRAY, 0, 0);
filterPlan.add(namePrj2);
ConstantExpression constExp = new ConstantExpression(filterPlan, DataType.CHARARRAY, "joe");
filterPlan.add(constExp);
EqualExpression equal = new EqualExpression(filterPlan, namePrj2, constExp);
filterPlan.add(equal);
filter.setFilterPlan(filterPlan);
filter.setAlias("C");
plan.add(filter);
LOFilter filter2 = new LOFilter(plan);
LogicalExpressionPlan filter2Plan = new LogicalExpressionPlan();
ProjectExpression name2Prj2 = new ProjectExpression(filter2Plan, DataType.CHARARRAY, 0, 0);
filter2Plan.add(name2Prj2);
ConstantExpression const2Exp = new ConstantExpression(filter2Plan, DataType.CHARARRAY, "joe2");
filter2Plan.add(const2Exp);
EqualExpression equal2 = new EqualExpression(filter2Plan, namePrj2, constExp);
filter2Plan.add(equal2);
filter2.setFilterPlan(filter2Plan);
filter2.setAlias("C1");
plan.add(filter2);
plan.connect(foreach, filter2);
plan.connect(filter2, filter);
stor = new LOStore(plan);
stor.setAlias("D");
plan.add(stor);
plan.connect(filter,stor);
try {
// Stamp everything with a Uid