近段時間在做PSO演算法的最佳化,在測試效能時要使用CEC05的資料集。但這個資料集提供的測試函數介面十分蛋疼:以條件編譯來區分一大堆同名同參數的函數。就像這樣:
int a;
#define f1
//#define f2
#ifdef f1
a = XX;
double function()
#endif
#ifdef f2
a = YY;
double function()
#endif
在上面的例子中,如果要運行F2函數,就要把#define f1注釋掉,並取消#define f2的注釋,然後編譯運行。但在CEC05中,這樣的函數共有25個。也就是說,進行一輪完整的測試就要手動這個過程25次。況且,肯定不止進行一輪測試。
面對這個問題,一開始想到的是將整個工程重構下,但在重構過程發現,條件編譯用得比較分散,改下來很麻煩。而且還可能出現改錯的情況,因此改到一半就放棄了。之後才想到適合做重複性日常工作的批處理。思路也很簡單:將標頭檔複製25份,每份對應一種注釋,即第一份將F1之外的define都注釋掉,第二份將F2之外的define都注釋掉。。。。。。然後依次將25份標頭檔覆蓋工程的同名檔案,重新編譯,並運行。代碼如下:
@echo off
set testFun=1
:loop
if %testFun%==26 goto end
echo f%testFun% start at %time%
copy D:\code\PSO\global\f%testFun%.h D:\code\PSO\win_test\global.h
copy D:\code\PSO\global\cf%testFun%.h D:\code\PSO\myConstant.h
msdev D:\code\PSO\pso.dsw /make /rebuild
call D:\code\PSO\Debug\pso.exe f%testFun%_res.txt f%testFun%_mid.txt
echo f%testFun% end at %time%
set /a testFun=%testFun%+1
goto loop
:end
這裡解釋下幾個語句:copy a\x.h b\y.h 就是將路徑a的x.h拷到路徑b處並將名字改為y.h。 msdev path /make /rebuild 就是調用VC6的編譯器,將path路徑下的工程重新編譯。call path argument1 argument2 就是調用path裡的exe,並將argument1和argument2作為參數傳給那個exe。
有了這個批處理後,之後的測試只要雙擊下就行了>_<