123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- const isNodeJs = (typeof window) === 'undefined'? true : false;
- if (isNodeJs) {
- var Benchmark = require('benchmark');
- var cv = require('../../opencv');
- var HelpFunc = require('../perf_helpfunc');
- var Base = require('../base');
- } else {
- var paramsElement = document.getElementById('params');
- var runButton = document.getElementById('runButton');
- var logElement = document.getElementById('log');
- }
- function perf() {
- console.log('opencv.js loaded');
- if (isNodeJs) {
- global.cv = cv;
- global.combine = HelpFunc.combine;
- global.log = HelpFunc.log;
- global.decodeParams2Case = HelpFunc.decodeParams2Case;
- global.setBenchmarkSuite = HelpFunc.setBenchmarkSuite;
- global.addKernelCase = HelpFunc.addKernelCase;
- global.cvSize = Base.getCvSize();
- } else {
- enableButton();
- cvSize = getCvSize();
- }
- let totalCaseNum, currentCaseId;
- const RemapSize = [cvSize.szVGA, cvSize.sz1080p];
- const RemapSrcType = ["CV_16UC1", "CV_16SC1", "CV_32FC1"];
- const RemapType = ["CV_16SC2", "CV_32FC1", "CV_32FC2"];
- const InterType = ["INTER_NEAREST", "INTER_LINEAR", "INTER_CUBIC", "INTER_LANCZOS4"];
- const combiRemap = combine(RemapSize, RemapSrcType, RemapType, InterType);
- function addRemapCase(suite, type) {
- suite.add('remap', function() {
- cv.remap(src, dst, map1, map2, interType);
- }, {
- 'setup': function() {
- let size = this.params.size;
- let matType = cv[this.params.matType];
- let mapType = cv[this.params.mapType];
- let interType = cv[this.params.interType];
- let src = new cv.Mat(size, matType);
- let dst = new cv.Mat(size, matType);
- let map1 = new cv.Mat(size, mapType);
- let map2;
- if (mapType == cv.CV_32FC1) {
- map2 = new cv.Mat(size, mapType);
- } else if (interType != cv.INTER_NEAREST && mapType == cv.CV_16SC2) {
- map2 = new cv.Mat.zeros(size, cv.CV_16UC1);
- } else {
- map2 = new cv.Mat();
- }
- for (let j = 0; j < map1.rows; j++) {
- for (let i = 0; i < map1.cols; i++) {
- let randNum = Math.random();
- let view, view1;
- switch(matType) {
- case cv.CV_16UC1:
- view = src.ushortPtr(j,i);
- view[0] = Math.floor(randNum*256);
- break;
- case cv.CV_16SC1:
- view = src.shortPtr(j,i);
- view[0] = Math.floor(randNum*256);
- break;
- case cv.CV_32FC1:
- view = src.floatPtr(j,i);
- view[0] = randNum*256;
- break;
- default:
- console.error("Unknown conversion type 1");
- break;
- }
- switch(mapType) {
- case cv.CV_32FC1:
- view1 = map1.floatPtr(j,i);
- let view2 = map2.floatPtr(j,i);
- view1[0] = src.cols - i - 1;
- view2[0] = j;
- break;
- case cv.CV_32FC2:
- view1 = map1.floatPtr(j,i);
- view1[0] = src.cols - i - 1;
- view1[1] = j;
- break;
- case cv.CV_16SC2:
- view1 = map1.shortPtr(j,i);
- view1[0] = src.cols - i - 1;
- view1[1] = j;
- break;
- default:
- console.error("Unknown conversion type 2");
- break;
- }
- }
- }
- },
- 'teardown': function() {
- src.delete();
- dst.delete();
- map1.delete();
- map2.delete();
- }
- });
- }
- function addRemapModeCase(suite, combination, type) {
- totalCaseNum += combination.length;
- for (let i = 0; i < combination.length; ++i) {
- let size = combination[i][0];
- let matType = combination[i][1];
- let mapType = combination[i][2];
- let interType = combination[i][3];
- let params = {size: size, matType:matType, mapType:mapType, interType:interType};
- addKernelCase(suite, params, type, addRemapCase);
- }
- }
- function genBenchmarkCase(paramsContent) {
- let suite = new Benchmark.Suite;
- totalCaseNum = 0;
- currentCaseId = 0;
- if (/\([0-9]+x[0-9]+,[\ ]*CV\_\w+,[\ ]*CV\_\w+,[\ ]*INTER\_\w+\)/g.test(paramsContent.toString())) {
- let params = paramsContent.toString().match(/\([0-9]+x[0-9]+,[\ ]*CV\_\w+,[\ ]*CV\_\w+,[\ ]*INTER\_\w+\)/g)[0];
- let paramObjs = [];
- paramObjs.push({name:"size", value:"", reg:[""], index:0});
- paramObjs.push({name:"matType", value:"", reg:["/CV\_[0-9]+[FSUfsu]C[0-9]/"], index:1});
- paramObjs.push({name:"mapType", value:"", reg:["/CV\_[0-9]+[FSUfsu]C[0-9]/g"], index:2, loc:1});
- paramObjs.push({name:"interType", value: "", reg:["/INTER\_\\w+/"], index:3});
- let locationList = decodeParams2Case(params, paramObjs, remapCombinations);
- for (let i = 0; i < locationList.length; i++){
- let first = locationList[i][0];
- let second = locationList[i][1];
- addRemapModeCase(suite, [remapCombinations[first][second]], first);
- }
- } else {
- log("no filter or getting invalid params, run all the cases");
- addRemapModeCase(suite, combiRemap, 0);
- }
- setBenchmarkSuite(suite, "remap", currentCaseId);
- log(`Running ${totalCaseNum} tests from remap`);
- suite.run({ 'async': true }); // run the benchmark
- }
- let remapCombinations = [combiRemap];
- if (isNodeJs) {
- const args = process.argv.slice(2);
- let paramsContent = '';
- if (/--test_param_filter=\([0-9]+x[0-9]+,[\ ]*CV\_\w+,[\ ]*CV\_\w+,[\ ]*INTER\_\w+\)/g.test(args.toString())) {
- paramsContent = args.toString().match(/\([0-9]+x[0-9]+,[\ ]*CV\_\w+,[\ ]*CV\_\w+,[\ ]*INTER\_\w+\)/g)[0];
- }
- genBenchmarkCase(paramsContent);
- } else {
- runButton.onclick = function() {
- let paramsContent = paramsElement.value;
- genBenchmarkCase(paramsContent);
- if (totalCaseNum !== 0) {
- disableButton();
- }
- }
- }
- };
- async function main() {
- if (cv instanceof Promise) {
- cv = await cv;
- perf();
- } else {
- cv.onRuntimeInitialized = perf;
- }
- }
- main();
|