12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- # Compare metadata filter output containing float value strings to reference
- # output data. Returns the whole reference data if delta of each value is below
- # threshold, else returns the whole input data.
- function abs(val) {
- return ((val < 0.0) ? -val : val);
- }
- function max(val1, val2) {
- return ((val1 >= val2) ? val1 : val2);
- }
- function is_numeric_str(str) {
- return (str ~ /^[+-]?[0-9]*\.?[0-9]+$/);
- }
- BEGIN {
- FS = "=";
- # check for "fuzz" (threshold) program parameter, else use default
- if (fuzz <= 0.0) {
- fuzz = 0.1;
- }
- # check for "ref" (reference file) program parameter
- if (ref) {
- ref_nr = 0;
- while ((getline line < ref) > 0) {
- ref_nr++;
- ref_lines[ref_nr] = line;
- if (split(line, fields) == 2 && is_numeric_str(fields[2])) {
- ref_keys[ref_nr] = fields[1];
- ref_vals[ref_nr] = fields[2] + 0; # convert to number
- }
- }
- close(ref);
- }
- delta_max = 0;
- result = (ref ? 1 : 0);
- }
- {
- cmp_lines[NR] = $0;
- if (NF == 2 && is_numeric_str($2) && ref_vals[NR]) {
- val = $2 + 0; # convert to number
- delta = abs((val / ref_vals[NR]) - 1);
- delta_max = max(delta_max, delta);
- result = result && ($1 == ref_keys[NR]) && (delta <= fuzz);
- } else {
- result = result && ($0 == ref_lines[NR]);
- }
- }
- END {
- result = result && (NR == ref_nr);
- if (result) {
- for (i = 1; i <= ref_nr; i++)
- print ref_lines[i];
- } else {
- for (i = 1; i <= NR; i++)
- print cmp_lines[i];
- if (NR == 0)
- print "[refcmp] no input" > "/dev/stderr";
- else if (NR != ref_nr)
- print "[refcmp] lines: " NR " != " ref_nr > "/dev/stderr";
- if (delta_max >= fuzz)
- print "[refcmp] delta_max: " delta_max " >= " fuzz > "/dev/stderr";
- }
- }
|