Compare commits
	
		
			13 Commits
		
	
	
		
			nilmtools-
			...
			python2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0cf2db6c5e | |||
| f530edd8a0 | |||
| 4d946bee79 | |||
| 13ceb91999 | |||
| dab9625296 | |||
| 3e7527ab57 | |||
| 31b6d82dfc | |||
| 077010ba3a | |||
| 77751a8529 | |||
| 9c711300a2 | |||
| 74cf34e2ad | |||
| 120bf58b85 | |||
| c26daa9a3b | 
							
								
								
									
										22
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,14 +1,14 @@ | |||||||
| #URL="http://bucket.mit.edu:8080/nilmdb" | #URL="http://bucket.mit.edu:8080/nilmdb" | ||||||
| URL="http://localhost/nilmdb" | URL="http://localhost/nilmdb" | ||||||
|  |  | ||||||
| all: | all: test | ||||||
| ifeq ($(INSIDE_EMACS), t) |  | ||||||
| 	@make test |  | ||||||
| else |  | ||||||
| 	@echo "Try 'make install'" |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| test: test_trainola3 | test: | ||||||
|  | ifeq ($(INSIDE_EMACS), t) | ||||||
|  | 	@make test_sinefit | ||||||
|  | else | ||||||
|  | 	@echo 'No test suite for nilmtools.  Try "make install"' | ||||||
|  | endif | ||||||
|  |  | ||||||
| test_pipewatch: | test_pipewatch: | ||||||
| 	nilmtools/pipewatch.py -t 3 "seq 10 20" "seq 20 30" | 	nilmtools/pipewatch.py -t 3 "seq 10 20" "seq 20 30" | ||||||
| @@ -58,6 +58,14 @@ test_prep: /tmp/raw.dat | |||||||
| 	nilmtools/prep.py -c 2 /test/raw /test/sinefit /test/prep | 	nilmtools/prep.py -c 2 /test/raw /test/sinefit /test/prep | ||||||
| 	nilmtool extract -s min -e max /test/prep | head -20 | 	nilmtool extract -s min -e max /test/prep | head -20 | ||||||
|  |  | ||||||
|  | test_sinefit: | ||||||
|  | 	make install >/dev/null 2>&1 | ||||||
|  | 	-nilmtool destroy -R /test/sinefit | ||||||
|  | 	nilmtool create /test/sinefit float32_3 | ||||||
|  | 	nilmtools/sinefit.py -c 5 -s '2013/03/25 09:11:00' \ | ||||||
|  | 	-e '2013/03/25 10:11:00' /sharon/raw /test/sinefit | ||||||
|  | 	nilmtool extract -s min -e max /test/sinefit | head -20 | ||||||
|  |  | ||||||
| test_decimate: | test_decimate: | ||||||
| 	-@nilmtool destroy /lees-compressor/no-leak/raw/4 || true | 	-@nilmtool destroy /lees-compressor/no-leak/raw/4 || true | ||||||
| 	-@nilmtool destroy /lees-compressor/no-leak/raw/16 || true | 	-@nilmtool destroy /lees-compressor/no-leak/raw/16 || true | ||||||
|   | |||||||
| @@ -6,3 +6,4 @@ keep = 2w | |||||||
|  |  | ||||||
| [/sharon/sinefit] | [/sharon/sinefit] | ||||||
| keep = 1y | keep = 1y | ||||||
|  | decimated = false | ||||||
|   | |||||||
| @@ -1,9 +1,15 @@ | |||||||
| # Install this by running "crontab crontab" (will replace existing crontab) | # Install this by running "crontab crontab" (will replace existing crontab) | ||||||
|  |  | ||||||
|  | SHELL=/bin/bash | ||||||
|  | PATH=/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin | ||||||
|  |  | ||||||
| # m h dom mon dow cmd | # m h dom mon dow cmd | ||||||
|  |  | ||||||
| # Run NilmDB processing every 5 minutes | # Run NilmDB processing every 5 minutes | ||||||
| */5 * * * * chronic /home/nilm/data/process.sh | */5 * * * * chronic /home/nilm/data/process.sh | ||||||
|  |  | ||||||
| # Check the capture process every minute | # Try frequently restarting the capture process in case it died | ||||||
| */1 * * * * chronic /home/nilm/data/capture.sh | */5 * * * * chronic /home/nilm/data/capture.sh | ||||||
|  |  | ||||||
|  | # Run fsck at startup | ||||||
|  | @reboot chronic nilmdb-fsck --fix --no-data /home/nilm/data/db/ | ||||||
|   | |||||||
| @@ -12,6 +12,8 @@ import sys | |||||||
| def main(argv = None): | def main(argv = None): | ||||||
|     f = nilmtools.filter.Filter() |     f = nilmtools.filter.Filter() | ||||||
|     parser = f.setup_parser("Copy a stream") |     parser = f.setup_parser("Copy a stream") | ||||||
|  |     parser.add_argument('-n', '--nometa', action='store_true', | ||||||
|  |                         help="Don't copy or check metadata") | ||||||
|  |  | ||||||
|     # Parse arguments |     # Parse arguments | ||||||
|     try: |     try: | ||||||
| @@ -25,6 +27,7 @@ def main(argv = None): | |||||||
|         raise SystemExit(1) |         raise SystemExit(1) | ||||||
|  |  | ||||||
|     # Copy metadata |     # Copy metadata | ||||||
|  |     if not args.nometa: | ||||||
|         meta = f.client_src.stream_get_metadata(f.src.path) |         meta = f.client_src.stream_get_metadata(f.src.path) | ||||||
|         f.check_dest_metadata(meta) |         f.check_dest_metadata(meta) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,6 +16,8 @@ def main(argv = None): | |||||||
|  |  | ||||||
|     Example: %(prog)s -u http://host1/nilmdb -U http://host2/nilmdb /sharon/* |     Example: %(prog)s -u http://host1/nilmdb -U http://host2/nilmdb /sharon/* | ||||||
|     """, skip_paths = True) |     """, skip_paths = True) | ||||||
|  |     parser.add_argument('-n', '--nometa', action='store_true', | ||||||
|  |                         help="Don't copy or check metadata") | ||||||
|     parser.add_argument("path", action="store", nargs="+", |     parser.add_argument("path", action="store", nargs="+", | ||||||
|                         help='Wildcard paths to copy') |                         help='Wildcard paths to copy') | ||||||
|     args = parser.parse_args(argv) |     args = parser.parse_args(argv) | ||||||
| @@ -56,6 +58,8 @@ def main(argv = None): | |||||||
|             new_argv.extend(["--end", "@" + repr(args.end)]) |             new_argv.extend(["--end", "@" + repr(args.end)]) | ||||||
|         if args.dry_run: |         if args.dry_run: | ||||||
|             new_argv.extend(["--dry-run"]) |             new_argv.extend(["--dry-run"]) | ||||||
|  |         if args.nometa: | ||||||
|  |             new_argv.extend(["--nometa"]) | ||||||
|         if args.force_metadata: |         if args.force_metadata: | ||||||
|             new_argv.extend(["--force-metadata"]) |             new_argv.extend(["--force-metadata"]) | ||||||
|         new_argv.extend([stream[0], stream[0]]) |         new_argv.extend([stream[0], stream[0]]) | ||||||
|   | |||||||
| @@ -21,9 +21,9 @@ def main(argv = None): | |||||||
|     parser.add_argument("-u", "--url", action="store", |     parser.add_argument("-u", "--url", action="store", | ||||||
|                         default="http://localhost/nilmdb/", |                         default="http://localhost/nilmdb/", | ||||||
|                         help="NilmDB server URL (default: %(default)s)") |                         help="NilmDB server URL (default: %(default)s)") | ||||||
|     parser.add_argument('-f', '--factor', action='store', default=4, type=int, |     parser.add_argument("-f", "--factor", action="store", default=4, type=int, | ||||||
|                         help='Decimation factor (default: %(default)s)') |                         help='Decimation factor (default: %(default)s)') | ||||||
|     parser.add_argument("--force-metadata", action="store_true", |     parser.add_argument("-F", "--force-metadata", action="store_true", | ||||||
|                         default = False, |                         default = False, | ||||||
|                         help="Force metadata changes if the dest " |                         help="Force metadata changes if the dest " | ||||||
|                         "doesn't match") |                         "doesn't match") | ||||||
|   | |||||||
| @@ -206,7 +206,7 @@ class Filter(object): | |||||||
|                            default = False, |                            default = False, | ||||||
|                            help="Just print intervals that would be " |                            help="Just print intervals that would be " | ||||||
|                            "processed") |                            "processed") | ||||||
|         group.add_argument("--force-metadata", action="store_true", |         group.add_argument("-F", "--force-metadata", action="store_true", | ||||||
|                            default = False, |                            default = False, | ||||||
|                            help="Force metadata changes if the dest " |                            help="Force metadata changes if the dest " | ||||||
|                            "doesn't match") |                            "doesn't match") | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ def parse_args(argv = None): | |||||||
|       is stepped forward to match 'clock'. |       is stepped forward to match 'clock'. | ||||||
|  |  | ||||||
|     - If 'data' is running ahead, there is overlap in the data, and an |     - If 'data' is running ahead, there is overlap in the data, and an | ||||||
|       error is raised.  If '--ignore' is specified, the current file |       error is raised.  If '--skip' is specified, the current file | ||||||
|       is skipped instead of raising an error. |       is skipped instead of raising an error. | ||||||
|     """)) |     """)) | ||||||
|     parser.add_argument("-u", "--url", action="store", |     parser.add_argument("-u", "--url", action="store", | ||||||
|   | |||||||
| @@ -37,6 +37,7 @@ def sfit4(data, fs): | |||||||
|     i = argmax(F[0:int(N/2)] + F[1:int(N/2+1)]) |     i = argmax(F[0:int(N/2)] + F[1:int(N/2+1)]) | ||||||
|  |  | ||||||
|     # Interpolate FFT to get a better result (from Markus [B37]) |     # Interpolate FFT to get a better result (from Markus [B37]) | ||||||
|  |     try: | ||||||
|         U1 = real(Fc[i]) |         U1 = real(Fc[i]) | ||||||
|         U2 = real(Fc[i+1]) |         U2 = real(Fc[i+1]) | ||||||
|         V1 = imag(Fc[i]) |         V1 = imag(Fc[i]) | ||||||
| @@ -48,6 +49,9 @@ def sfit4(data, fs): | |||||||
|         Z1 = V1 * (K - cos(ni1)) / sin(ni1) + U1 |         Z1 = V1 * (K - cos(ni1)) / sin(ni1) + U1 | ||||||
|         Z2 = V2 * (K - cos(ni2)) / sin(ni2) + U2 |         Z2 = V2 * (K - cos(ni2)) / sin(ni2) + U2 | ||||||
|         i = arccos((Z2*cos(ni2) - Z1*cos(ni1)) / (Z2-Z1)) / n |         i = arccos((Z2*cos(ni2) - Z1*cos(ni1)) / (Z2-Z1)) / n | ||||||
|  |     except Exception: | ||||||
|  |         # Just go with the biggest FFT peak | ||||||
|  |         i = argmax(F[0:int(N/2)]) | ||||||
|  |  | ||||||
|     # Convert to Hz |     # Convert to Hz | ||||||
|     f0 = i * float(fs) / N |     f0 = i * float(fs) / N | ||||||
|   | |||||||
| @@ -81,7 +81,8 @@ def main(argv = None): | |||||||
|     f.check_dest_metadata({ "prep_raw_source": f.src.path, |     f.check_dest_metadata({ "prep_raw_source": f.src.path, | ||||||
|                             "prep_sinefit_source": sinefit.path, |                             "prep_sinefit_source": sinefit.path, | ||||||
|                             "prep_column": args.column, |                             "prep_column": args.column, | ||||||
|                             "prep_rotation": repr(rotation) }) |                             "prep_rotation": repr(rotation), | ||||||
|  |                             "prep_nshift": args.nshift }) | ||||||
|  |  | ||||||
|     # Find the intersection of the usual set of intervals we'd filter, |     # Find the intersection of the usual set of intervals we'd filter, | ||||||
|     # and the intervals actually present in sinefit data.  This is |     # and the intervals actually present in sinefit data.  This is | ||||||
|   | |||||||
| @@ -96,8 +96,11 @@ def process(data, interval, args, insert_function, final): | |||||||
|     rows = data.shape[0] |     rows = data.shape[0] | ||||||
|  |  | ||||||
|     # Estimate sampling frequency from timestamps |     # Estimate sampling frequency from timestamps | ||||||
|     fs = (rows-1) / (timestamp_to_seconds(data[-1][0]) - |     ts_min = timestamp_to_seconds(data[0][0]) | ||||||
|                      timestamp_to_seconds(data[0][0])) |     ts_max = timestamp_to_seconds(data[-1][0]) | ||||||
|  |     if ts_min >= ts_max: | ||||||
|  |         return 0 | ||||||
|  |     fs = (rows-1) / (ts_max - ts_min) | ||||||
|  |  | ||||||
|     # Pull out about 3.5 periods of data at once; |     # Pull out about 3.5 periods of data at once; | ||||||
|     # we'll expect to match 3 zero crossings in each window |     # we'll expect to match 3 zero crossings in each window | ||||||
|   | |||||||
| @@ -287,8 +287,21 @@ def main(argv = None): | |||||||
|  |  | ||||||
|     if argv is None: |     if argv is None: | ||||||
|         argv = sys.argv[1:] |         argv = sys.argv[1:] | ||||||
|  |     if len(argv) != 1 or argv[0] == '-h' or argv[0] == '--help': | ||||||
|  |         printf("usage: %s [-h] [-v] <json-config-dictionary>\n\n", sys.argv[0]) | ||||||
|  |         printf("  Where <json-config-dictionary> is a JSON-encoded " + | ||||||
|  |                "dictionary string\n") | ||||||
|  |         printf("  with exemplar and stream data.\n\n") | ||||||
|  |         printf("  See extras/trainola-test-param*.js in the nilmtools " + | ||||||
|  |                "repository\n") | ||||||
|  |         printf("  for examples.\n") | ||||||
|         if len(argv) != 1: |         if len(argv) != 1: | ||||||
|         raise DataError("need one argument, either a dictionary or JSON string") |             raise SystemExit(1) | ||||||
|  |         raise SystemExit(0) | ||||||
|  |  | ||||||
|  |     if argv[0] == '-v' or argv[0] == '--version': | ||||||
|  |         printf("%s\n", nilmtools.__version__) | ||||||
|  |         raise SystemExit(0) | ||||||
|  |  | ||||||
|     try: |     try: | ||||||
|         # Passed in a JSON string (e.g. on the command line) |         # Passed in a JSON string (e.g. on the command line) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user