Compare similar files with numeric fields
Usage: numdiff -h|--help|-v|--version or
numdiff [-s IFS][-D DELIMS][-a THRVAL[:RANGE|:RANGE1:RANGE2]][-r THRVAL[:RANGE|:RANGE1:RANGE2]][-2][-F NUM][-# NUM][-P][-N][-I][-c CURRNAME][-d C1C2][-t C1C2][-g N1N2][-p C1C2][-n C1C2][-e C1C2][-i C1C2][-X 1:RANGE][-X 2:RANGE][-E][-U][-b][-V][-O[NUM]][-q][-S][-z 1:RANGE][-z 2:RANGE][-Z 1:RANGE][-Z 2:RANGE][-m][-H][-f[NUM]][-T][-B][-l PATH][-o PATH] FILE1 FILE2
Compare putatively similar files line by line and field by field, ignoring small numeric differences or/and different numeric formats.
RANGE, RANGE1 and RANGE2 stay for a positive integer value or for a range of integer values, like 1-, 3-5 or -7. The two arguments after the options are the names of the files to compare. The complete paths of the files should be given, a directory name is not accepted. The given paths cannot refer to the same file but one of them can be "-", which refers to stdin.
Exit status: 1 if files differ, 0 if they are equal, -1 (255) in case of error
-s, --separators=IFS
Specify the set of characters to use as delimiters while splitting the input lines into fields (The default set of delimiters is space, tab and newline). If IFS is prefixed with 1: or 2: then use the given delimiter set only for the lines from the first or the second file respectively
-D, --delimiters=DELIMS
Specify the set of strings to use as delimiters while splitting the input lines into fields (The default set of delimiters is space, tab and newline). If DELIMS is prefixed with 1: or 2: then use the given delimiter set only for the lines from the first or the second file respectively
-a, --absolute-tolerance=THRVAL[:RANGE|:RANGE1:RANGE2]
Set to THRVAL the maximum absolute difference permitted before that two numeric fields are regarded as different (The default value is zero). If a RANGE is given, use the specified threshold only when comparing fields whose positions lie in RANGE. If both RANGE1 and RANGE2 are given and have the same length, then use the specified threshold when comparing a field of FILE1 lying in RANGE1 with the corresponding field of FILE2 in RANGE2
-r, --relative-tolerance=THRVAL[:RANGE|:RANGE1:RANGE2]
Set to THRVAL the maximum relative difference permitted before that two numeric fields are regarded as different (The default value is zero). If a RANGE is given, use the specified threshold only when comparing fields whose positions lie in RANGE. If both RANGE1 and RANGE2 are given and have the same length, then use the specified threshold when comparing a field of FILE1 lying in RANGE1 with the corresponding field of FILE2 in RANGE2
-2, --strict
Consider two numerical values as equal only if both absolute and relative difference do not exceed the corresponding tolerance threshold
-F, --formula=NUM
Use the formula indicated by NUM to compute the relative errors. If 'NUM' is 0 use the classic formula. If 'NUM' is 1 compute the relative errors by considering the values in FILE1 as sample values. If 'NUM' is 2 compute the relative errors by considering the values in FILE2 as sample values.
-#, --digits=NUM
Set to NUM the number of digits in the significands used in multiple precision arithmetic
-P, --positive-differences
Ignore all differences due to numeric fields of the second file that are less than the corresponding numeric fields in the first file
-N, --negative-differences
Ignore all differences due to numeric fields of the second file that are greater than the corresponding numeric fields in the first file
-I, --ignore-case
Ignore changes in case while doing literal comparisons
-c, --currency=CURRNAME
Set to CURRNAME the currency name for the two files to compare. CURRNAME must be prefixed with 1: or 2: to specify the currency name only for the first or the second file
-d, --decimal-point=C1C2
Specify the characters representing the decimal point in the two files to compare
-t, --thousands-separator=C1C2
Specify the characters representing the thousands separator in the two files to compare
-g, --group-length=N1N2
Specify the number of digits forming each group of thousands in the two files to compare
-p, --plus-prefix=C1C2
Specify the (optional) prefixes for positive values used in the two files to compare
-n, --minus-prefix=C1C2
Specify the prefixes for negative values used in the two files to compare
-e, --exponent-letter=C1C2
Specify the exponent letters used in the two files to compare
-i, --imaginary-unit=C1C2
Specify the characters representing the imaginary unit in the two files to compare
-X, --exclude=1:RANGE
Select the fields of the first file that have to be ignored
-X, --exclude=2:RANGE
Select the fields of the second file that have to be ignored
-E, --essential
While printing the differences between the two compared files show only the numerical ones
-U, --dummy
While printing the differences between the two compared files neglect all the numerical ones (dummy mode)
-b, --brief
Suppress all messages concerning the differences discovered in the structures of the two files
-V, --verbose
For every couple of lines which differ in at least one field print an header to show how these lines appear in the two compared files
-O, --overview[=NUM]
Display a side by side difference listing of the two files showing which lines are present only in one file, which lines are present in both files but with one or more differing fields, and which lines are identical. If 'NUM' is zero or is not specified, output at most 130 columns per line. If 'NUM' is a positive number, output at most 'NUM' columns per line. If 'NUM' is a negative number, do not output common lines and display at most -'NUM' columns per line.
-q, --quiet, --silent
Suppress all the standard output
-S, --statistics
Add some statistics to the standard output
-z, --blur-if-numerical=1:RANGE
Select the fields of the first file that have to be blurred during the synchronization procedure only if they turn out to be numeric
-z, --blur-if-numerical=2:RANGE
Select the fields of the second file that have to be blurred during the synchronization procedure only if they turn out to be numeric
-Z, --blur-unconditionally=1:RANGE
Select the fields of the first file that have to be unconditionally blurred during the synchronization procedure
-Z, --blur-unconditionally=2:RANGE
Select the fields of the second file that have to be unconditionally blurred during the synchronization procedure
-m, --minimal
During synchronization try hard to find a smaller set of changes
-H, --speed-large-files
During synchronization assume large files and many scattered small changes
-f, --test-filter[=NUM]
Run only the filter and then show the results of its attempt to synchronize the two files. If 'NUM' is zero or is not specified, output at most 130 columns per line. If 'NUM' is a positive number, output at most 'NUM' columns per line. If 'NUM' is a negative number, do not output common lines and display at most -'NUM' columns per line.
-T, --expand-tabs
Expand tabs to spaces in output while displaying the results of the synchronization procedure (meaningful only together with option -O or -f)
-B, --binary
Treat both files as binary files (only meaningful under Doz/Windoz)
-l, --warnings-to=PATH
Redirect warning and error messages from stderr to the indicated file
-o, --output=PATH
Redirect output from stdout to the indicated file
-h, --help
Show help message and predefined settings
-v, --version
Show version number, Copyright, Distribution Terms and NO-Warranty
Currency name = ""
Decimal point = `.'
Thousands separator = `,'
Number of digits in each thousands group = 3
Leading positive sign = `+'
Leading negative sign = `-'
Prefix for decimal exponent = `e'
Symbol used to denote the imaginary unit = `i'
Copyright © 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013 Ivano Primi <[email protected]>
License GPLv3+: GNU GPL version 3 or later, see <http://gnu.org/licenses/gpl.html>.
This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law.
The full documentation for numdiff is maintained as a Texinfo manual. If the info and numdiff programs are properly installed at your site, the command
info numdiff
should give you access to the complete manual.