TestX: 
PROC [design: 
CD.Design] 
RETURNS [channelCT: Core.CellType] = {
left: CD.Object ← PW.Get[design, "left.mask"];
right: CD.Object ← PW.Get[design, "right.mask"];
leftCT: Core.CellType ← PWCore.FromLayoutWithoutPublic[left];
rightCT: Core.CellType ← PWCore.FromLayoutWithoutPublic[right];
public: Core.Wire ← CoreCreate.Wires["middlea", "through", "bar", "left", "higha", "highb"];
onlyInternal: Core.Wire ← CoreCreate.Wires["middleb", "green", "red", "ring", "foo"];
channelCT ← CoreCreate.Cell[
public: public, 
onlyInternal: onlyInternal,
instances: 
LIST [
CoreCreate.Instance[leftCT, ["righta", "middlea"], ["rightb", "middleb"]],
CoreCreate.Instance[rightCT, ["righta", "middlea"], ["rightb", "middleb"]]
],
name: "ChannelInX"
];
PWCore.SetLayout[channelCT, $RawChannelRoute, $ChannelInfo, 
NEW [ChannelInfoRec ← [
direction: vertical, 
tech: design.technology,
bottomOrLeftWires: LIST [CoreOps.FindWire[public, "middlea"], CoreOps.FindWire[public, "through"], CoreOps.FindWire[public, "highb"]], 
topOrRightWires: LIST[CoreOps.FindWire[public, "through"], CoreOps.FindWire[public, "highb"]],
trunk: "metal",
branch: "metal2"
]]];
};
 
TestY: 
PROC [design: 
CD.Design] 
RETURNS [channelCT: Core.CellType] = {
left: CD.Object ← PW.Get[design, "rleft.mask"];
right: CD.Object ← PW.Get[design, "rright.mask"];
leftCT: Core.CellType ← PWCore.FromLayoutWithoutPublic[left];
rightCT: Core.CellType ← PWCore.FromLayoutWithoutPublic[right];
public: Core.Wire ← CoreCreate.Wires["middlea", "x", "y", "z", "bar", "left", "higha", "highb"];
onlyInternal: Core.Wire ← CoreCreate.Wires["middleb", "green", "red", "ring", "foo"];
channelCT ← CoreCreate.Cell[
public: public, 
onlyInternal: onlyInternal,
instances: 
LIST [
CoreCreate.Instance[rightCT, ["righta", "middlea"], ["foo", "middlea"], ["rightb", "middleb"]],
CoreCreate.Instance[leftCT, ["righta", "middlea"], ["rightb", "middleb"]]
],
name: "ChannelInY"
];
PWCore.SetLayout[channelCT, $RawChannelRoute, $ChannelInfo, 
NEW [ChannelInfoRec ← [
direction: horizontal, 
tech: design.technology,
justifyBottomOrLeft: FALSE,
bottomOrLeftWires: LIST [public[0], public[1], public[2], public[3]], 
topOrRightWires: LIST[public[0], public[1], public[2], public[3]],
trunk: "metal",
branch: "metal2"
]]];
};