{"id":2564,"date":"2010-05-14T14:35:06","date_gmt":"2010-05-14T05:35:06","guid":{"rendered":"http:\/\/yasu2.prosou.nu\/blog\/index.php\/2010\/05\/14\/reconf_may14_2010\/"},"modified":"2010-05-14T14:35:06","modified_gmt":"2010-05-14T05:35:06","slug":"reconf_may14_2010","status":"publish","type":"post","link":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/2010\/05\/14\/2564\/","title":{"rendered":"RECONF\u7814 (May.14, 2010)"},"content":{"rendered":"<p>[FPGA\u3092\u7528\u3044\u305f\u69d8\u3005\u306a\u5927\u304d\u3055\u3001\u56de\u8ee2\u89d2\u3092\u6301\u3064\u30d1\u30bf\u30fc\u30f3\u306e\u691c\u51fa\u624b\u6cd5\u306e\u691c\u8a0e]<br \/>\n\u68b6\u539f\u3055\u3093: \u56de\u8ee2\u306e\u3068\u3053\u308d\u3067\u3001\u96a3\u306e\u30d4\u30af\u30bb\u30eb\u306b\u79fb\u52d5\u3057\u3061\u3083\u3063\u305f\u3068\u3053\u308d\u3060\u3051\u3092\u8a08\u7b97\u3057\u3066\u51e6\u7406\u91cf\u3092\u6e1b\u3089\u3057\u3066\u3044\u308b\u3093\u3060\u3051\u3069\u3001\u5927\u304d\u306a\u753b\u50cf\u306b\u306a\u308b\u3068\u3042\u307e\u308a\u7bc0\u7d04\u306b\u306a\u3089\u306a\u3044\u306e\u3067\u306f\uff1f<br \/>\n\u9234\u6728\u3055\u3093: \u3044\u307e\u4f7f\u3063\u3066\u3044\u308bFPGA\u3067\u3067\u304d\u308b\u30b5\u30a4\u30ba\u306e\u753b\u50cf\u3067\u306f\u3053\u308c\u3067\u3088\u3044\u3068\u601d\u3063\u3066\u3044\u308b\u3002\u5927\u304d\u3044\u306e\u3067\u306f\u9055\u3046\u3051\u308c\u3069\u3002<br \/>\n[\u632f\u52d5\u6291\u5236\u3092\u8003\u616e\u3057\u305f\u8ffd\u5f93\u30b7\u30b9\u30c6\u30e0\u306eFPGA\u306b\u3088\u308b\u5b9f\u88c5]<br \/>\n\u73fe\u4ee3\u5236\u5fa1\u306a\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3092MATLAB\/Simulink \u306e\u30e2\u30c7\u30eb\u304b\u3089\u5b9f\u88c5\u3002<br \/>\n\u7d44\u307f\u8fbc\u307f\u306a\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2\u306b\u5bfe\u3057\u3066\u3069\u308c\u304f\u3089\u3044\u306e\u30a2\u30c9\u30d0\u30f3\u30c6\u30fc\u30b8\u304c\u3042\u308b\u304b\uff1f<br \/>\nXilinx, Altera \u306a\u3069\u306e\u30c4\u30fc\u30eb\u306f\u3042\u308b\u3051\u3069\u3001\u4e3b\u306b DSP \u7528\u3067\u3042\u308a\u3001FPGA \u7528\u306e\u6a5f\u7a2e\u4f9d\u5b58\u306a\u30d6\u30ed\u30c3\u30af\u3092\u4f7f\u3063\u3066\u3084\u3089\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u3002Mathworks \u304c\u51fa\u3057\u3066\u3044\u308b\u30c4\u30fc\u30eb\u306f\u9650\u5b9a\u7684\u3060\u304c\u6a19\u6e96\u306e\u30d6\u30ed\u30c3\u30af\u3092\u30b5\u30dd\u30fc\u30c8\u3057\u3066\u3044\u308b\u3002<br \/>\n\u5236\u9707\u5236\u5fa1: \u305f\u3068\u3048\u3070\u6c34\u306e\u5165\u3063\u305f\u30b3\u30c3\u30d7\u3092\u3001\u6c34\u3092\u3053\u307c\u3055\u305a\u306b\u9ad8\u901f\u306b\u79fb\u52d5\u3059\u308b\u3002<br \/>\n\u92f3\u9020\u306e\u30e9\u30a4\u30f3\u3068\u304b\u3067\u4f7f\u3046\u3002\u88c5\u7f6e\u306e\u5236\u7d04 (\u6700\u5927\u901f\u5ea6\u3001\u6700\u5927\u52a0\u901f\u5ea6\u306a\u3069) \u3092\u6e80\u305f\u3059\u305f\u3081\u306b\u3001\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u3067\u30b7\u30df\u30e5\u30ec\u30fc\u30b7\u30e7\u30f3\u3057\u306a\u304c\u3089\u6b21\u306e\u52d5\u4f5c\u3092\u6c7a\u3081\u308b (\u4e88\u6e2c\u5236\u5fa1) \u5fc5\u8981\u304c\u3042\u308a\u3001\u8a08\u7b97\u304c\u5927\u5909\u3067\u3001Atom Z530 \u3067\u306f\u5b9f\u6642\u9593\u5236\u5fa1\u306b\u9593\u306b\u5408\u308f\u306a\u3044!<br \/>\n\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2\u5b9f\u884c\u7248\u3068HDL\u7248\u3067\u306fMATLAB\u306e\u30ec\u30d9\u30eb\u3067\u66f8\u304d\u65b9\u3092\u5909\u3048\u306a\u3044\u3068\u30c0\u30e1\u3002<br \/>\n\u4eac\u3055\u3093: \u7d44\u307f\u8fbc\u307f\u3067\u901f\u3044\u30d7\u30ed\u30bb\u30c3\u30b5\u3092\u4f7f\u3048\u306a\u3044\u306e\u306f\u306a\u305c\uff1f<br \/>\n\u5e02\u5ddd\u5148\u751f: \u30b3\u30b9\u30c8\u3068\u304b\u3001\u3042\u308b\u3044\u306f\u4ed6\u6a5f\u7a2e\u3068\u5171\u901a\u90e8\u54c1\u3060\u3063\u305f\u308a\u3059\u308b\u306e\u3067\u3002\u9ad8\u901f\u306a\u4e88\u6e2c\u5236\u5fa1\u306f\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2\u3067\u306f\u3067\u304d\u306a\u3044\u306e\u3067\u3001\u30b3\u30b9\u30c8\u304c\u8a31\u3059\u306a\u3089\u3070FPGA\u306a\u3069\u3092\u5c0e\u5165\u3059\u308b\u3053\u3068\u3067\u3001\u3044\u307e\u307e\u3067\u3067\u304d\u306a\u304b\u3063\u305f\u3053\u3068\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b\u3002\u4eca\u56de\u306f\u3001\u3075\u3064\u3046\u306e\u5e02\u8ca9\u306e\u30c4\u30fc\u30eb\u3067\u3069\u308c\u304f\u3089\u3044\u306e\u3082\u306e\u304c\u3067\u304d\u308b\u304b\u306b\u8208\u5473\u304c\u3042\u3063\u305f\u3002<br \/>\n[SIMD\u578b\u4e26\u5217\u5ea6\u53ef\u5909\u30d7\u30ed\u30bb\u30c3\u30b5\u30b3\u30a2\u306e\u63d0\u6848\u3068\u305d\u306e\u691c\u8a3c]<br \/>\nSuper H-2\u4e92\u63db\u30bd\u30d5\u30c8IP \u306e Aquarius (available at opencores.org) \u306e Verilog \u8a18\u8ff0\u3092\u4f7f\u7528\u3002<br \/>\n\u30de\u30eb\u30c1\u30b3\u30a2\u306b\u3059\u308b\u3088\u308a\u306fSIMD\u306e\u307b\u3046\u304c\u7701\u9762\u7a4d\u306a\u611f\u3058\u3067\u3001SIMD \u306e\u307b\u3046\u304c\u3001\u4f7f\u7528 LUT \u306b\u6bd4\u4f8b\u3057\u3066\u7d20\u76f4\u306b\u6027\u80fd\u304c\u4f38\u3073\u308b\u3002<br \/>\n\u67f4\u7530\u5148\u751f: \u6f14\u7b97\u5668\u3068\u30ec\u30b8\u30b9\u30bf\u306f\u30bb\u30c3\u30c8\u306b\u3057\u3066\u4e26\u3079\u308b\u306e\uff1f<br \/>\n\u7530\u908a\u3055\u3093: \u306f\u3044\u3002<br \/>\n\u67f4\u7530\u5148\u751f: \u958b\u767a\u74b0\u5883\u306f\u3069\u3046\u3057\u3066\u3044\u307e\u3059\u304b\uff1f<br \/>\n\u7530\u908a\u3055\u3093: SSE\u7528\u306e\u958b\u767a\u74b0\u5883\u3068\u304b\u306e\u51fa\u529b\u3092 translate \u3059\u308b\u3053\u3068\u3092\u8003\u3048\u3066\u3044\u307e\u3059\u3002<br \/>\n\u6e21\u908a\u5148\u751f: \u30aa\u30ea\u30b8\u30ca\u30eb\u306e\u547d\u4ee4\u30bb\u30c3\u30c8\u306b\u5bfe\u3057\u3066\u3069\u3046\u3044\u3063\u305fSIMD\u547d\u4ee4\u3092\u8ffd\u52a0\u3057\u3066\u3044\u307e\u3059\u304b\uff1f<br \/>\n\u7530\u908a\u3055\u3093: \u5b9f\u306f\u547d\u4ee4\u306f\u8ffd\u52a0\u3057\u3066\u3044\u306a\u304f\u3066\u3001\u3059\u3079\u3066\u306e\u6f14\u7b97\u5668\u304c\u540c\u3058\u547d\u4ee4\u3092\u5b9f\u884c\u3059\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u308b\u3002\u6f14\u7b97\u30e6\u30cb\u30c3\u30c8\u9593\u306e\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u304c\u3067\u304d\u3066\u304b\u3089\u3001\u901a\u4fe1\u95a2\u4fc2\u306e\u3053\u3068\u3092\u8003\u3048\u305f\u3044\u3002<br \/>\n[PC-FPGA\u8907\u5408\u30af\u30e9\u30b9\u30bf\u306b\u304a\u3051\u308b\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2-\u30cf\u30fc\u30c9\u30a6\u30a7\u30a2\u9593\u901a\u4fe1\u3068\u9060\u9694\u547c\u3073\u51fa\u3057]<br \/>\nPC\u30af\u30e9\u30b9\u30bf\u7528\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u306b\u304a\u3051\u308bFPGA\u306e\u5229\u7528\u306fMaestro2 (\u7b51\u6ce2\u5927) \u3068\u304b DIMMnet (\u6176\u61c9)\u3068\u304b\u306b\u898b\u3089\u308c\u308b\u3057\u3001\u8a08\u7b97\u306b\u3082\u4f7f\u308f\u308c\u3066\u3044\u308b\u3002<br \/>\n\u4e95\u53e3\u5148\u751f: \u306a\u3093\u304b\u9045\u3044\u306e\u306f\u3001\u5b9f\u306f\u6e2c\u5b9a\u30bf\u30a4\u30de\u306e\u95a2\u6570\u306e\u7cbe\u5ea6\u306e\u554f\u984c\u3067\u306f\uff1f\u3082\u3063\u3068\u3044\u3044\u6027\u80fd\u304c\u51fa\u3066\u3044\u308b\u304b\u3082 :p<br \/>\n\u5c0f\u7551\u5148\u751f: \u305d\u3046\u304b\u3082\u3057\u308c\u307e\u305b\u3093 \ud83d\ude42<br \/>\n\u68b6\u539f\u3055\u3093: FPGA \u304b\u3089 PC \u3092\u547c\u3076\u3001\u3068\u3044\u3046\u51e6\u7406\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u308b\u3051\u3069\u3001\u3069\u3046\u4f7f\u3046\uff1f\u5bfe\u79f0\u6027\u304c\u3042\u308b\u306e\u306f\u3044\u3044\u3051\u308c\u3069\u3002<br \/>\n\u5c0f\u7551\u5148\u751f: \u3061\u3087\u3063\u3068\u691c\u8a0e\u3057\u307e\u3059\u3002<br \/>\n[\u8907\u6570FPGA\u4e0a\u3067\u52d5\u4f5c\u3059\u308b\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u30a2\u30ec\u30a4\u30d7\u30ed\u30bb\u30c3\u30b5\u306e\u305f\u3081\u306eGALS\u8a2d\u8a08]<br \/>\n\u30b9\u30c6\u30f3\u30b7\u30eb\u8a08\u7b97\u3068\u304b\u3092\u3059\u308b\u305f\u3081\u306e\u3001globally async, locally sync \u306a\u30b7\u30b9\u30c6\u30e0\u3002<br \/>\nFPGA \u30dc\u30fc\u30c9\u3092\u8907\u6570\u4f7f\u3063\u3066\u691c\u8a3c\u3002\u30b9\u30c8\u30fc\u30eb\u306e\u89e3\u6c7a\u30e1\u30ab\u30cb\u30ba\u30e0\u304c\u30ad\u30e2\u3067\u3001\u304b\u306a\u308a\u3046\u307e\u304f\u3044\u3063\u3066\u3044\u308b\u3002<br \/>\n\u5c0f\u6817\u5148\u751f: dual port FIFO \u3092\u4f7f\u3046\u3068\u30c7\u30fc\u30bf\u306f\u3046\u307e\u304f\u3044\u304f\u3093\u3060\u3051\u3069\u3001handshake \u306e\u3068\u3053\u308d\u306f\u3080\u305a\u304b\u3057\u3044\u306e\u3067\u3001\u6c17\u3092\u3064\u3051\u3066\u4f5c\u3089\u306a\u3044\u3068metastable\u306b\u843d\u3061\u3066\u8aa4\u52d5\u4f5c\u304c\u8d77\u304d\u308b\u3053\u3068\u304c\u3042\u308b\u306e\u3067\u3001\u8907\u6570\u306e\u30af\u30ed\u30c3\u30af\u3092\u4f7f\u3046\u3068\u96e3\u3057\u3044\u304b\u3082\u3002<br \/>\n\u305d\u3046\u304b\u30fb\u30fb\u30fb\u96e3\u3057\u3044\u306a\u3042\u3002<br \/>\n[\u8907\u6570\u306e\u7570\u306a\u308b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u7528\u3044\u305fFPGA\u30d9\u30fc\u30b9\u30fb\u30ea\u30b3\u30f3\u30d5\u30a3\u30ae\u30e5\u30e9\u30d6\u30eb\u30b7\u30b9\u30c6\u30e0\u7528OS\u306e\u6027\u80fd\u8a55\u4fa1]<br \/>\n\u30db\u30b9\u30c8 PC \u306b\u304f\u3063\u3064\u3044\u305f FPGA \u306a\u3093\u304b\u3067\u3001\u8907\u6570\u306e SW task \u304c\u52d5\u304f\u306e\u306f\u5f53\u7136\u3068\u3057\u3066\u3001\u305d\u308c\u306b\u5bfe\u5fdc\u3059\u308b\u8907\u6570\u306e HW task \u3092\u52d5\u304b\u305b\u308b\u3088\u3046\u306a OS \u7684\u306a\u30b7\u30b9\u30c6\u30e0\u3092\u4f5c\u3063\u3066\u3044\u308b\u3002\u30d7\u30ed\u30c8\u30bf\u30a4\u30d7\u306f SPARTAN3 \u30924\u3064\u642d\u8f09\u3002<br \/>\n\u6e21\u908a\u5148\u751f: HW task \u306f1\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067FPGA\u3072\u3068\u3064\uff1f<br \/>\n\u5150\u5cf6\u5148\u751f: \u518d\u69cb\u6210\u306e\u4e8b\u60c5\u3068\u304b\u3067\u305d\u3046\u306a\u3063\u3066\u3044\u307e\u3059\u304c\u3001\u5c06\u6765\u306f\u4f55\u3068\u304b\u3057\u305f\u3044\u3002<br \/>\n[An Efficient Implementation of Exhaustive Verification of the Collatz Conjecture using DSP48E blocks of Xilinx Virtex-5 FPGAs]<br \/>\n\u5c02\u9580\u59d4\u54e1\u4f1a\u304c\u3042\u3063\u3066\u9045\u523b\u3057\u307e\u3057\u305f\u3054\u3081\u3093\u306a\u3055\u3044\u3002<br \/>\n\u5e02\u5ddd\u5148\u751f\u3068\u5c0f\u6817\u5148\u751f\u304c\u3053\u308c\u3063\u3066\u4f55\u3067\u8a3c\u660e\u3067\u304d\u306a\u3044\u306e\u304b\u3001\u3068\u3044\u3046\u8b70\u8ad6\u3067\u76db\u308a\u4e0a\u304c\u308b\u3002<br \/>\nVirtex-II \u306e\u3068\u304d\u304b\u3089\u306e\u6027\u80fd\u5411\u4e0a\u306b\u306f DSP block \u306e\u5bc4\u4e0e\u304c\u5927\u304d\u3044\u3068\u306e\u3053\u3068\u3002<br \/>\n[\u30de\u30eb\u30c1FPGA\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0FLOPS-2D\u306b\u304a\u3051\u308b\u6f14\u7b97\u30d1\u30a4\u30d7\u30e9\u30a4\u30f3\u306e\u5b9f\u88c5]<br \/>\n\u3061\u3087\u3063\u3068\u5c0e\u5165\u306e\u30b9\u30e9\u30a4\u30c9\u304c\u307e\u305a\u304b\u3063\u305f\u306a\u30fc\u3002preliminary work \u3060\u3063\u3066\u3044\u3046\u306e\u3092\u524d\u9762\u306b\u51fa\u3055\u306a\u3044\u3068\u8aa4\u89e3\u3055\u308c\u308b\u3001\u3068\u3044\u3046\u3053\u3068\u304c\u3088\u304f\u308f\u304b\u3063\u305f\u3002\u3084\u3063\u3066\u308b\u5185\u5bb9\u306f\u60aa\u304f\u306a\u3044\u3068\u601d\u3046\u3002<br \/>\n[\u52d5\u7684\u518d\u69cb\u6210\u30c7\u30d0\u30a4\u30b9\u306b\u3088\u308b\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u7ffb\u8a33\u30b7\u30b9\u30c6\u30e0\u306e\u69cb\u7bc9\u3068\u691c\u8a3c]<br \/>\nDAP\/DNA2!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>[FPGA\u3092\u7528\u3044\u305f\u69d8\u3005\u306a\u5927\u304d\u3055\u3001\u56de\u8ee2\u89d2\u3092\u6301\u3064\u30d1\u30bf\u30fc\u30f3\u306e\u691c\u51fa\u624b\u6cd5\u306e\u691c\u8a0e] \u68b6\u539f\u3055\u3093: \u56de\u8ee2\u306e\u3068\u3053\u308d\u3067\u3001\u96a3\u306e\u30d4\u30af\u30bb\u30eb\u306b\u79fb\u52d5\u3057\u3061\u3083\u3063\u305f\u3068\u3053\u308d\u3060\u3051\u3092\u8a08\u7b97\u3057\u3066\u51e6\u7406\u91cf\u3092\u6e1b\u3089\u3057\u3066\u3044\u308b\u3093\u3060\u3051\u3069\u3001\u5927\u304d\u306a\u753b\u50cf\u306b\u306a\u308b\u3068\u3042\u307e\u308a\u7bc0\u7d04\u306b\u306a\u3089\u306a\u3044\u306e\u3067 &hellip; <a href=\"https:\/\/yasu2.prosou.nu\/blog\/index.php\/2010\/05\/14\/2564\/\" class=\"more-link\"><span class=\"screen-reader-text\">&#8220;RECONF\u7814 (May.14, 2010)&#8221; \u306e<\/span>\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"activitypub_content_warning":"","activitypub_content_visibility":"","activitypub_max_image_attachments":4,"activitypub_interaction_policy_quote":"anyone","activitypub_status":"","footnotes":""},"categories":[10],"tags":[],"class_list":["post-2564","post","type-post","status-publish","format-standard","hentry","category-conference-logs"],"_links":{"self":[{"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/posts\/2564","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/comments?post=2564"}],"version-history":[{"count":0,"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/posts\/2564\/revisions"}],"wp:attachment":[{"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/media?parent=2564"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/categories?post=2564"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/yasu2.prosou.nu\/blog\/index.php\/wp-json\/wp\/v2\/tags?post=2564"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}