Mmul TA D 16_256_16★

top Top: -

par Par: 85 lines

Problem Statement

\(256 \times 16\) 行列 \(A\) と、\(256 \times 16\) 行列 \(B\) に対して、行列積 \(C = A^T \times B\) (shape:\(16 \times 16\)) を計算し、DRAMへ 出力してください。\(A,B,C\) のレイアウトは以下のとおりです。

A: ((8_L2B:1, 4:2, 8_L1B:1), (2:1, 4_PE:1, 2_W:1)) B: ((8_L2B:1, 4:2, 8_L1B:1), (2:1, 4_PE:1, 2_W:1)) C: ((4_L2B:2, 4:8), (8:1, 2_W:1))
\(A, B, C\) の値はこちらです。この問題は乱数値が使用されています。

A (256, 16):

[[-129, 461, 237, 101,-353,-353,-453, 374, 103, 213,-491, 481, 340,-295,-326,-325], [-201, 25, -70,-214, 114,-370,-213,-137, -45, 292,-308, 14, 94,-465, 110,-338], [-446, 459, 476, 315,-201,-412, 188, -62,-388, -5,-477, 419,-248, 166,-193, 20], [ 47,-323, 480, 281, 450, 404, 100, 431,-422,-312,-466,-179,-114,-235, 336,-147], [-225, 43,-368, 309,-436, 498, 278,-309,-507, 323, 211, 234, 277,-437,-145,-394], [ 371, 126,-174,-447,-194,-180, 235, 140, 396, -29,-390, 218, 267, 62, 277, -7], [ 23, -75,-486,-402,-480, 139,-191, 8, 417,-257, -92, 261,-278,-434,-216,-347], [ 440, 315, 136, 380, 310,-321, 401, 40, 314, 405,-187,-400,-279, -75, 325, 369], [-505, 11, -85,-285,-390,-167, 453,-182, 19, 207,-140, 483, 473,-255, -3,-204], [-221,-475, 112, 2,-460,-227, 418,-267,-364, -11, 497,-265, 176, 267,-269, 233], [-136, 135, 136, 36,-420, 343,-184,-322,-471, 93, 181,-496, 12,-281, 148,-334], [ 195,-116, 447,-372,-163,-396, 434, 386,-248, 163, 324, 56, 30,-265,-417, 406], [ 410, 136,-165,-155, 231, 406, 396, 286, 145,-426,-347, 408, 108,-503,-409, 167], [-507,-348, 49, 196, 155,-283, 217,-270,-179, 252, 153, 357, 161, 69,-417,-136], [-241,-263, 484,-110, 401, 134, 301, 2, 78, -8,-313, 227,-225,-488, 148,-331], [ 451, 464, 424,-133,-497, 438, -74, 477, 474, 361,-211,-118, 359,-188,-339, 58], [ 446, 200, 71,-413, 117, 501,-369, 18, 386, 246, 201, 207,-144,-212, 316, 317], [ 375, 423, 11, 1, 305, 153, 206, 302, 399,-166,-128,-416, 80,-476, -36, 43], [-219, 93,-481,-474, 330,-144,-382, 22, 276,-291, 125,-425,-460, 32, 41, 140], [ 231, 487, 16,-182, 302,-235, -63,-432,-487, 473, 344, 200, -94,-335,-352,-256], [ 50, 219, 164,-226, 465, 243, 55, 114, -83,-259,-148, 264,-498,-394,-465,-471], [ 363, 208, -27,-412, -9, -28,-335, -68,-104, 118, 138,-466,-129, 128, 3, 365], [ 162,-346,-440, 145,-485, 87, 450, 77,-115, 146, -43, 46, 452,-117, 472, 415], [-312,-441,-409,-494,-416, 187,-440,-186, 353,-489, 322,-224,-391, 201, 132, 386], [ 240, 310,-224,-331, 256, 314, 502, -90,-132, 283,-164, 441, 367, -73, 256, 260], [-407, 412, 5, 334,-185, 405,-114,-501, 415,-419,-186, 460, 461, 75, 135, -53], [-212,-176, 176, 258, 298, 296,-419, -6,-454, 50, -60, 397,-153,-393,-366, 267], [ 121,-409,-426, 205,-438, 329, 211,-429,-426, 498,-129,-133, 320, 457, 497, 259], [-127,-427, 283, 59, -78, 416,-399, -8,-501, -33,-455,-391,-392, 152, 251, 85], [ 473,-129,-220, 377,-284, 474,-500, 481,-468, 400, 28, 504,-437, 55, 480, 23], [ 132, 200, -47, 130, 86, 410,-466,-225, 461, 399, -46, 123,-228,-320, -38,-151], [ 85,-433, 485, 497, 202, 36,-196, 321, 189,-346, 420, 330, 460, 231, 116, -84], [ 443, 374,-466,-486,-127, 318, 498,-358, 96,-122, 481, 350, 346, -33, -88,-233], [-455, 373, 320, 511, 508, 56, 275, 455, 358,-259, -51,-380, 464, 108,-278, 175], [ 120,-146,-396, 175, 20, 278, 20, 360, 53, 62, 385, -99,-375,-483, 261, 123], [ 208,-294,-373,-498,-153, 92,-111, -65, 413,-156, 14, 290,-106, 125, 371, 460], [-362, 436, -9,-248, -42, 491, -8,-176, 136,-267,-435,-381,-381,-357,-370, 144], [-326,-159, 406, -27, 171,-336,-316,-471,-340,-227,-331,-422,-389, -41,-301,-139], [ 3, 194,-472, 306, 130,-429, 382, 430,-450,-229, 313, 254,-324,-298,-133, -16], [ 121,-135, -39, 253,-475,-254, 218, 404, 11, 32,-403, -54, 33,-264,-237,-126], [-492,-183,-296,-177,-390, 399, 95, 183, 296, -2,-423, 37, 88, 251, -70,-382], [-222,-141, 149, 72,-148, 498, 108,-270,-408,-356,-261,-348,-321,-221,-335, 406], [-430, 25, -92, 493,-398,-105, 480, 374, 324,-248,-338, 172, 439, 58, 73,-226], [ 275,-321,-181, -77, 7,-264,-395, 113,-217, 83,-354, -20, 33,-459,-168,-375], [-448, 501,-182, 317,-252, 185, 266, 97, -30, -91,-155, 439, 338, 476,-385, 236], [ 448,-327,-444, 246, 76, 350,-369, 302,-306,-345,-344, 322, 169, 23,-145, 386], [-111, 324, -63,-127, -39,-204, 253, 2,-275, 409,-119, 44, 416, 127,-393, 450], [ 130,-170,-370, 301, 122, 34, 403, 295,-357,-193,-258, 249,-478, 71, 268, 385], [-162, 328,-399, 354,-382,-106, 304,-359,-278, 227, 225, 144, 198, 43,-255,-159], [-327, 418, 85,-102, -39, 458,-355, 88, 6, 114,-494, 381, 442, 66, 201, 432], [ 212,-356, 78, 109, -78, 242, 444, 435, -51,-397, 496, 347,-385, 430, 378, 19], [ 93,-104,-456,-169, 310,-508,-171,-105, 38, 429,-158,-157, 243, -49,-283, -49], [-368,-332, -2, -84, 424,-141, 82, 135,-499, 167,-330, 472,-360, -88,-425, 508], [ 2, 97,-444, 255,-298, 407,-302,-317,-475, -29, 66,-445, 282, -48, 24, -61], [-102, 61,-354,-326, 370, 456,-130,-235, 147, -94,-487,-353, 221, 162,-485,-285], [-276, 176,-492,-406, 307,-330, 156,-269,-411,-263, 227, 364, 338,-106, 172,-303], [-212, 405,-499,-425,-300,-485,-327, 85, -81, 402, 325,-162,-247,-124, 92,-238], [ 127, -93, 53, -66,-211, 459, 269,-369, 377, -13, 404, 307, -77,-489,-237, 42], [ 136,-248,-370, 342, 496, 26,-337,-234,-494, 424,-392, 78,-232, 55, 155, 337], [-301,-501,-372, 409, 382, 99, 102, 168,-333, 424, -84,-120, 19,-464,-342, 243], [-428, 105,-261,-114,-217,-148, 224,-208, 67, -25, 167, 447, 238,-292,-481,-244], [ 97,-460, -4, 99,-170, 277,-403,-436, 233, -5, 192, -67,-260, 326, 306, 199], [-234, 92,-143,-419, 427,-372, 461, -56,-323, 42, 381, 237, 313, 162, 196, 357], [-257, -11,-286, 499, 454,-472, 210, 435,-328, 69, 425,-478, 202,-208, 434, 482], [ 454, -27, 370, 352,-186, 336,-475, 98,-277,-389,-434, 200,-164, 230,-446,-190], [ 40, 297,-186, 128, 395, 118,-274,-488, 378,-491, 383, 29, 449, 305, 509,-153], [ 273,-101, -21, 130, 382, 495, 274, -85, -81, 243,-268,-399,-149,-218,-209,-273], [-469,-494, 499, -74,-119, 183,-289, 460, 293,-421, -85, 388, 455, -34, 116,-341], [ 502,-275, 453, 153, 110, 12,-276,-332,-287,-322, 286,-154,-453, 480, 392, 438], [ 506,-334,-107, 264, 200,-355, 323,-283,-283, 37, 95, 82,-419, 386,-241,-380], [ 398, 466, 370, 316, 158, 52,-423, -94,-131,-247, 228, -5,-430,-287, 187,-435], [ 359, -5, -20, 94, 332,-156, 182, 67,-239, 387, 304, 162, 358, 376, 213, 345], [ 202, 184, 121, 258,-350, 390, 380,-483, 333,-381,-169, 249,-348, 325, 340, 7], [-506,-219, 119, 492, 134,-246, 137, 40, 286,-403, 267, 42, 474,-162, 135, 442], [-408, 447, 192,-443,-204, 213,-444, 84,-158, 123,-466, 380, 484, 480, 255,-379], [ 264,-487,-490,-181, -12, 276, 187, -56,-232, 509, -76, -50,-345, 301, 198,-286], [-428, 184, 158,-233, 461,-358, -70, 454, -83, 141,-105,-232, 495, -93, 403,-277], [-294,-481, 155,-135, 373, -28, 479,-323, 377, 283, 277, 353, 267, 129,-378,-479], [ 430, 119, 303, -19,-392,-384, 190, -72,-307, -9,-447, 83,-237, 304,-195, -46], [-501,-438,-111, -21, 102,-214, 199, 368, 286,-472, -20,-405,-265, 498,-367, -2], [ 120, 207, 61,-502,-178, 18,-423,-153,-479,-432,-106,-377, 69, 194, 307,-308], [-341,-405, 139, 211,-480, 446,-459, 42, 214, 379, 219, 308,-165, 322,-430, 404], [ 48, 324, -49, 147, 27, 237,-429,-451,-259,-349, 380,-288, 487,-168,-326, 296], [ 162, -2, 56, 224,-279, 508, 486, 153,-308, 184,-439,-481,-249, -39, 377, 232], [ 248, -77,-158,-133, 499,-471, 375, 80, -63, 230, -14, 382, 410, -81,-229, 94], [ 422,-297, 125, 134, 238,-378, 221, 418,-329,-269, 482,-327, 362, -8,-259, 379], [ -57, 15,-145, 95,-345,-112, 480,-248, 160,-180, 280,-378, 481, -48,-271,-437], [-339, 20,-167, 336, -71,-258, 119, 211,-341,-341,-475, 242, 167, -26, 352, 313], [ 87, 377,-302,-398,-236,-454, 31, 447,-472,-387, -49, 444,-189, 7,-470,-361], [ 498, 476,-507, 462, 142, 376, -47, 15, -12, 170,-369,-482,-197, 209,-306, 177], [ 481,-416, 176, -58, 376,-331, 197, 346, 455, 187, -3, 120, 377, 72,-481, 441], [ 194, 180,-292, 162,-109, 154,-403, 161, 511,-463, 488, -96, 379, 289, 68, 244], [ 387, -99,-178, 171, 315, 268, 304, -66, 325,-389, 45,-507,-180,-137,-107, 200], [-115, -53,-269,-130,-280,-438, 105, 172, 122, -38,-124, 372, 19, -22,-486,-163], [-123,-104, 82, 34, 110, 271, 320, 223, 466,-494,-312,-505, 151, 407,-263, 437], [-451, 444,-152,-409, -15,-250,-221,-198, 310, 40,-194, 112, 221,-233, -89,-388], [-327, 185,-327, 25, 214,-403, 68,-250, 474, -17, 313, 51,-468, 136, 462, 104], [ 326, 393,-279,-295, 113, -92, 348, 409,-151,-270, 287,-231, 330, -79, 171,-415], [ 126, -50, 88,-340, 242, 371,-291,-414,-488, 145, 109, 47,-275,-112, 96, -4], [ 499,-373, 199, -98, -74, 222, 197, 503,-381,-406, 229, 80,-232,-431,-425, 403], [-316,-181,-280,-149,-441, 19,-443, 307,-273, 40, 389, 154, 33,-180,-172, 173], [ 505, 165, 59, 236, -36,-451, 63, 468,-333, 194,-307, 36,-414, -51, 262,-157], [ 168, 302, 437,-272,-104,-356, 504, 437, 40, 350, 21, 126,-421, 261,-382, 333], [ 288, 213,-475,-202,-243,-144,-423, 447, 55,-200,-106, -55, 103, 16, 429, -4], [ 503, 359,-299, 440,-393, 325,-123, 387, 376, 313, 296,-201,-430,-100,-335, 199], [-158, 487, 144, 330,-377, 370, 432, -14, 108, 271,-333, 2,-104,-363,-136,-443], [-486,-374, 474, 50, 477, -70,-193, 6, -62,-404, 144,-291, 122, 153,-357,-450], [ 287, -42,-453, 506,-453, 199, 495,-268,-367,-388,-202,-409, 196,-449, 9, 508], [ 321, 117,-199, 126, 27, -76,-379, 395, -52,-313,-136, -88, 335, 239, 275,-501], [ -86, -20,-493,-246, 266,-372, 36,-292,-500,-266, 487, 308, 470, -13,-400, 49], [ -47, 352,-412, -13,-359,-180, 243, -25,-128,-109, -42, 291, 401, 466, 293,-190], [ 192, -64,-252, 349,-473, 411, -40, 140, 163, 404, 139, 116,-444, 18,-359, 243], [ 12, 184,-470,-426, 221,-439,-440,-500, 467, 243,-151,-209,-154, 281, 165,-323], [-334,-412, 164, 270,-241,-491,-428, 479,-210, 275, 127,-121,-302,-388, 117, 281], [ 147, 31,-470, 479, 305,-213, 491, 104, 84, 254, 319, 160,-381,-166, 438,-282], [-131, -70, -63, 115, 453,-266,-388,-310, 396, 149,-220, 323, 370, 354, 428,-254], [ 261, -41, 350, 233, 283, 159,-331, 46, 496, 447,-468,-344,-378, 231, 325,-294], [ 5, 348, 238, 43, 92, 8,-208, 66, 193, 382, 139, 267,-349, -40,-503,-260], [ 231, 503,-411,-101, 307,-304, 56, 238, 118,-320,-149, 290, 55,-507, 267,-476], [ 251,-305, 469,-136,-178,-360,-200, 385, 508,-135, -53, 227, 395, 95,-112, -90], [ 200,-509, 122,-148, 301,-417, 90, -20, 145,-446, 81, 62, 62, 105, 180, 312], [-236, 332, -2,-434,-453,-170, 291, 212, 295, 17, -62,-362,-176, -68,-422,-287], [ 100, 241, 510, 443, 145, -81, 139, 292,-391, -93, 347,-119, 73, 89,-324,-142], [-170,-486,-488, 339,-233, 18,-207, 451,-247, -73, 381, 350,-322, 309, -43, -18], [-376,-430, 233, -4, -65, 235, 271,-350, 112,-374, 257, 160, 467,-442,-454,-224], [-245,-260, 416,-257,-234, 265, -52, 283,-446, -13,-478,-448, 416,-370, 33, -92], [-157, 409,-490, 167, 474, 61, 447,-459, -84,-246, 236, 492,-250, 157,-310, 66], [ -37, 483, 111,-155,-396,-358,-282,-256, 359, 62, 23,-395, 368, 228,-443, 212], [ 44,-429, -43, -16,-343, 456, 358, 173, -39, -91, 154, 46,-449, 12, 313, -42], [-459, 293,-306,-248,-344,-174, 262, 19,-303, 386, 388, 379,-268, -50, 496, 278], [-485,-446, -37, 419, 39, -3,-404, 160, 329,-123, 282, 475,-304, 23,-218, 299], [ 79, 137, 305,-107, 425, 33,-351, 200, 300,-188, 365, 415,-229, 495,-368,-306], [-324, 403, 157,-357, -62, 118,-427, 391, 310, 5, 478, -85, 495, 171, 137,-343], [ 391, -75,-346,-500, 61, 28, 224, 399,-431, 237,-321, 366, 326, 41, 215,-191], [ -30, 329, -42,-146, -6, 336,-169,-335, 217, 333,-409,-267,-367,-156, -51, 254], [ 154, 123,-152, 349, -30, 490, 137,-383, 180,-180, 190,-441,-333, 364,-280, 345], [-227, 146, 198, 12,-200,-295,-479,-201, 156, 448, 380, 272, 295, 168,-246, 416], [ 174, 61,-399, -55, -41, 373, 47,-123, 488,-399, -80,-469, 245, 428,-226, 366], [-213, 420, 260, 312,-494, 473, 232,-200, 337,-224, 381,-397, 208, 41,-414,-265], [-500, -32,-204, 100,-208,-205, 249,-463, 412, 360, 171, 95, 401,-323,-432,-267], [ 301,-477, 84, 507, 364, 21,-447, 339, 101,-395,-416, 419, 173, 337, 388, 73], [ 17, -72,-188, -67, 280, 104, 401, -58, 109, 134, 93, 207,-269, 12,-406,-119], [ -13, 155, 461, 103, 249, 6, 137,-440,-252,-142, -29,-466,-369,-229, 482,-173], [ -19,-312, 113,-225,-301, 16,-507,-505,-288,-475,-402,-166, 309, 73, 12,-212], [ 442,-106,-423, 119,-396,-159, 7, 383, -7, 207, 504,-378,-231,-108, -81, -92], [ 417, 219, 110,-196, 331, 465, 328,-511, 139,-460,-249,-452, 106, 191,-395,-119], [ -45,-135,-389, -83, 257,-440,-430,-149, 452, 172, 182,-142, 95,-502, 139, 423], [ 115, 382, 229,-389, 412,-444, 34,-367,-501, -80,-210, -15, 79,-468,-387, 60], [-161, 234, 155, 353, 197, -72, 177,-231,-199, 295, -55, 305, 330, 366, 426, -71], [-186, 84,-132, 103, 210, 192,-129,-342, -72,-366, 399,-158,-354,-486, 149, 140], [-164,-439, -93,-194, 181, 108,-139,-289, 499, -48, 192,-369, -15,-484, 5, 475], [-119,-473,-481,-115,-349,-489, 262, -43,-216, 409,-394, 466,-191, 397, 105, 334], [ 495,-217, 472,-114,-118,-164, 42,-355, 55, 42, 268, 341, -61,-203,-247,-313], [-453,-162,-236, 477, 59,-157, 82,-370, -58, 129, -12,-101, 505, 389, 126, 71], [ 123,-306,-108,-472, -26, 44,-279, 475, 419, 227, 34, 378,-379, 297,-385, 301], [-230, 386, 454,-360, -39, 492, -17, 372, 90,-128,-220,-304, 268,-117, 11, -8], [ 79, 374, 492, -95, 335, 270, 75, 466,-307,-401, 362, -63, 355, 402,-449, 392], [ -53, 10, 129, 436,-493, -24, 192, 228, 197,-375,-206,-145, 311,-227,-297, 468], [-503, 509, 181, 336,-211,-498, 243, 342, 246,-366, 259, 275, 162, 272, 354, 116], [-422, -13,-433, -95, -96,-445,-155,-399, 315, 458,-438, 466, 23,-206,-434, 0], [ 301, 212,-461,-438,-100,-210,-275,-225, 310, 439, -98, 415,-183, -25,-281, 143], [ 490, 105,-146, 151,-387, 397, 3, -52, 87, 127,-439, 187,-265, 219, 330, 311], [ 53, 20,-366, 281,-235, -4,-221,-375, 132,-457, 254,-187,-512, 11,-465,-230], [ 211,-448, 347,-509,-260, 246,-189,-408,-144,-236, 350,-192, 295, 401, -68, 419], [-126, 475,-421, 191, -7,-116, 135, 208,-508,-342, 218, 170, 477, 267, 461, 207], [-207,-405, 288, 147,-463,-144, 467, 0, -69, -44,-299,-135,-134,-459, 273, -86], [ 329, 358,-295, 161, -29, 389,-292, 182, 110,-210,-373, 155, 244,-189, 148,-108], [ 218,-309, 399,-218,-136,-453,-398, 16,-238, 343,-497,-124,-167,-493,-385, -89], [ -8, -99, 31, 97,-502, -37, 474, 19, 181,-193, 280, 279, 21, 487,-384,-495], [ 276, 314,-389,-241,-495,-212, 279, 18,-156,-132,-511,-206, 149, 485, 355,-488], [ 408, 289, 287, -44,-105,-202,-445,-279,-260, -17, 253, -27,-453, 468, 453, 292], [ 503, 45, 473,-435,-138,-282,-312,-368, 125, 288, 80,-362, 318, 139,-115, 178], [-246,-159, 427,-215, -31, 399, 212,-449,-362,-504, 134, -54,-375, 468, 30,-265], [ 0, 183,-434,-231, 314, -42, 47, -69,-468,-343, -56,-298,-461, 351, 492, 300], [ 362,-265, 471,-311, 462, 506, 216, 492, 71,-247, -65, 95,-438, 125, 492,-318], [ 299, 417, 454, 471, 21, 488, 263,-347, -24, 223,-259, 143, 170,-346, 66, 278], [ -2,-500,-503,-147, 436,-278, 137,-285,-183, 356, 234,-415, -74,-483, -20, 166], [-391,-217,-105, 429, 505,-467, 267,-132,-111, 260, 428, 461, 78,-147, 294,-255], [ 65,-145, 160,-266,-316, 428,-408, 6,-286,-473,-476,-333, 375,-223, 461, 83], [ -65, 82, 17, 264,-223,-151, 403, 457, 401, -83, 287, -25, -3,-303, 93,-322], [-173, 363,-300,-440,-442, 451, 7, -93, 318, 343,-172, 198, 277, 158,-357, 384], [ 40,-223, -77,-474,-382, 271,-512, -86, 23,-457, 484,-281,-201,-201,-277,-511], [ 234, 478,-283, 166, 247, 356, -80,-202,-179, 217, 324,-327,-133, 411, 314, 496], [ 260,-110, 92, 164,-432, 45, 214,-341, 287, 85, 463,-469,-241, 103,-209, 219], [ 265,-408, 14, 9,-134, 443, 335, 201, 219, -40, 431, 199, 234, 370,-232, 314], [-313,-159,-169, 490, 365, 205, 232, 63, 457, -4,-123,-346, 293, 240,-119,-487], [ 347,-501, 208, 481, -64,-272, 209, 324, 47, 478,-460, 4, 223, 371,-329, 307], [ 53,-106,-378, 374,-351,-195,-215, 380, 176, 303,-256, 127, 73, 340, 415,-500], [ 178,-459, 50,-218,-198,-151, 124,-170, 238, -98,-443, 290,-220, -69, 189,-172], [-455,-130, 455, 145, 175, 135,-309, -84, 256,-409,-228,-230, -70, 491,-443, 19], [-329, 481,-396, -99, 243, 209, -80,-158,-105,-242,-302, -18,-238,-218, 160, 479], [ 106,-434,-435, 462,-208,-418, 101, 126, 152,-239,-497, 476,-256, 180, 211, 112], [-192,-235, 100, 374, 457,-404,-354, 455, 242, 392,-305, 89, 205, 184, -95,-497], [ 84,-253, -51, 468,-104, 347,-319, 176, 488,-408,-504, -69,-418, 254, 424, -68], [-248, -68, 228,-503, 91, 116, 140,-265, 219,-419,-308, 386, 244,-498,-258,-293], [-235,-259,-448, -43, 238, 109, 177,-429, 462, 346, 312, 330, 443, 45,-307, 119], [ 248, 243, 21,-442,-132, 430, 86, 39,-237,-135, 404, 170, 294, -47, 133,-258], [ 210, -75, -59, 152, 446,-447, 332,-213, -58,-490,-204, 2,-455, -10, 437,-405], [ 270, -93, 158,-246,-349,-348,-440,-322, 168, 390, 321, 189,-399,-216,-195,-257], [ 15, 36,-147,-150, 336, 296,-197, 423, 463,-178,-150, 5, 451, 385,-407,-110], [ 54, 3,-314, 367, 181, 346, 367, 254, -63, 113,-348, 177,-329, 198,-277,-392], [-343,-510, 223, 237, 15,-347,-427,-493,-343, 400,-265,-150,-405,-285, 19, 110], [-261,-453,-112,-273,-288, 470, 119, 58, -87, -73, 41, 201, 206,-337, 0, -91], [ 379, 134, 33,-394, 108,-392,-167,-366, 196,-301,-111, 405,-303, 7, -83,-494], [ 299,-442, -27, 62, 131, 193,-253,-502, 228, 36, 344, 329, 351, -16,-171, 298], [ -50,-325, 363, 391, -35,-435,-115, 310, 411,-304,-444, 386,-114, 42, 479,-444], [ 151,-437,-128, 311, -69, 509, 60,-184,-287,-154,-131,-442,-134, -37, 228, 160], [ 213,-504,-290, 165, -17,-507, 311, 279, 49,-444, 272, 85, 288, 257, 310, 18], [-369, 175, 123, 248,-339,-313, 399, 255, 418, 264, 99, 157, 398, 80, 135,-352], [ -27, 221,-235,-305,-191,-265,-292, -77, 417, 7,-320,-434, 200,-121, 329, 163], [ 303,-234, 196,-242, 449, 139,-180,-237,-317, 199,-289, 97,-242, 165, 322, 284], [ 267,-320,-422, 203,-135, -70,-481,-247,-478, 388,-263, 58,-473, 170,-182, 407], [ 397,-179, 410, 508, 333, 353,-258, 78,-444,-415, 510,-178, 254, 314, 366, 509], [-265,-471, -91,-379,-490,-143, 290, 67,-192, 158,-275,-498, 270, 126, 268,-473], [ 345, 122, 64, 127, 373, 89, 82, 502, 262, -60, 212,-114,-278, 99, 438, 439], [-162, 28,-296, 507, 492, 153, 311, 220, 95,-458, -47, 178, 181,-130, 452,-341], [ 0, 195, 201, 152,-231,-353, 139, 101,-329, 210, -46, 171, 345,-339,-493, 285], [ 112, 204, 346, 310, 471, 36, -12,-101,-355, 74,-229, 431, 85, 95,-149,-459], [-480, -79,-426, 109, 390, 392, 162,-296, 371, 395,-311, 243,-219, 309, 509,-482], [ 406, 125, 484, -36, 355,-449,-169,-444, 486, 324, 361, 448,-425,-118,-440,-297], [-278, -32,-237,-409,-341,-362, 484, 265, 478, -62,-227, 305,-178,-206,-274,-380], [-250,-149, 178,-448,-297, 316,-362,-162, 373,-354,-428, -16,-203, 64, 311,-372], [ 82, 5,-365, 126,-232, -13,-428, -42,-199, 330,-454, -84, -43, 230, 76, 171], [ 283, 370,-191, 38, 348, 501, 398,-132,-313, -11, 247, -8, -18, 346,-142, 368], [ -96,-176, -48, 268,-383,-311, 462,-333, 69, 81, -11, 148,-277, 53,-131, 165], [-368, 72,-323,-227,-289,-325, 333,-220, 437, 481, 72,-366,-129, 304,-136,-423], [ 58, 353, 303,-333, 176,-287,-289, 383,-257,-243,-512, 379, 299, 130, 256,-357], [ -43,-153,-416, -15, 430,-471,-214,-300,-269, 418, -33, -35, 266,-354, -14, -72], [ 99, 511, 275,-105, 335,-338,-481,-303,-164, 10, 117, 420, 10, 1,-461,-477], [ 52, -64, 347,-348,-487, -53,-269,-462, 229,-398, 110,-225,-335,-124, 308,-111], [ 256,-384, 279,-270, 181, 67, 439,-116,-445,-493, 334, 25, 281,-272,-159,-482], [ 472, 171, 443,-241, 114, 182,-187, 356, 457, 394, 244,-228,-224, 474,-502, 221], [ 211, 125, 501,-193,-164,-432, -59,-245,-161, 342, 445,-322,-131, 438,-449,-418], [-346, 97,-358, 479, -55, 1,-260, -30, 165, 257, 259, 79, 414, 325, 263,-456], [-505,-295, 167, -91,-100, 393, 405, 418,-191, 195,-234,-317,-323,-162, -72, 338], [-390, 240, 32,-218, -8,-205, 98, -68,-344,-393, 47, 412,-160, 238, 162, 441], [ 328, 68, 160, 407,-103,-178,-501, 334, 308,-406, 78, -37,-391, 492,-293,-444], [ 97, 244,-479, 162, 33,-407,-336, 69,-209, 448, 326, 495,-247, 480, -71,-157], [-461,-458, 196, -44,-281, 116,-254, 79,-145, 331, 328, -24,-153,-141, 313,-176], [-298,-426, -35, -19, 349,-286,-122, 315, 331,-119, -42,-202, 442,-391, 444, 188], [ 32,-479, -25, -95,-347, 160, 482, 63, 219,-442, -85,-393, 115, 449, 165,-434], [-149, 51,-100, 341, 322, 114,-130,-251,-404,-149, -89, 180, 161,-441,-108,-326], [-352, 335,-470, -83,-340, 388, 58,-276, 2, 237, 469,-287, 395, 444, 426, 138], [ 132,-100, 258, 32, 181, -74, 237, 332,-363, 340, 41, 352, -71,-124, 425,-255], [ 352, -17, 14,-197, 74,-179,-472,-234,-506, 489, 476,-108, 233,-158, 175, 312], [ 457,-103, 290,-240, 502,-486, 106, 163, 192,-389, 449,-327, 125,-284,-198, 47], [ -85,-348,-337, -84, 263, 407,-426,-110,-410,-496, 165, 104,-346,-273,-488, 342], [ 486,-374,-275, 377, 436, -83,-461,-472, 75,-110,-483, 85,-501, 294,-199,-471], [ 90,-105, 485, 45,-231, 214,-234, 413,-129, 51,-461, -76, 340, 312,-283,-281], [ 324, 440,-415, -52,-167, 379,-427,-296, 258,-460, -8, -60,-170,-108, 30,-347], [ 73, 312, 266,-355,-360,-238,-143, -94, 184,-454,-477,-111, 201,-314, 144,-246], [ 395, 405,-208,-277, -91,-266, 176, 333, 177, 332,-106,-352, 243,-143, 175,-235], [-429, 504,-353, 500, 488, 300, 163, 79, 374,-216, -34, 122, -91, -75,-174, 65], [ 358,-306, 444, 193, 331, 57, 286,-496, 326,-471, 399, 503,-211,-297, 271,-253], [ 374,-407,-384, 490, 178, 355,-180, 180, 96, 105, 186, 77, -73,-230, 275,-281], [ 196,-274, 128, 253,-289,-451,-378, 108, 357,-466, 239,-163, -22, 439,-173, -36]]

B (256, 16):

[[-498,-429,-248,-484, 134, -76, 49,-334,-209, 167, 476,-461, 399, 78, 65, 0], [-441,-420, 103,-163, 427, -96,-366, 219,-212, 26, 202, 409, 299, 180, 183, 456], [-210,-511,-234,-289, 165, 136, 95,-496, 234,-181, 169, 57,-162,-375,-416, 339], [ 428, 153,-407,-101, 234, 286,-391,-512, 217,-147,-252,-499, 41, 359, 468, 67], [ 14,-425, 50,-123, 109,-114,-266,-415,-190,-414,-331, 499, -58, 32, 382, 507], [ 84, 319,-178,-199,-100, 176, 186,-190,-376, 135,-381, 80, 198, 205, 259, 381], [ -1, 235, 122,-321,-486,-221, -59, 119, 358,-312,-384, 474,-402, -23, 87, 42], [-424,-454,-404, 87, 45,-273, 141, 327,-470, -2, 193,-254,-197, 116, 407, 317], [ 85, 235,-139, 144, -35,-318, 206, 57,-145, 421,-491,-189,-454, 272, 206,-173], [ 179,-107, 262, -47, -90, 445,-256,-389, 86, 480,-126,-449,-165, 6,-347, 161], [ 509, -50,-149,-102,-395, 392, -88,-116, 163, -60, 151,-450, 321, 451, 152, 465], [-357, -24, 104, 83,-101,-166,-383,-111,-346, 239,-299,-453, 53, 97, 380, 78], [-159, 310, 41,-431, 67, 417,-107,-209,-366,-357, -69, 97,-430, 450, 261, 88], [ 336,-430, -24, 133, 336, 290,-229, 451,-385, 384, 482,-331, 227,-471, -97, 16], [ 82, 446, 176, -20, 317, 461,-490, 494,-424, 321,-225,-377, -62, 147,-122,-457], [ 101, 412,-120,-291, -59,-463, 328, 334, 90,-151, 306, 55, 333, 134, 291, 100], [ -88, 468, 42, 107,-287, 128, 73,-323,-451, 106, 270, 23,-280, 170,-430, -60], [-345,-324,-305,-117,-460,-105, 11, -18,-121, 347,-364, 5,-449,-440, 75, 67], [ 387, 59, 470,-463,-412,-467,-323, 42, 149,-466, 456, 350,-209,-433,-339,-383], [-386, 19,-261,-146, 501, 188, 459,-367,-121, 56,-434,-508, 174, 145, -92, -11], [ -87,-488,-169,-331,-412, 467, 101, 234,-190,-110,-270,-413,-329, 304, 181, 48], [ -26, 432,-438,-225,-154, 289, 504,-266, 383, 338,-282,-104, -93, 489,-327, 306], [-170, 236, -82, 80, 340, 311, 375,-451, 196,-369, -87, 49,-100, 20, 508,-374], [ 179,-107,-376,-350, 460, 388, 416, 503,-299,-149, 173, -17, -84,-146, 96, 77], [-347, -29, 54, 71,-297, 248,-487,-149, 286, 65,-245, 199, 69, 303, 240, 112], [ -13,-376,-245, -83, 101, 14,-217,-506, -4,-220, 240,-488, 86, 452,-334, -30], [-419, 128, 51, -95, 21, 406,-311,-489, 370, 78, 400, 99, 317, -73, 255, 422], [ 73,-327,-237,-309,-260,-199, 56, 90, -76, 118,-429,-423,-337, 18,-293,-222], [-103, 319,-498, 152, 172, 305, 443,-492,-355, 395, -43, 66, 166, 183, 442, 508], [ 225,-218, 388,-462,-276, 406,-250,-287,-371, 367, 0, 179,-268, 264, 266,-192], [ -92,-298, 487, 149, 444,-202, 288, 272, 196, 476,-109,-379, 175, 234, 76,-301], [ 4,-193, -75, 148, 251,-275, -97,-237,-309, 290, 419,-133, 257, 406, 354,-325], [ 467,-127,-165,-449, -15,-401,-258,-188, 316, 384,-203, 367, 365, 271,-362, 194], [ 455, 186,-173, 0, 149, 10,-390,-193, 309, 370,-372, 463,-176, 166, 257, 319], [ 456,-192, 367,-378, 209, 247, 181,-254, 381,-340,-458, 222, -26, 357,-120,-340], [ 344, 50,-319, 225, 11, 106, -41, 336, 337, 214,-405, 346, 175, 201,-141, 388], [ 230,-397, -95, 395,-464, 472, 183, 134,-235,-258, 452,-207, 282,-110,-370,-502], [ 45, 487,-135,-147,-160, 21, -61, 389, 5, 7,-371, 494,-257,-437, 167, 97], [ -87, -80, 291,-312, 327, 152, -83, -43,-250, 258, 13,-184, 98, 507, -67, 430], [-159,-456,-303, -84,-288,-512, 424, 352, 248,-341,-389,-443, 229, 439, -72,-390], [ 12,-155,-129, 124, 223,-399,-476, 506,-274,-457,-318,-473,-111, 309,-163, -58], [ 179, 9, 370, 374,-502, 284, -41, 500, -18, 498, 260,-258, 39, 503, 366,-413], [ 211,-159,-505, -99,-272, 326,-167, 335,-512,-197,-266,-273,-443,-321, 56,-214], [ -85,-127, 384, 415, -8,-174,-403, 464,-451,-208,-207,-184,-344, 289,-387, 138], [-386,-440, 419,-318, 328, 45,-433, 466,-260, 368,-340, 362,-499, 12, 275, 445], [ 419, 327, 397,-308,-221,-217,-126,-110, 45,-349, 195,-341,-195, 3, 303, 245], [ 149,-353, 48,-423,-126, -89,-472,-232, 466, 464,-152,-468,-329,-111, 458,-368], [ 269,-401, 492,-122, 281,-162, 130,-316,-363, 448, 427, 396, 128, 315,-442,-170], [-191, 138,-148,-360, 98, 321,-121,-377,-311,-269,-205, 146, 103, 200,-141, 331], [-304, -32, 308,-328,-400, 392,-161, 188,-487, 194,-189,-455, 112,-266,-116,-430], [-362,-207,-421, 420,-506, -17,-386,-197, 436,-347, 477,-302, 247, 47, 393, 55], [ 35,-312,-342, 426,-177,-131, 266,-166, 462, 243, 99, 390,-462,-249, -36,-280], [ 249, 429, -79,-162, 472, -57, -12,-152, 419, 70, 268, 319,-162, -68, 356,-141], [ 300, 451, 126, 247, 312, 353,-108,-460,-101, 177, -51, 254,-147, 137,-322, 255], [ 46,-304,-214, 254, -18,-291, 478, 220, 468, -75, -26, 407, 25, 212,-254, -55], [-386,-302,-512,-472, 488,-264, 167, 347, 51,-356, 233, 102, 236, 276, 486, 75], [-163, 152,-442, 406,-390,-177, 323, 99,-109, -28, 363,-164, 378,-422, 283, 355], [-326, -72,-343, 211, 36, 138,-311,-296,-470,-183, 61, 366, 170, -67, 463, 224], [ 440, 28,-247,-458, 231,-388,-202, 33, 65, 102,-342,-124, 120, 481, 233, 432], [ 268, 93,-316, 170, 126, 104, -11, 29,-170, 19,-310, 312,-322,-425, -66, 162], [ -64,-229, 59,-157, 443, 432, 2,-177, 242,-475, -26,-168, 430,-500, 54, 246], [ -16,-425, 483, 18, 116,-270, -17, -73,-436,-404, 345,-267,-313, 5, 275,-449], [ 78,-390,-475,-458, 342,-392,-466, -64, 352,-244, -81,-472, -53, 79, 72,-172], [-189,-403,-137,-411, 272, 477, 481, 373, 103, 205,-220, 133, -46, -19, 263,-224], [-187, 434,-455, -15, 422, 113, 47,-257,-161, 360, 60, 15,-411,-496, 474,-126], [ 105,-431, 187, 442, 77,-383, 83, 272, -96, 388, 152, 408, 126,-378,-195,-306], [ 418, 266, 180,-204,-324, 262, -27,-281, 119,-471,-179, -33,-361, 496,-298,-379], [-304, 275, -77, 66,-491,-477, -56, 324, 394,-424, 39, 423,-115, 337,-376, 445], [ 257, 451, 180,-140, 448,-230,-172, 205, 271, 439,-303, 305, 244,-447,-116,-223], [-201, 494, 146, 222, 488,-126, 309, -68, 378,-328, 458,-288,-178, 262,-109, 110], [ -57, 248,-279,-453,-205, -27,-340,-149,-103,-454, 85, 393,-357, 100, 168, -83], [ 205, -92, 4,-505, 196, 165,-473,-135, 490, -82, 1, 419, 222, 84, 304, 373], [ -45, -26,-117, 477, 201,-427, 371, -20,-442, 50, -85, 386,-304, 334, 59,-457], [ 483, 12,-215, -32, 366,-200,-315,-380,-207, 286, -30,-280,-342,-172, 450,-161], [ 499, -16,-329, 400, -41, 214, 495,-461,-413, 225,-224,-324,-472,-490, 281,-375], [ -34, 108, -74,-485, 290,-502, 268, 402, -69, 36, -24,-114, 396, 403,-169, 117], [ 437, 473, 9, -49,-227, 469,-366, 81,-223,-227, -98, 510,-456, 80,-428,-354], [ -62, 10,-247,-188,-423,-202, 477, 455,-170, 72, 419,-506, 318, 459,-419,-347], [ 471, 38,-498,-249, -52, 197, 238, 507,-218, 39, 34, -97,-339, 488, 361, -2], [ 105,-280, 44, 199, 15, 502, 114,-133, 278,-338,-119,-157, -70, 288, -17, 301], [ 78,-162, 317,-268,-283, 4,-245,-503, 151, 11, -56, 478, 72, 372,-370, 70], [ 376, 85, 223,-132,-418, -44,-109, 375,-263, 477, 469,-259,-156, 405, 477, -58], [-184, 26, 192,-232, 242,-460,-462,-117,-151,-189, -10,-184,-316,-196, 486, -92], [ -57, 78, 494,-265, 185, 221, 109,-422, 181,-447, 98, 245,-296, 349,-481, 352], [ -41,-290,-376, 464,-438,-309,-156, 123, 45,-384,-216,-268,-294, -91, 208,-290], [-137,-112, 487, 465, 307,-265,-443,-188,-239, 6, 284, 366, 353,-144, 191,-192], [-450, 206,-502, -93,-175, 198, 272,-201, 319,-212, -55, 232, 197, 499,-282, 166], [ 112, 425,-352, 257, 69,-231, -27,-171, 81, 398, 70, 134, 19,-460,-274, -9], [-195,-326, 4,-182,-248, -37,-376, 438, 376, 212,-404, 282, 315, 274,-396, 147], [ 342, 79, 149, -43, 29,-477, 142,-429, -67,-213, 46,-376, 196, 302,-345,-406], [-363, 386, 28, -34,-403, 153, 376, 336, 129,-435,-397,-462,-249,-374,-246,-118], [ 453, 113, 343, 215,-397, 241,-231, 142,-163, 509,-243,-227, 441,-487, 201, 230], [ 344, 485, 487,-446, 329, 149, 150,-381, 153, 494, 421, -63,-472,-142, 334, 206], [ -42,-456, -75, -32, 438, 144,-193, 25,-445, 483,-144, -23,-149, 186, 166, 220], [-238,-189,-384, 159,-472, 100, 378, 400, -53, -42,-434, 174, 328,-262, -81, 346], [ 386,-263, 51,-315,-408, 420, 328, 266,-463, 351, -64,-162, 47,-419, 262, 84], [-321,-320,-324,-454, 89, 348,-495,-462, 74, 327,-178,-154, 98,-232,-485, 240], [ 128, 82, 247, 179,-302,-152,-383,-380, 180, 367, 473, 131,-324,-404, 320, 80], [ 121, 288, 208, 342,-455, 253, 359,-219, 143,-191, 468,-478, 81,-342, 217,-332], [-271, -6, 424,-296,-365, 265, 0, 421,-362, 149,-274,-352, 187, 95, 260,-196], [ -54, -97, 495,-213,-211,-149, 66,-254, 425,-240, 405,-407, 160, 416,-340, 479], [ -49, 456, 181,-204,-320,-201,-417,-365,-405, -79, 302,-368,-379, 146,-311,-413], [-342, 433, 329,-150, 159, 38, 181, 187, 131,-240,-473, -46, 400, 71, 340, 503], [-345, 196, 178, 491, 497, 191,-263, 305,-403, 287, 420,-120, 133, -72, -64,-195], [ 268, 446, 451,-334, 383, 243,-254,-444,-238, 422, 136, 226,-249, 224,-484,-128], [ 129,-363, 330,-272, 155, -98, 98,-402,-495, 419,-236, 327, 511,-296,-241, 166], [ 476, 425, 2, 302,-373, 488, 475,-345,-206,-410,-234, 323,-125,-422,-162, 492], [ 132, -86,-342, 497, 328,-224,-441,-455,-389, 82, 439, -4, 351, -56, 213, 237], [-334,-143, 140,-440,-142, 35, 508, -27, 323, -70, 303, 97, 395, -92, 106, 133], [ -85,-365,-417,-495, 382,-270,-296, 241,-185, 6,-346, 470, 360, 372, -96, 268], [-365,-504,-492, 88, -46, 18,-505, -80, 223, -59, 237,-274, 320, 90,-297,-270], [ 131, 337, -87,-248, 375, 173, -54, -13,-303, 129,-145, 507, -21, -15, 67, 426], [ 308, -51, 223, 88, -8,-316, -37,-261, 424,-169, 463, 33, 134, 43,-380,-128], [-411, 125, -55, 284,-287,-344, -96, 436, 215, -84, 17,-426, 496, 170,-220, 87], [-400, 477,-334, 151,-261, 222, 283, 177, 117, 401,-432,-174,-258, 499,-114, 238], [ 189,-295,-268,-224, -92,-273,-492, 388, 476,-163,-166,-505, 184, 333,-362,-349], [ 297, 119,-467, 125,-196,-135, 276, 318,-103, 457, -96, 278, -17, 407, 417,-423], [ 446, 333, 298,-307, 312, 358,-216, 463,-461,-359, 38, 77, 148,-495, 471,-467], [-366,-498, 68, 442, 169, 330,-499, 43, -42, -2,-439, 188, 3, 271, -16,-360], [ 151,-336, 381, 115,-352, 473, 18,-438, 129,-253, 310, 325, 490, 1, -47, 259], [-377, 48, 47,-421, -84, 361, 364,-411,-420,-243, 383,-381, 225,-409, 126,-148], [ 295,-273, 142,-271, 218, 382,-383, 375, 95,-382, -75,-348, 205, 265,-404, 6], [ 322, 446, 13, 461, 36,-109, 356, -8, -29, -10, 355, 339, -99,-171, -9, 74], [-268, 301, -14,-170,-403,-268, 460,-200,-340, -41,-198,-476,-182, 45, 52,-147], [ -54, 476,-126,-248,-263, -44, 265,-302, 214,-491, -84, 282,-166, 65,-303, 247], [-459, 361,-310, 383,-152, 228,-186, 415,-383,-330, -8,-429,-312, 454, 487,-127], [ 433, 45,-236, 207, 162, 500,-241, 176,-459,-396,-508, 511, 309, 293, 9,-205], [-358,-221,-128, 262, 40,-433,-494,-408, -92, 443, 140, 309, -35,-142,-401, 384], [ 289,-340, 12, -13, 128, 456, 81, 41,-461,-448,-321,-479, 249, 228,-373, 344], [-354,-204,-258,-131,-252, -12, -95, 498,-455,-367,-458, 128,-457, 344, 12, 27], [ 63,-338,-310,-186, 95,-297,-393, 481,-490, 309, 294,-208,-374,-363, 202, 146], [ 289, 447, 196,-353,-263, 350,-298,-438, 208,-100, 430, 153,-420, 458,-248,-167], [-101,-460, -4,-386,-102,-153, 279, 310,-355,-137,-130,-357, 305, 212,-318,-137], [-404, 131,-388, 497, 287,-113, 80, 421, 55,-334,-125, 351, 147, 154, 375, 403], [ 429,-415, 45, 246, 263, 109,-342, 304, 225,-424, -38,-334,-167,-494,-103, 51], [ 122, 167, 344,-292,-389, 359,-352, 486, 350, 0, 492,-413,-202, 141,-154, 438], [-445, 50, 93, 156,-251,-139, 351,-313, 334, 64, 268, 218,-300, 70, 376, -70], [ 477, -49,-366,-114, 462,-185, 376, 390,-154,-427, 229,-194, 289, -59, -16, 284], [-121, -59,-127,-136, 26, 316,-142, 24, 174,-237,-228, 443, 228, 79, 151,-482], [ 120, 9, 46,-144,-429,-315, 461, -94, -35,-459,-474, 222, 39, 8,-264, 250], [-340,-318, -41,-219,-259, 148, 154, 332, -85,-438,-232, 491, 98, 214,-505, 18], [-474, 70, 430, 479, 41, -43, 455, 177,-446, -36,-266, -31, -46, 84,-147,-344], [ 3, 338, 167,-166, 445, 422,-298,-472, 247, 335, 479, 399, 102, 30,-484,-260], [ -42, 131, 58, 248,-226, 66,-422, -89, 256, 198, 502,-228, -2,-175, -61, 365], [ 188, 391,-304, 382,-451, 397,-176,-190, 12, 451,-464,-152, 365,-107,-309, -78], [-118, 425, 268, 5, 500, -36,-453,-244, -66,-352, 458, 273,-238, 92, 226, 451], [ 390, 15, 281, 63, 53,-395,-383, 30,-237,-491, 228,-479, 97, 40, 480, -17], [-447, 52, 349, 508, -72,-185, 416,-317, 118, -97,-470,-157,-241, 190, 459,-238], [ 318,-456, 39,-440, 444, 272, 161, 331, 151, 480, 219, 434, 17,-393, 28,-383], [ 94, -18, 125,-502,-313, -9, 461,-120, -78, 219, 106,-206, -92,-290, 477,-379], [-132,-486,-285, 287,-306,-431, -27,-502,-426, 315, 277, 425, 363, 187,-459, 289], [ 353, 306, 8,-274, 353, 232, 492,-353,-281,-296, 299,-321,-444, 510,-487, 343], [-138, 349, 55, 411, 436,-503,-435,-256, 173, 397, -42, 109,-319, 312, 478,-237], [ -6,-424, 60, 2,-365, -60,-170, 22, 87,-504, 267, 218,-137,-458, 261, 466], [-267,-181,-324, 78,-354,-148, 201, 61,-117, -82, 63,-506,-432, 390,-433, 211], [ 430,-235,-133, 70, 390, 452, 245,-424, 173, -92, -31,-462,-317, 297, -48,-204], [-119, 362, 254,-234,-392,-254, 430, 83, 34, 98,-138, 314, 23,-393,-380, 37], [ 447,-197, 378, 270,-259,-475,-408, 233,-308,-132, 1, 230,-397, -96, -16, 41], [ 326,-337, 315, 197, 57, 204, -91,-371, 169, 25, 142,-166, 416, 89,-425, -52], [ 262, 301, -6, 404,-238, -92, 408, 405, 190, 367,-422, 373,-184,-330,-267, -85], [-255,-184,-374,-209, 74, -60,-157, 252, 402, 262,-173, 250,-357,-379,-159, 315], [-260,-448,-378, 367, 136,-253, 56, 28, 159,-274, 373,-196, 198,-496,-131,-152], [ 44,-438, 297,-289, 181, 310, 63, 246, 165,-148, 316,-211, 72, 251,-124,-202], [ -42, 325, 440, 46, 165, 412,-412,-275, 213, 331, 365, -87,-421, -64,-276,-214], [ 278,-435, 335, -75, 98,-421,-167,-421, 472, 314, -42,-284, 443,-160,-348, 64], [ 454,-509,-269, 448,-337,-397, 71, 370, -24, 506, 183,-437, 504, -95,-218, 59], [-201,-424,-511, -52, 344, 74, 511,-219,-225,-349,-344,-220, 299, 415, 486,-275], [ 390,-176,-397, 378, 139,-344, -72,-218, 242, -48, 501,-456,-149, -19, 3,-189], [ 234, 383, 449, 312, 358, 51, 333,-202,-104,-188, -34,-220, 472,-192,-412, 27], [-454,-399,-288, -37, -69, 306, 245, -76,-171,-188, 280,-459,-499, 302, -24,-378], [-271, 442, 368, 214, -19, 20, 486, 476,-292, 318,-311,-294, 180, -98, 441,-421], [ 11, 428, 413,-352,-137, 121,-349, 479, 424,-342,-388,-425, 419,-314, -86, -53], [ 101,-439,-280, 441, 418, 288,-493,-178, 131,-231, 419, 137,-439, 418, 468,-433], [ 33,-202,-110,-329, 79, 468, 3,-428, 122,-164, 364, -67,-315,-317, 275,-241], [ 273,-302,-183, -36, 453, 442,-301,-146,-360, 10, -41, 410, 440,-120, -9, 405], [ 314,-509,-185, -81,-277,-308,-474, 146,-244,-459,-276, 309, 359, -18, -86, 489], [-307,-292,-214,-336,-124, 420, 118, -91, 444,-463,-297, 67, 118,-472,-100, 152], [ 202, 141,-184,-417, -75,-381, 458, -26,-188, 272, -3,-195, 319, 375, 177,-464], [ 67, 269,-373,-278, 391,-492, 258, -27, -55,-505, 327,-144, 41, 181, 207, 466], [ 32,-103, 464, 145,-207,-383, 350,-142, 164, -30,-309, 104,-450, -89, 47, -66], [ 254, 335, 277,-473,-314, 37, 445, 342, 350,-202, -73, -30,-351,-481, 457,-266], [-267,-427, 438, 81, 171, 421,-159, 124,-473,-321, 339, 273,-153,-127, 34,-512], [-265,-299,-256, 313,-226,-316, 4, 374,-265,-432,-148, 253, 51, 324, 470, 299], [ 106, -7,-471, 495,-120,-357, 170,-221, 87, 88, -56, 344,-241, -53, 38, 167], [ 290,-108, 149,-358, 443,-120, 235,-492,-302, -14, 387, 27, 440, -17, -10,-390], [ 309,-260, 409, 420, 453, 20, 181, 285,-378, 103,-477, -3,-354,-325,-139, -70], [ 126,-436, 3,-325, 75, 140, 58, 244,-169, 271, -69, -17, 151,-494, 157, 121], [-195,-425,-419, 433, 193,-382,-147, 94, 343,-468,-270, 399,-503,-306, 470, 116], [-245,-444,-484,-262, 390, -87, 225, 428, -95,-317, 17, 417, 311,-445, 197, 73], [ 417,-387, 34, 388, -93, -19,-440,-228,-180, 455,-223, -41, 175,-346, -14, 244], [ 375, 129, 173,-383, 456,-377, 281,-241, 443, 225, 259,-288, -59, 120, 276,-406], [ 473, 399,-236, 330, 18, -40,-191, 82, 235, -92, 132, 204, 216,-459, 368, -43], [-244,-265, -18, 396,-125, 255,-413, -25, 503, 276,-297, 1,-273, -93, 286, 277], [-279, 432, 94,-123, 1, 107, 61, -14, 5,-332, 320, 42,-378, 272, 442, 458], [-135,-374, 18,-397, 444,-325,-254, -96,-120, 301, -45,-338,-239, 9,-362, 114], [ 67, 219, 448, 422, 456,-262,-378,-203, 404, 483, 367,-400, 458, -79,-503, -59], [-465, 44,-166, -28, 115, 377, 165, -68, 327, 415,-390, 32,-221,-464, 172, 371], [-346, 319, 361, 424,-241, 413,-184, 53,-461,-468, 225, -57,-250,-318, 174,-512], [ 313,-431,-316,-117, -16,-149,-184, 475, 144,-489, -72, 384,-204,-416, 264, 108], [ 72,-458,-369, 125,-300, 4, 45,-222, 459, 350, 227,-433,-404, -8,-348, 489], [-350, -13,-140, 142,-380, -72,-231, 397,-471, 423, 340,-208, 296,-481, 478, 27], [-202,-141,-445, 501,-472, 158, -59, 459,-261, 32, -19, 207,-443,-314,-293, 243], [-319, 75,-292, 370, 452, 18,-152,-273,-462,-238, 157, 34, 454,-107, 198, -11], [ 12,-238, -47, -30, 211, 451,-175,-469, -4, 45,-340, 266, 496, 456,-311, 384], [ 209, -48, 41, 357, -21,-130, -7, 81,-319, 410, 178, 136,-411, 106,-389,-432], [ 27,-100, 90,-421, -71,-334, 498, 62, 191,-179,-415, 487,-219, -79, 153,-487], [ 317, 37,-228,-449,-346, 404, 190,-257,-445, 195, 74, -98,-140,-290, 173, 481], [-333, 99, -78, -55,-252, 332, -16, 44,-200,-326,-425, 219,-312, 194,-113, -87], [ -32,-136,-409,-195, 167, 169,-219, -41,-314,-297,-489, 406,-297,-280,-226,-382], [ 142,-436,-375, 148,-165, 212, 58,-250, 154,-393, 37, -65,-238, 106, 380, 510], [ 110, -98,-282,-249, -22,-136, 423,-135,-130,-120, 344, 154, 116,-170, 325,-473], [ 379, 13,-105, -3, 171,-499, 380, -55,-161,-371, -62, -4, -99, 182, -82, 472], [ 101, 314,-401,-106,-168, 71, 369,-432,-438, 358,-295, 172, 43, 340,-384,-380], [ 58, 457, -88,-178, 109, 440, 345, 507,-489,-397, 112, 328,-220,-268, 293,-455], [-134, 5, 61, 234,-149, 115, 87, 48, 143,-247,-426,-390,-283, 0, 348, 206], [ 295,-153, -98,-109,-316,-450, 93, 500,-342,-465, 286,-254, 337, 208, 456, -94], [ 165, -36, 133, -52,-319, 8, 29, 318, 241, 167,-396, 225, 0, 403, 429,-456], [ 328,-474,-137, 43,-361, 252,-504,-340, 82, 219, 426, 210, 175,-109,-511,-389], [ 35, 179, -85, 236, 22,-437,-316, 348, 230, 404,-392, 501,-298,-500, 509,-225], [ 172,-332, 82, 413,-185, 174,-320, 127,-168,-296,-192,-329, 411,-106,-261, -53], [-184, 250, 482, -64, 369, 67,-351, 195, 13, 154, 399, -61, 410, 256, -12, 105], [-179, 495, 171,-468,-178, 126,-455,-488, -52,-172, -64,-244,-344, 193, 14,-308], [-185, 94,-439,-362,-437, 319, 258, 259, 221, 173, -24, 145,-473, 124, 284, 0], [-146,-228, 146, 197, 379,-162, 276, 62, 392, 28, 18, 79, 255, 475,-437,-458], [ 448, 30, 117, -18,-417, 274, 253,-193,-199, 345,-438, 390,-250, 95, 446, 182], [ -88, 194,-160,-229, 508, 256, 148,-149,-462,-481, 55, 268, 38, 348,-478,-137], [-270, -54,-438, 465,-284, 432, -76, 497, 55, 441,-507, 254, 412,-369,-414, -78], [ 444, 43, 28,-368,-512, 317,-423, 137, 424,-299, 169,-432, 106,-345, 241,-204], [ -38, 101,-337, 247,-203, 166,-350, 192,-381, -77,-259, 254,-244, 390, 401,-311], [ 116,-423,-112, 218, 163, 127,-223,-125,-407, 224, 3, 213,-258,-180,-170,-486], [-163, 310, 406, 18, -46,-481, 388,-499, 455, -12,-162, 434,-488, 83, 50,-288], [ -73, 155, 232,-512, 447,-344,-273,-243,-474,-386, 498,-190,-394,-403, 224, 363], [-249,-491,-284,-455,-407, -71,-277, 16,-253, 451, 415, 68,-150,-122, -91, 233], [ -50, 365, 454,-168, 62,-415,-307, -89,-301, 385,-350, -46, 108, 196,-120, 377], [ 69, -62,-444, -37, 328, 117, 340, -7,-391,-499,-202, 202, 297,-210, -5, -81], [ -92,-276,-373,-311,-456,-310,-503, 130,-189, 484,-314,-158,-146,-504, 347,-480], [ 450, 401, 36, 44, 157,-116, 150,-467,-457, -44, 50, 397,-405, 330,-297,-109], [-188,-103,-358, 3, 308, -60, -10, 357, 211, -10,-249, 394, 78,-286,-237, 310], [-467, 503,-379, 303,-108, -8, 389, -90, 38,-462,-510,-262, 184,-388,-396, -92], [ 151, 217,-330,-431, 450,-246, 361, 372, 279,-340, 329, 275, 99,-167,-244,-388], [ 9, 87,-145, -26,-140, 144, 410,-345,-122,-368, 127, 234, 442,-227, 461,-448], [ 105,-454, 403, 30, 173, 339,-359,-473, 387,-190,-380, -33, 100,-481,-231,-479], [ -82, 404, 494, 140,-347, 415, 16,-355, 431, 263, 237, 214,-307,-296, 192,-288], [ -63, 288, 290, -48, 299, 346, 158,-279,-232,-190,-393,-233,-298, -46, 418,-406], [ 225, 191,-414, 432, 70,-140, 262,-249, 198,-472, 347, -54, 139,-286, 181, 278], [ -28, 120, -45, 403, -3, 350, 308, -92,-277, -97, 334,-279, 25, 313,-151, 145], [-261,-401, 301,-411,-235, 363,-158, 484, 491,-238,-471, 209, -51,-409, 212,-481], [ 379,-371,-382,-333, 471, 197, 308,-105,-168,-272, -20, 53, 134,-249, 459,-339], [ 476,-497, -20,-171, -53, 72, -66, -88, 238, 190, 341,-257, 112, 87,-134, -15], [-191,-367,-294,-404, 187, 164, 461, 235,-459, 393, 371, -59, 87, 487, 33, 415], [-427,-317, -61, 86, 323, 499,-114,-464, 308, 106,-309, -6, 248, 276, -1,-200], [ 485, 167, -94,-225, 236,-265,-337, 30,-216, 131,-392, 158,-222,-512,-383, 444], [ 376,-273, 285, 111, 482,-130, 185,-447,-107, 474, 39,-218,-389, 208, 148,-130], [ 461,-490,-201, 431,-184,-254, 35, 331,-407, 453, 302,-327, 217,-118,-101, 290], [ 473,-383, -82, -20,-127,-141,-459, 189, -66,-313, 323, 309, -14,-207, 141,-217], [-271, 236,-471,-415,-506,-356,-442, 507,-217,-360,-266, 446, 20,-139, 382,-108]]

C (16, 16):

[[-1246173, 2550833, 632651, 58800, 570833, -902753, 416371,-1839066, -463739, -443016, 1570754, 778342, 595195, 2445115, 1541783, 521101], [-1147477,-3002508, 1347880,-1536164, 765208, 471872,-2297850,-1875670, 1226589, 3254058,-2123893, 753017, 315272, 960143, -646381, -344059], [ -220878, 2375081, 212857, 2371532,-1867802, 1537085,-1003056,-1434010,-1774442, 1529931, 1078538, -501927, 167936, -731854, 589298,-1705763], [ 3662868, -979045, 555394, 290432, 298699,-1955562, -430738,-1118644,-2664615, 2010289, -442561, 1615983, -434542, -300787, 1838623, -141044], [ 1480499, -191257, 407760, 237480, 417606, 53913, -619205, 243137, 2318734, 699101, -97089, 483502, -97594, -908692, 599454,-2544676], [ 2834503, 1156794, 2393530,-1056564, 1111691, 1239870, 1147891,-2667423,-2186417, -48525, 2212983, -65763, -549541, 2157908, 1682820, -162234], [ -608212, -475851, 227734, 581955, 2607132, 992104, 459475,-1185017,-1173263, -471462,-3290331, 337865, 1419365, 1981786, -366746, 31435], [-1747090, 1602612, 825976,-1117571,-1574454, 740777, 846036, 903192,-1132524, -723488,-2149718,-1434600, -52125, 1239607, 585219, 1184759], [ 1646963,-1599551, 617810, 1006723, -498438,-2236381, 269981, 2874251,-2020662, -584277, 352218, 545686, -229304,-1063749,-2654920, 576137], [ 72199, 1044173,-1547067, -272566, -145313,-2228947, 1410010, 2827129, 1384668, 260001,-2608802,-1540940, -776658,-1161401, -291774, 1504722], [-1151613, 1601812, 3654631, -435989, -846197, -582598, -862435,-2077294, 61521, 1336190, 360656, 987722, 2316152, 134661,-1700666, 24986], [-2111745,-2909426, -814007,-1134592, 939460,-1878245,-2232976, 1854793, -900756, 1988707,-2673189, -449087, 1242909, 933862, 879102,-1551054], [ -791588,-1654714, -914504, 570576, -953098,-2791678,-1296574,-1623044, 3040448, 554541,-1686156, 153278, 1138717,-1233375, -759124, 491750], [ 1004907, 587178, -731248, -769961, 356070, -101750, 1019369, 437592, 739108, 1372844, 2097431, 993481,-1143686,-1142846,-1234118, 16999], [ -679937, -117190,-2980651, 323684, 422426, -110389, 1018187,-1079277, -371420, -435768, 104924, 482676, 615181, 7802, 1008215,-2816329], [ 1238421, 1486481, 1297436,-1248198, -466684,-2093671, 769245, -272756, 1292337, 2141008, 1262820,-2532444, -522767,-1557855, 2119722, 1758333]]

Explanation

前回の問題 Mmul TA 16_4_16 のレイアウトは以下の通りでした。

A: (( 4:2), (2:1, 4_PE:1, 2_W:1)) B: (( 4:2), (2:1, 4_PE:1, 2_W:1))

今回の問題では、\(A, B\) の 1 次元目に 8_L2B:1, 8_L1B:1 とある通り、8 個の L2B, 8 個の L1B に分散して配置され、1 次元目の長さが 4 から 256 に 64 倍に増えています。

今回の問題の行列サイズに注目すると、\((256\times16)\times(256\times16)^T = (16\times16)\) という計算です。

\((256\times16)\) の行列を縦に 64 個に分け \((4\times16)\) の形の行列にして、前問のように、\((4\times16)^T\times(4\times16) = (16\times16)\) の行列演算を行った後、64 個に分割した出力の \((16\times16)\) 行列を足し合わせること最終的な答えの \((16\times16)\) 行列を求めることができます。

各 L1B に分かれて \((4\times16)\) の行列積を求めたあと、DRAM まで値を転送する過程で L1B 間、L2B 間の縮約を行うことで、Accept を得られます。

なお、DRAM へは、\(16\times16\) 行列を 4 グループに分けて、各グループの DRAM に分割して格納する必要があります。

DRAM までの縮約に使う命令

L2BM 間の縮約と、4 DRAM への分割を効率的に行うために、L2BM から PDM への縮約と、PDM から DRAM への転送に分けると良いでしょう。

最初、各 PE には 64 単語(32長語)の値があり、4 PE 間での結合と、0 番 MAB の値を L1BM に転送します。

次に各 L1BM にある 128 長語を、L2BM へ 8 L1BM 間で縮約を行います。

各 L2BM には 128 長語があり、8 L2BM 間で縮約を行い、PDM へ転送します。

PDM には 128 長語があり、4 グループの各 DRAM へそれぞれ 32 長語を個別転送します。

…と最後に、PDM から DRAM への転送粒度・アドレスの指定が 64(長語)単位でないと行けない問題に遭遇します。

どうにかして 4 DRAM に分割する方法は無いでしょうか?

ひとまず、これらの命令自体は使用するので、一度書いて考えてみましょう。

4 DRAM への分割とアライメント l1bmm@0l2bmrffaddmvrffadd/n64 で PDM まで値を転送・縮約したあと、4 DRAM に分割する転送を行おうとしたところで、うまい命令が見つからないかもしれません。

単独個別転送命令 mvp をしようにも、32 長語単位で送りたいのに 64 長語単位でしかアドレスを指定できず、PDM → DRAM 分配命令 mvd を使おうにも、要素の順番がうまく揃いません。

L1BM まで 128 長語を上げた後、

l2bmrffadd $lb0 $lc0 l2bmrffadd $lb32 $lc32 l2bmrffadd $lb64 $lc64 l2bmrffadd $lb96 $lc96

で L2BM 間で縮約を行うと思いますが、ここで書き込みアドレスを

l2bmrffadd $lb0 $lc0 l2bmrffadd $lb32 $lc64 l2bmrffadd $lb64 $lc128 l2bmrffadd $lb96 $lc192

のようにあえてパディングを入れることで、回避することができます。

Inputs

Outputs

Testcases

testcase.vsm

Submission

ログイン / 新規登録