在Google Driver中,更新檔案(需檔案權限)或上傳檔案(需目錄權限)較為複雜,目前先針對下載檔案說明。
2024年11月18日 星期一
2024年5月28日 星期二
生成verilog Look-Up Table (case) module 的matlab程式
matlab程式如下,ibright為Look-Up Table變數輸入,obright為Look-Up Table變數輸出
11~14行為LUT,xy對應的方程式在第12行
- % 開啟檔案以寫入
- fileID = fopen('contrast.v', 'w');
- % 寫入檔案內容
- fprintf(fileID, 'module contrast(\n\tibright,\n\tobright\n);\n\n');
- fprintf(fileID, 'input\t\t\t[7:0]\tibright;\n');
- fprintf(fileID, 'output reg\t[7:0]\tobright;\n\n');
- fprintf(fileID, 'always @(ibright)\n\tbegin\n\t\tcase(ibright)\n');
- % 生成從 0 到 255 的數值和對應的 nn 值
- for x = 0:255
- y = floor(96*( (x-128)/128)^3 + 96 ); % equation
- fprintf(fileID, '\t\t8''d%03d: obright = %03d;\t//\n', x, y);
- end
- % 完成 case 和模組結束部分
- fprintf(fileID, '\t\tendcase\n\tend\nendmodule\n');
- % 關閉檔案
- fclose(fileID);
- disp('檔案 contrast.v 已生成');
生成module結果附在下方,可用下面方式呼叫
為減少延遲,本例未使用clock
為減少延遲,本例未使用clock
- contrast u(
- .ibright(gray),
- .obright(gray_contrast)
- );
module的verilog檔
- module contrast(
- ibright,
- obright
- );
- input [7:0] ibright;
- output reg [7:0] obright;
- always @(ibright)
- begin
- case(ibright)
- 8'd000: obright = 000; //
- 8'd001: obright = 002; //
- 8'd002: obright = 004; //
- 8'd003: obright = 006; //
- 8'd004: obright = 008; //
- 8'd005: obright = 010; //
- 8'd006: obright = 012; //
- 8'd007: obright = 014; //
- 8'd008: obright = 016; //
- 8'd009: obright = 018; //
- 8'd010: obright = 020; //
- 8'd011: obright = 022; //
- 8'd012: obright = 024; //
- 8'd013: obright = 026; //
- 8'd014: obright = 028; //
- 8'd015: obright = 029; //
- 8'd016: obright = 031; //
- 8'd017: obright = 033; //
- 8'd018: obright = 035; //
- 8'd019: obright = 036; //
- 8'd020: obright = 038; //
- 8'd021: obright = 039; //
- 8'd022: obright = 041; //
- 8'd023: obright = 043; //
- 8'd024: obright = 044; //
- 8'd025: obright = 045; //
- 8'd026: obright = 047; //
- 8'd027: obright = 048; //
- 8'd028: obright = 050; //
- 8'd029: obright = 051; //
- 8'd030: obright = 052; //
- 8'd031: obright = 054; //
- 8'd032: obright = 055; //
- 8'd033: obright = 056; //
- 8'd034: obright = 057; //
- 8'd035: obright = 059; //
- 8'd036: obright = 060; //
- 8'd037: obright = 061; //
- 8'd038: obright = 062; //
- 8'd039: obright = 063; //
- 8'd040: obright = 064; //
- 8'd041: obright = 065; //
- 8'd042: obright = 066; //
- 8'd043: obright = 067; //
- 8'd044: obright = 068; //
- 8'd045: obright = 069; //
- 8'd046: obright = 070; //
- 8'd047: obright = 071; //
- 8'd048: obright = 072; //
- 8'd049: obright = 073; //
- 8'd050: obright = 074; //
- 8'd051: obright = 075; //
- 8'd052: obright = 075; //
- 8'd053: obright = 076; //
- 8'd054: obright = 077; //
- 8'd055: obright = 078; //
- 8'd056: obright = 078; //
- 8'd057: obright = 079; //
- 8'd058: obright = 080; //
- 8'd059: obright = 080; //
- 8'd060: obright = 081; //
- 8'd061: obright = 082; //
- 8'd062: obright = 082; //
- 8'd063: obright = 083; //
- 8'd064: obright = 084; //
- 8'd065: obright = 084; //
- 8'd066: obright = 085; //
- 8'd067: obright = 085; //
- 8'd068: obright = 086; //
- 8'd069: obright = 086; //
- 8'd070: obright = 087; //
- 8'd071: obright = 087; //
- 8'd072: obright = 087; //
- 8'd073: obright = 088; //
- 8'd074: obright = 088; //
- 8'd075: obright = 089; //
- 8'd076: obright = 089; //
- 8'd077: obright = 089; //
- 8'd078: obright = 090; //
- 8'd079: obright = 090; //
- 8'd080: obright = 090; //
- 8'd081: obright = 091; //
- 8'd082: obright = 091; //
- 8'd083: obright = 091; //
- 8'd084: obright = 092; //
- 8'd085: obright = 092; //
- 8'd086: obright = 092; //
- 8'd087: obright = 092; //
- 8'd088: obright = 093; //
- 8'd089: obright = 093; //
- 8'd090: obright = 093; //
- 8'd091: obright = 093; //
- 8'd092: obright = 093; //
- 8'd093: obright = 094; //
- 8'd094: obright = 094; //
- 8'd095: obright = 094; //
- 8'd096: obright = 094; //
- 8'd097: obright = 094; //
- 8'd098: obright = 094; //
- 8'd099: obright = 094; //
- 8'd100: obright = 094; //
- 8'd101: obright = 095; //
- 8'd102: obright = 095; //
- 8'd103: obright = 095; //
- 8'd104: obright = 095; //
- 8'd105: obright = 095; //
- 8'd106: obright = 095; //
- 8'd107: obright = 095; //
- 8'd108: obright = 095; //
- 8'd109: obright = 095; //
- 8'd110: obright = 095; //
- 8'd111: obright = 095; //
- 8'd112: obright = 095; //
- 8'd113: obright = 095; //
- 8'd114: obright = 095; //
- 8'd115: obright = 095; //
- 8'd116: obright = 095; //
- 8'd117: obright = 095; //
- 8'd118: obright = 095; //
- 8'd119: obright = 095; //
- 8'd120: obright = 095; //
- 8'd121: obright = 095; //
- 8'd122: obright = 095; //
- 8'd123: obright = 095; //
- 8'd124: obright = 095; //
- 8'd125: obright = 095; //
- 8'd126: obright = 095; //
- 8'd127: obright = 095; //
- 8'd128: obright = 096; //
- 8'd129: obright = 096; //
- 8'd130: obright = 096; //
- 8'd131: obright = 096; //
- 8'd132: obright = 096; //
- 8'd133: obright = 096; //
- 8'd134: obright = 096; //
- 8'd135: obright = 096; //
- 8'd136: obright = 096; //
- 8'd137: obright = 096; //
- 8'd138: obright = 096; //
- 8'd139: obright = 096; //
- 8'd140: obright = 096; //
- 8'd141: obright = 096; //
- 8'd142: obright = 096; //
- 8'd143: obright = 096; //
- 8'd144: obright = 096; //
- 8'd145: obright = 096; //
- 8'd146: obright = 096; //
- 8'd147: obright = 096; //
- 8'd148: obright = 096; //
- 8'd149: obright = 096; //
- 8'd150: obright = 096; //
- 8'd151: obright = 096; //
- 8'd152: obright = 096; //
- 8'd153: obright = 096; //
- 8'd154: obright = 096; //
- 8'd155: obright = 096; //
- 8'd156: obright = 097; //
- 8'd157: obright = 097; //
- 8'd158: obright = 097; //
- 8'd159: obright = 097; //
- 8'd160: obright = 097; //
- 8'd161: obright = 097; //
- 8'd162: obright = 097; //
- 8'd163: obright = 097; //
- 8'd164: obright = 098; //
- 8'd165: obright = 098; //
- 8'd166: obright = 098; //
- 8'd167: obright = 098; //
- 8'd168: obright = 098; //
- 8'd169: obright = 099; //
- 8'd170: obright = 099; //
- 8'd171: obright = 099; //
- 8'd172: obright = 099; //
- 8'd173: obright = 100; //
- 8'd174: obright = 100; //
- 8'd175: obright = 100; //
- 8'd176: obright = 101; //
- 8'd177: obright = 101; //
- 8'd178: obright = 101; //
- 8'd179: obright = 102; //
- 8'd180: obright = 102; //
- 8'd181: obright = 102; //
- 8'd182: obright = 103; //
- 8'd183: obright = 103; //
- 8'd184: obright = 104; //
- 8'd185: obright = 104; //
- 8'd186: obright = 104; //
- 8'd187: obright = 105; //
- 8'd188: obright = 105; //
- 8'd189: obright = 106; //
- 8'd190: obright = 106; //
- 8'd191: obright = 107; //
- 8'd192: obright = 108; //
- 8'd193: obright = 108; //
- 8'd194: obright = 109; //
- 8'd195: obright = 109; //
- 8'd196: obright = 110; //
- 8'd197: obright = 111; //
- 8'd198: obright = 111; //
- 8'd199: obright = 112; //
- 8'd200: obright = 113; //
- 8'd201: obright = 113; //
- 8'd202: obright = 114; //
- 8'd203: obright = 115; //
- 8'd204: obright = 116; //
- 8'd205: obright = 116; //
- 8'd206: obright = 117; //
- 8'd207: obright = 118; //
- 8'd208: obright = 119; //
- 8'd209: obright = 120; //
- 8'd210: obright = 121; //
- 8'd211: obright = 122; //
- 8'd212: obright = 123; //
- 8'd213: obright = 124; //
- 8'd214: obright = 125; //
- 8'd215: obright = 126; //
- 8'd216: obright = 127; //
- 8'd217: obright = 128; //
- 8'd218: obright = 129; //
- 8'd219: obright = 130; //
- 8'd220: obright = 131; //
- 8'd221: obright = 132; //
- 8'd222: obright = 134; //
- 8'd223: obright = 135; //
- 8'd224: obright = 136; //
- 8'd225: obright = 137; //
- 8'd226: obright = 139; //
- 8'd227: obright = 140; //
- 8'd228: obright = 141; //
- 8'd229: obright = 143; //
- 8'd230: obright = 144; //
- 8'd231: obright = 146; //
- 8'd232: obright = 147; //
- 8'd233: obright = 148; //
- 8'd234: obright = 150; //
- 8'd235: obright = 152; //
- 8'd236: obright = 153; //
- 8'd237: obright = 155; //
- 8'd238: obright = 156; //
- 8'd239: obright = 158; //
- 8'd240: obright = 160; //
- 8'd241: obright = 162; //
- 8'd242: obright = 163; //
- 8'd243: obright = 165; //
- 8'd244: obright = 167; //
- 8'd245: obright = 169; //
- 8'd246: obright = 171; //
- 8'd247: obright = 173; //
- 8'd248: obright = 175; //
- 8'd249: obright = 177; //
- 8'd250: obright = 179; //
- 8'd251: obright = 181; //
- 8'd252: obright = 183; //
- 8'd253: obright = 185; //
- 8'd254: obright = 187; //
- 8'd255: obright = 189; //
- endcase
- end
- endmodule
訂閱:
文章 (Atom)