<stg><name>VecDotDq_DSPx2</name>


<trans_list>

<trans id="135" from="1" to="2">
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>
</trans>
</trans_list>



<state_list>

<state id="1" st_id="1">

<operation id="3" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="6" bw="8" op_0_bw="8" op_1_bw="8">
<![CDATA[
arrayctor.loop.preheader:0  %S_V_read = call i8 @_ssdm_op_Read.ap_auto.i8(i8 %S_V)

]]></Node>
<StgValue><ssdm name="S_V_read"/></StgValue>
</operation>

<operation id="4" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="7" bw="24" op_0_bw="24" op_1_bw="24">
<![CDATA[
arrayctor.loop.preheader:1  %B_1_V_read = call i24 @_ssdm_op_Read.ap_auto.i24(i24 %B_1_V)

]]></Node>
<StgValue><ssdm name="B_1_V_read"/></StgValue>
</operation>

<operation id="5" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="8" bw="24" op_0_bw="24" op_1_bw="24">
<![CDATA[
arrayctor.loop.preheader:2  %B_0_V_read = call i24 @_ssdm_op_Read.ap_auto.i24(i24 %B_0_V)

]]></Node>
<StgValue><ssdm name="B_0_V_read"/></StgValue>
</operation>

<operation id="6" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="9" bw="24" op_0_bw="24" op_1_bw="24">
<![CDATA[
arrayctor.loop.preheader:3  %A_1_V_read = call i24 @_ssdm_op_Read.ap_auto.i24(i24 %A_1_V)

]]></Node>
<StgValue><ssdm name="A_1_V_read"/></StgValue>
</operation>

<operation id="7" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="10" bw="24" op_0_bw="24" op_1_bw="24">
<![CDATA[
arrayctor.loop.preheader:4  %A_0_V_read = call i24 @_ssdm_op_Read.ap_auto.i24(i24 %A_0_V)

]]></Node>
<StgValue><ssdm name="A_0_V_read"/></StgValue>
</operation>

<operation id="8" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="11" bw="6" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:5  %tmp_2 = trunc i24 %B_0_V_read to i6

]]></Node>
<StgValue><ssdm name="tmp_2"/></StgValue>
</operation>

<operation id="9" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="12" bw="6" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:6  %tmp_3 = trunc i24 %B_1_V_read to i6

]]></Node>
<StgValue><ssdm name="tmp_3"/></StgValue>
</operation>

<operation id="10" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="13" bw="24" op_0_bw="24" op_1_bw="6" op_2_bw="12" op_3_bw="6">
<![CDATA[
arrayctor.loop.preheader:7  %tmp = call i24 @_ssdm_op_BitConcatenate.i24.i6.i12.i6(i6 %tmp_2, i12 0, i6 %tmp_3)

]]></Node>
<StgValue><ssdm name="tmp"/></StgValue>
</operation>

<operation id="11" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="14" bw="2" op_0_bw="8">
<![CDATA[
arrayctor.loop.preheader:8  %tmp_4 = trunc i8 %S_V_read to i2

]]></Node>
<StgValue><ssdm name="tmp_4"/></StgValue>
</operation>

<operation id="12" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="15" bw="30" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:9  %rhs_V_cast = zext i24 %tmp to i30

]]></Node>
<StgValue><ssdm name="rhs_V_cast"/></StgValue>
</operation>

<operation id="13" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="17" bw="6" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:11  %tmp_6 = trunc i24 %A_0_V_read to i6

]]></Node>
<StgValue><ssdm name="tmp_6"/></StgValue>
</operation>

<operation id="14" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="18" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:12  %lhs_V_cast = zext i6 %tmp_6 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_cast"/></StgValue>
</operation>

<operation id="15" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="19" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:13  %ret_V_5 = mul i30 %rhs_V_cast, %lhs_V_cast

]]></Node>
<StgValue><ssdm name="ret_V_5"/></StgValue>
</operation>

<operation id="16" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="26" bw="6" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:20  %tmp_8 = trunc i24 %A_1_V_read to i6

]]></Node>
<StgValue><ssdm name="tmp_8"/></StgValue>
</operation>

<operation id="17" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="27" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:21  %lhs_V_0_1_cast = zext i6 %tmp_8 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_0_1_cast"/></StgValue>
</operation>

<operation id="18" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="28" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:22  %ret_V_5_0_1 = mul i30 %rhs_V_cast, %lhs_V_0_1_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_0_1"/></StgValue>
</operation>

<operation id="19" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="35" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:29  %p_Result_s = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %B_0_V_read, i32 6, i32 11)

]]></Node>
<StgValue><ssdm name="p_Result_s"/></StgValue>
</operation>

<operation id="20" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="36" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:30  %p_Result_1_1 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %B_1_V_read, i32 6, i32 11)

]]></Node>
<StgValue><ssdm name="p_Result_1_1"/></StgValue>
</operation>

<operation id="21" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="37" bw="24" op_0_bw="24" op_1_bw="6" op_2_bw="12" op_3_bw="6">
<![CDATA[
arrayctor.loop.preheader:31  %tmp_5 = call i24 @_ssdm_op_BitConcatenate.i24.i6.i12.i6(i6 %p_Result_s, i12 0, i6 %p_Result_1_1)

]]></Node>
<StgValue><ssdm name="tmp_5"/></StgValue>
</operation>

<operation id="22" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="38" bw="2" op_0_bw="2" op_1_bw="8" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:32  %p_Result_2_1 = call i2 @_ssdm_op_PartSelect.i2.i8.i32.i32(i8 %S_V_read, i32 2, i32 3)

]]></Node>
<StgValue><ssdm name="p_Result_2_1"/></StgValue>
</operation>

<operation id="23" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="39" bw="30" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:33  %rhs_V_1_cast = zext i24 %tmp_5 to i30

]]></Node>
<StgValue><ssdm name="rhs_V_1_cast"/></StgValue>
</operation>

<operation id="24" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="41" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:35  %p_Result_3_1 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %A_0_V_read, i32 6, i32 11)

]]></Node>
<StgValue><ssdm name="p_Result_3_1"/></StgValue>
</operation>

<operation id="25" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="42" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:36  %lhs_V_1_cast = zext i6 %p_Result_3_1 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_1_cast"/></StgValue>
</operation>

<operation id="26" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="43" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:37  %ret_V_5_1 = mul i30 %rhs_V_1_cast, %lhs_V_1_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_1"/></StgValue>
</operation>

<operation id="27" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="50" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:44  %p_Result_3_1_1 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %A_1_V_read, i32 6, i32 11)

]]></Node>
<StgValue><ssdm name="p_Result_3_1_1"/></StgValue>
</operation>

<operation id="28" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="51" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:45  %lhs_V_1_1_cast = zext i6 %p_Result_3_1_1 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_1_1_cast"/></StgValue>
</operation>

<operation id="29" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="52" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:46  %ret_V_5_1_1 = mul i30 %rhs_V_1_cast, %lhs_V_1_1_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_1_1"/></StgValue>
</operation>

<operation id="30" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="59" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:53  %p_Result_3 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %B_0_V_read, i32 12, i32 17)

]]></Node>
<StgValue><ssdm name="p_Result_3"/></StgValue>
</operation>

<operation id="31" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="60" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:54  %p_Result_1_2 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %B_1_V_read, i32 12, i32 17)

]]></Node>
<StgValue><ssdm name="p_Result_1_2"/></StgValue>
</operation>

<operation id="32" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="61" bw="24" op_0_bw="24" op_1_bw="6" op_2_bw="12" op_3_bw="6">
<![CDATA[
arrayctor.loop.preheader:55  %tmp_s = call i24 @_ssdm_op_BitConcatenate.i24.i6.i12.i6(i6 %p_Result_3, i12 0, i6 %p_Result_1_2)

]]></Node>
<StgValue><ssdm name="tmp_s"/></StgValue>
</operation>

<operation id="33" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="62" bw="2" op_0_bw="2" op_1_bw="8" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:56  %p_Result_2_2 = call i2 @_ssdm_op_PartSelect.i2.i8.i32.i32(i8 %S_V_read, i32 4, i32 5)

]]></Node>
<StgValue><ssdm name="p_Result_2_2"/></StgValue>
</operation>

<operation id="34" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="63" bw="30" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:57  %rhs_V_2_cast = zext i24 %tmp_s to i30

]]></Node>
<StgValue><ssdm name="rhs_V_2_cast"/></StgValue>
</operation>

<operation id="35" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="65" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:59  %p_Result_3_2 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %A_0_V_read, i32 12, i32 17)

]]></Node>
<StgValue><ssdm name="p_Result_3_2"/></StgValue>
</operation>

<operation id="36" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="66" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:60  %lhs_V_2_cast = zext i6 %p_Result_3_2 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_2_cast"/></StgValue>
</operation>

<operation id="37" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="67" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:61  %ret_V_5_2 = mul i30 %rhs_V_2_cast, %lhs_V_2_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_2"/></StgValue>
</operation>

<operation id="38" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="74" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:68  %p_Result_3_2_1 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %A_1_V_read, i32 12, i32 17)

]]></Node>
<StgValue><ssdm name="p_Result_3_2_1"/></StgValue>
</operation>

<operation id="39" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="75" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:69  %lhs_V_2_1_cast = zext i6 %p_Result_3_2_1 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_2_1_cast"/></StgValue>
</operation>

<operation id="40" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="76" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:70  %ret_V_5_2_1 = mul i30 %rhs_V_2_cast, %lhs_V_2_1_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_2_1"/></StgValue>
</operation>

<operation id="41" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="83" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:77  %p_Result_4 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %B_0_V_read, i32 18, i32 23)

]]></Node>
<StgValue><ssdm name="p_Result_4"/></StgValue>
</operation>

<operation id="42" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="84" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:78  %p_Result_1_3 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %B_1_V_read, i32 18, i32 23)

]]></Node>
<StgValue><ssdm name="p_Result_1_3"/></StgValue>
</operation>

<operation id="43" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="85" bw="24" op_0_bw="24" op_1_bw="6" op_2_bw="12" op_3_bw="6">
<![CDATA[
arrayctor.loop.preheader:79  %tmp_1 = call i24 @_ssdm_op_BitConcatenate.i24.i6.i12.i6(i6 %p_Result_4, i12 0, i6 %p_Result_1_3)

]]></Node>
<StgValue><ssdm name="tmp_1"/></StgValue>
</operation>

<operation id="44" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="86" bw="2" op_0_bw="2" op_1_bw="8" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:80  %p_Result_2_3 = call i2 @_ssdm_op_PartSelect.i2.i8.i32.i32(i8 %S_V_read, i32 6, i32 7)

]]></Node>
<StgValue><ssdm name="p_Result_2_3"/></StgValue>
</operation>

<operation id="45" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="87" bw="30" op_0_bw="24">
<![CDATA[
arrayctor.loop.preheader:81  %rhs_V_3_cast = zext i24 %tmp_1 to i30

]]></Node>
<StgValue><ssdm name="rhs_V_3_cast"/></StgValue>
</operation>

<operation id="46" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="89" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:83  %p_Result_3_3 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %A_0_V_read, i32 18, i32 23)

]]></Node>
<StgValue><ssdm name="p_Result_3_3"/></StgValue>
</operation>

<operation id="47" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="90" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:84  %lhs_V_3_cast = zext i6 %p_Result_3_3 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_3_cast"/></StgValue>
</operation>

<operation id="48" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="91" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:85  %ret_V_5_3 = mul i30 %rhs_V_3_cast, %lhs_V_3_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_3"/></StgValue>
</operation>

<operation id="49" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="110" bw="6" op_0_bw="6" op_1_bw="24" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:104  %p_Result_3_3_1 = call i6 @_ssdm_op_PartSelect.i6.i24.i32.i32(i24 %A_1_V_read, i32 18, i32 23)

]]></Node>
<StgValue><ssdm name="p_Result_3_3_1"/></StgValue>
</operation>

<operation id="50" st_id="1" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="111" bw="30" op_0_bw="6">
<![CDATA[
arrayctor.loop.preheader:105  %lhs_V_3_1_cast = zext i6 %p_Result_3_3_1 to i30

]]></Node>
<StgValue><ssdm name="lhs_V_3_1_cast"/></StgValue>
</operation>

<operation id="51" st_id="1" stage="1" lat="1">
<core>DSP48</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="112" bw="30" op_0_bw="30" op_1_bw="30">
<![CDATA[
arrayctor.loop.preheader:106  %ret_V_5_3_1 = mul i30 %rhs_V_3_cast, %lhs_V_3_1_cast

]]></Node>
<StgValue><ssdm name="ret_V_5_3_1"/></StgValue>
</operation>
</state>

<state id="2" st_id="2">

<operation id="52" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="16" bw="12" op_0_bw="2">
<![CDATA[
arrayctor.loop.preheader:10  %tmp_cast = zext i2 %tmp_4 to i12

]]></Node>
<StgValue><ssdm name="tmp_cast"/></StgValue>
</operation>

<operation id="53" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="20" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:14  %p_Result_6 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_6"/></StgValue>
</operation>

<operation id="54" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="21" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:15  %r_V_1 = lshr i12 %p_Result_6, %tmp_cast

]]></Node>
<StgValue><ssdm name="r_V_1"/></StgValue>
</operation>

<operation id="55" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="22" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:16  %tmp_8_0_cast = zext i12 %r_V_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_0_cast"/></StgValue>
</operation>

<operation id="56" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="23" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:17  %tmp_7 = trunc i30 %ret_V_5 to i12

]]></Node>
<StgValue><ssdm name="tmp_7"/></StgValue>
</operation>

<operation id="57" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="24" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:18  %r_V_1_0_0_1 = lshr i12 %tmp_7, %tmp_cast

]]></Node>
<StgValue><ssdm name="r_V_1_0_0_1"/></StgValue>
</operation>

<operation id="58" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="25" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:19  %tmp_8_0_0_1_cast = zext i12 %r_V_1_0_0_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_0_0_1_cast"/></StgValue>
</operation>

<operation id="59" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="29" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:23  %p_Result_4_0_1 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_0_1, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_0_1"/></StgValue>
</operation>

<operation id="60" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="30" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:24  %r_V_1_0_1 = lshr i12 %p_Result_4_0_1, %tmp_cast

]]></Node>
<StgValue><ssdm name="r_V_1_0_1"/></StgValue>
</operation>

<operation id="61" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="31" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:25  %tmp_8_0_1_cast = zext i12 %r_V_1_0_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_0_1_cast"/></StgValue>
</operation>

<operation id="62" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="32" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:26  %tmp_9 = trunc i30 %ret_V_5_0_1 to i12

]]></Node>
<StgValue><ssdm name="tmp_9"/></StgValue>
</operation>

<operation id="63" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="33" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:27  %r_V_1_0_1_1 = lshr i12 %tmp_9, %tmp_cast

]]></Node>
<StgValue><ssdm name="r_V_1_0_1_1"/></StgValue>
</operation>

<operation id="64" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="34" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:28  %tmp_8_0_1_1_cast = zext i12 %r_V_1_0_1_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_0_1_1_cast"/></StgValue>
</operation>

<operation id="65" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="40" bw="12" op_0_bw="2">
<![CDATA[
arrayctor.loop.preheader:34  %tmp_1_cast = zext i2 %p_Result_2_1 to i12

]]></Node>
<StgValue><ssdm name="tmp_1_cast"/></StgValue>
</operation>

<operation id="66" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="44" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:38  %p_Result_4_1 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_1, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_1"/></StgValue>
</operation>

<operation id="67" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="45" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:39  %r_V_1_1 = lshr i12 %p_Result_4_1, %tmp_1_cast

]]></Node>
<StgValue><ssdm name="r_V_1_1"/></StgValue>
</operation>

<operation id="68" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="46" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:40  %tmp_8_1_cast = zext i12 %r_V_1_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_1_cast"/></StgValue>
</operation>

<operation id="69" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="47" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:41  %tmp_10 = trunc i30 %ret_V_5_1 to i12

]]></Node>
<StgValue><ssdm name="tmp_10"/></StgValue>
</operation>

<operation id="70" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="48" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:42  %r_V_1_1_0_1 = lshr i12 %tmp_10, %tmp_1_cast

]]></Node>
<StgValue><ssdm name="r_V_1_1_0_1"/></StgValue>
</operation>

<operation id="71" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="49" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:43  %tmp_8_1_0_1_cast = zext i12 %r_V_1_1_0_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_1_0_1_cast"/></StgValue>
</operation>

<operation id="72" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="53" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:47  %p_Result_4_1_1 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_1_1, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_1_1"/></StgValue>
</operation>

<operation id="73" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="54" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:48  %r_V_1_1_1 = lshr i12 %p_Result_4_1_1, %tmp_1_cast

]]></Node>
<StgValue><ssdm name="r_V_1_1_1"/></StgValue>
</operation>

<operation id="74" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="55" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:49  %tmp_8_1_1_cast = zext i12 %r_V_1_1_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_1_1_cast"/></StgValue>
</operation>

<operation id="75" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="56" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:50  %tmp_11 = trunc i30 %ret_V_5_1_1 to i12

]]></Node>
<StgValue><ssdm name="tmp_11"/></StgValue>
</operation>

<operation id="76" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="57" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:51  %r_V_1_1_1_1 = lshr i12 %tmp_11, %tmp_1_cast

]]></Node>
<StgValue><ssdm name="r_V_1_1_1_1"/></StgValue>
</operation>

<operation id="77" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="58" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:52  %tmp_8_1_1_1_cast = zext i12 %r_V_1_1_1_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_1_1_1_cast"/></StgValue>
</operation>

<operation id="78" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="64" bw="12" op_0_bw="2">
<![CDATA[
arrayctor.loop.preheader:58  %tmp_2_cast = zext i2 %p_Result_2_2 to i12

]]></Node>
<StgValue><ssdm name="tmp_2_cast"/></StgValue>
</operation>

<operation id="79" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="68" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:62  %p_Result_4_2 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_2, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_2"/></StgValue>
</operation>

<operation id="80" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="69" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:63  %r_V_1_2 = lshr i12 %p_Result_4_2, %tmp_2_cast

]]></Node>
<StgValue><ssdm name="r_V_1_2"/></StgValue>
</operation>

<operation id="81" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="70" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:64  %tmp_8_2_cast = zext i12 %r_V_1_2 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_2_cast"/></StgValue>
</operation>

<operation id="82" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="71" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:65  %tmp_12 = trunc i30 %ret_V_5_2 to i12

]]></Node>
<StgValue><ssdm name="tmp_12"/></StgValue>
</operation>

<operation id="83" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="72" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:66  %r_V_1_2_0_1 = lshr i12 %tmp_12, %tmp_2_cast

]]></Node>
<StgValue><ssdm name="r_V_1_2_0_1"/></StgValue>
</operation>

<operation id="84" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="73" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:67  %tmp_8_2_0_1_cast = zext i12 %r_V_1_2_0_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_2_0_1_cast"/></StgValue>
</operation>

<operation id="85" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="77" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:71  %p_Result_4_2_1 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_2_1, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_2_1"/></StgValue>
</operation>

<operation id="86" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="78" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:72  %r_V_1_2_1 = lshr i12 %p_Result_4_2_1, %tmp_2_cast

]]></Node>
<StgValue><ssdm name="r_V_1_2_1"/></StgValue>
</operation>

<operation id="87" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="79" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:73  %tmp_8_2_1_cast = zext i12 %r_V_1_2_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_2_1_cast"/></StgValue>
</operation>

<operation id="88" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="80" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:74  %tmp_13 = trunc i30 %ret_V_5_2_1 to i12

]]></Node>
<StgValue><ssdm name="tmp_13"/></StgValue>
</operation>

<operation id="89" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="81" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:75  %r_V_1_2_1_1 = lshr i12 %tmp_13, %tmp_2_cast

]]></Node>
<StgValue><ssdm name="r_V_1_2_1_1"/></StgValue>
</operation>

<operation id="90" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="82" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:76  %tmp_8_2_1_1_cast = zext i12 %r_V_1_2_1_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_2_1_1_cast"/></StgValue>
</operation>

<operation id="91" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="88" bw="12" op_0_bw="2">
<![CDATA[
arrayctor.loop.preheader:82  %tmp_3_cast = zext i2 %p_Result_2_3 to i12

]]></Node>
<StgValue><ssdm name="tmp_3_cast"/></StgValue>
</operation>

<operation id="92" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="92" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:86  %p_Result_4_3 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_3, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_3"/></StgValue>
</operation>

<operation id="93" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="93" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:87  %r_V_1_3 = lshr i12 %p_Result_4_3, %tmp_3_cast

]]></Node>
<StgValue><ssdm name="r_V_1_3"/></StgValue>
</operation>

<operation id="94" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="94" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:88  %tmp_8_3_cast = zext i12 %r_V_1_3 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_3_cast"/></StgValue>
</operation>

<operation id="95" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="95" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:89  %tmp1 = add i13 %tmp_8_0_cast, %tmp_8_1_cast

]]></Node>
<StgValue><ssdm name="tmp1"/></StgValue>
</operation>

<operation id="96" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="96" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:90  %tmp1_cast = zext i13 %tmp1 to i14

]]></Node>
<StgValue><ssdm name="tmp1_cast"/></StgValue>
</operation>

<operation id="97" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="97" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:91  %tmp2 = add i13 %tmp_8_2_cast, %tmp_8_3_cast

]]></Node>
<StgValue><ssdm name="tmp2"/></StgValue>
</operation>

<operation id="98" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="98" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:92  %tmp2_cast = zext i13 %tmp2 to i14

]]></Node>
<StgValue><ssdm name="tmp2_cast"/></StgValue>
</operation>

<operation id="99" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="99" bw="14" op_0_bw="14" op_1_bw="14">
<![CDATA[
arrayctor.loop.preheader:93  %temp_0_V_write_assi = add i14 %tmp2_cast, %tmp1_cast

]]></Node>
<StgValue><ssdm name="temp_0_V_write_assi"/></StgValue>
</operation>

<operation id="100" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="100" bw="15" op_0_bw="14">
<![CDATA[
arrayctor.loop.preheader:94  %temp_0_V_write_assi_1 = zext i14 %temp_0_V_write_assi to i15

]]></Node>
<StgValue><ssdm name="temp_0_V_write_assi_1"/></StgValue>
</operation>

<operation id="101" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="101" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:95  %tmp_14 = trunc i30 %ret_V_5_3 to i12

]]></Node>
<StgValue><ssdm name="tmp_14"/></StgValue>
</operation>

<operation id="102" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="102" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:96  %r_V_1_3_0_1 = lshr i12 %tmp_14, %tmp_3_cast

]]></Node>
<StgValue><ssdm name="r_V_1_3_0_1"/></StgValue>
</operation>

<operation id="103" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="103" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:97  %tmp_8_3_0_1_cast = zext i12 %r_V_1_3_0_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_3_0_1_cast"/></StgValue>
</operation>

<operation id="104" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="104" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:98  %tmp3 = add i13 %tmp_8_0_0_1_cast, %tmp_8_1_0_1_cast

]]></Node>
<StgValue><ssdm name="tmp3"/></StgValue>
</operation>

<operation id="105" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="105" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:99  %tmp3_cast = zext i13 %tmp3 to i14

]]></Node>
<StgValue><ssdm name="tmp3_cast"/></StgValue>
</operation>

<operation id="106" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="106" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:100  %tmp4 = add i13 %tmp_8_2_0_1_cast, %tmp_8_3_0_1_cast

]]></Node>
<StgValue><ssdm name="tmp4"/></StgValue>
</operation>

<operation id="107" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="107" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:101  %tmp4_cast = zext i13 %tmp4 to i14

]]></Node>
<StgValue><ssdm name="tmp4_cast"/></StgValue>
</operation>

<operation id="108" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="108" bw="14" op_0_bw="14" op_1_bw="14">
<![CDATA[
arrayctor.loop.preheader:102  %temp_2_V_write_assi = add i14 %tmp4_cast, %tmp3_cast

]]></Node>
<StgValue><ssdm name="temp_2_V_write_assi"/></StgValue>
</operation>

<operation id="109" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="109" bw="15" op_0_bw="14">
<![CDATA[
arrayctor.loop.preheader:103  %temp_2_V_write_assi_1 = zext i14 %temp_2_V_write_assi to i15

]]></Node>
<StgValue><ssdm name="temp_2_V_write_assi_1"/></StgValue>
</operation>

<operation id="110" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="113" bw="12" op_0_bw="12" op_1_bw="30" op_2_bw="32" op_3_bw="32">
<![CDATA[
arrayctor.loop.preheader:107  %p_Result_4_3_1 = call i12 @_ssdm_op_PartSelect.i12.i30.i32.i32(i30 %ret_V_5_3_1, i32 18, i32 29)

]]></Node>
<StgValue><ssdm name="p_Result_4_3_1"/></StgValue>
</operation>

<operation id="111" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="114" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:108  %r_V_1_3_1 = lshr i12 %p_Result_4_3_1, %tmp_3_cast

]]></Node>
<StgValue><ssdm name="r_V_1_3_1"/></StgValue>
</operation>

<operation id="112" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="115" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:109  %tmp_8_3_1_cast = zext i12 %r_V_1_3_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_3_1_cast"/></StgValue>
</operation>

<operation id="113" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="116" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:110  %tmp5 = add i13 %tmp_8_0_1_cast, %tmp_8_1_1_cast

]]></Node>
<StgValue><ssdm name="tmp5"/></StgValue>
</operation>

<operation id="114" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="117" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:111  %tmp5_cast = zext i13 %tmp5 to i14

]]></Node>
<StgValue><ssdm name="tmp5_cast"/></StgValue>
</operation>

<operation id="115" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="118" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:112  %tmp6 = add i13 %tmp_8_2_1_cast, %tmp_8_3_1_cast

]]></Node>
<StgValue><ssdm name="tmp6"/></StgValue>
</operation>

<operation id="116" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="119" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:113  %tmp6_cast = zext i13 %tmp6 to i14

]]></Node>
<StgValue><ssdm name="tmp6_cast"/></StgValue>
</operation>

<operation id="117" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="120" bw="14" op_0_bw="14" op_1_bw="14">
<![CDATA[
arrayctor.loop.preheader:114  %temp_1_V_write_assi = add i14 %tmp6_cast, %tmp5_cast

]]></Node>
<StgValue><ssdm name="temp_1_V_write_assi"/></StgValue>
</operation>

<operation id="118" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="121" bw="15" op_0_bw="14">
<![CDATA[
arrayctor.loop.preheader:115  %temp_1_V_write_assi_1 = zext i14 %temp_1_V_write_assi to i15

]]></Node>
<StgValue><ssdm name="temp_1_V_write_assi_1"/></StgValue>
</operation>

<operation id="119" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="122" bw="12" op_0_bw="30">
<![CDATA[
arrayctor.loop.preheader:116  %tmp_15 = trunc i30 %ret_V_5_3_1 to i12

]]></Node>
<StgValue><ssdm name="tmp_15"/></StgValue>
</operation>

<operation id="120" st_id="2" stage="1" lat="1">
<core>Shift</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="123" bw="12" op_0_bw="12" op_1_bw="12">
<![CDATA[
arrayctor.loop.preheader:117  %r_V_1_3_1_1 = lshr i12 %tmp_15, %tmp_3_cast

]]></Node>
<StgValue><ssdm name="r_V_1_3_1_1"/></StgValue>
</operation>

<operation id="121" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="124" bw="13" op_0_bw="12">
<![CDATA[
arrayctor.loop.preheader:118  %tmp_8_3_1_1_cast = zext i12 %r_V_1_3_1_1 to i13

]]></Node>
<StgValue><ssdm name="tmp_8_3_1_1_cast"/></StgValue>
</operation>

<operation id="122" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="125" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:119  %tmp7 = add i13 %tmp_8_0_1_1_cast, %tmp_8_1_1_1_cast

]]></Node>
<StgValue><ssdm name="tmp7"/></StgValue>
</operation>

<operation id="123" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="126" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:120  %tmp7_cast = zext i13 %tmp7 to i14

]]></Node>
<StgValue><ssdm name="tmp7_cast"/></StgValue>
</operation>

<operation id="124" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="127" bw="13" op_0_bw="13" op_1_bw="13">
<![CDATA[
arrayctor.loop.preheader:121  %tmp8 = add i13 %tmp_8_2_1_1_cast, %tmp_8_3_1_1_cast

]]></Node>
<StgValue><ssdm name="tmp8"/></StgValue>
</operation>

<operation id="125" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="128" bw="14" op_0_bw="13">
<![CDATA[
arrayctor.loop.preheader:122  %tmp8_cast = zext i13 %tmp8 to i14

]]></Node>
<StgValue><ssdm name="tmp8_cast"/></StgValue>
</operation>

<operation id="126" st_id="2" stage="1" lat="1">
<core>AddSub</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="129" bw="14" op_0_bw="14" op_1_bw="14">
<![CDATA[
arrayctor.loop.preheader:123  %temp_3_V_write_assi = add i14 %tmp8_cast, %tmp7_cast

]]></Node>
<StgValue><ssdm name="temp_3_V_write_assi"/></StgValue>
</operation>

<operation id="127" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="130" bw="15" op_0_bw="14">
<![CDATA[
arrayctor.loop.preheader:124  %temp_3_V_write_assi_1 = zext i14 %temp_3_V_write_assi to i15

]]></Node>
<StgValue><ssdm name="temp_3_V_write_assi_1"/></StgValue>
</operation>

<operation id="128" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="131" bw="60" op_0_bw="60" op_1_bw="15">
<![CDATA[
arrayctor.loop.preheader:125  %mrv = insertvalue { i15, i15, i15, i15 } undef, i15 %temp_0_V_write_assi_1, 0

]]></Node>
<StgValue><ssdm name="mrv"/></StgValue>
</operation>

<operation id="129" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="132" bw="60" op_0_bw="60" op_1_bw="15">
<![CDATA[
arrayctor.loop.preheader:126  %mrv_1 = insertvalue { i15, i15, i15, i15 } %mrv, i15 %temp_1_V_write_assi_1, 1

]]></Node>
<StgValue><ssdm name="mrv_1"/></StgValue>
</operation>

<operation id="130" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="133" bw="60" op_0_bw="60" op_1_bw="15">
<![CDATA[
arrayctor.loop.preheader:127  %mrv_2 = insertvalue { i15, i15, i15, i15 } %mrv_1, i15 %temp_2_V_write_assi_1, 2

]]></Node>
<StgValue><ssdm name="mrv_2"/></StgValue>
</operation>

<operation id="131" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="134" bw="60" op_0_bw="60" op_1_bw="15">
<![CDATA[
arrayctor.loop.preheader:128  %mrv_3 = insertvalue { i15, i15, i15, i15 } %mrv_2, i15 %temp_3_V_write_assi_1, 3

]]></Node>
<StgValue><ssdm name="mrv_3"/></StgValue>
</operation>

<operation id="132" st_id="2" stage="1" lat="1">
<core>NULL</core>
<MemPortIdVec></MemPortIdVec>
<condition id="-1">
<or_exp><and_exp></and_exp></or_exp>
</condition>

<Node id="135" bw="0" op_0_bw="60">
<![CDATA[
arrayctor.loop.preheader:129  ret { i15, i15, i15, i15 } %mrv_3

]]></Node>
<StgValue><ssdm name=""/></StgValue>
</operation>
</state>
</state_list>


<ports>
</ports>


<dataflows>
</dataflows>


</stg>
