Compare commits
	
		
			10 Commits
		
	
	
		
			nilmtools-
			...
			nilmtools-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 3e7527ab57 | |||
| 31b6d82dfc | |||
| 077010ba3a | |||
| 77751a8529 | |||
| 9c711300a2 | |||
| 74cf34e2ad | |||
| 120bf58b85 | |||
| c26daa9a3b | |||
| 6993f5c886 | |||
|   | dd69f3e51d | 
							
								
								
									
										14
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								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_trainola3 | ||||||
|  | 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" | ||||||
|   | |||||||
| @@ -6,3 +6,4 @@ keep = 2w | |||||||
|  |  | ||||||
| [/sharon/sinefit] | [/sharon/sinefit] | ||||||
| keep = 1y | keep = 1y | ||||||
|  | decimated = false | ||||||
|   | |||||||
| @@ -5,5 +5,5 @@ | |||||||
| # 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 | ||||||
|   | |||||||
| @@ -13,16 +13,20 @@ if ! flock -n -x 99 ; then | |||||||
| fi | fi | ||||||
| trap 'rm -f "$LOCKFILE"' 0 | trap 'rm -f "$LOCKFILE"' 0 | ||||||
|  |  | ||||||
| # sinefit on phase A voltage | # redirect stdout/stderr to log, but keep it on the console too | ||||||
|  | exec >  >(tee /home/nilm/data/process.log) | ||||||
|  | exec 2> >(tee -a /home/nilm/data/process.log >&2) | ||||||
|  |  | ||||||
|  | echo "sinefit on phase A voltage" | ||||||
| nilm-sinefit -c 5 /sharon/raw /sharon/sinefit | nilm-sinefit -c 5 /sharon/raw /sharon/sinefit | ||||||
|  |  | ||||||
| # prep on A, B, C with appropriate rotations | echo "prep on A, B, C with appropriate rotations" | ||||||
| nilm-prep -c 1 -r 0 /sharon/raw /sharon/sinefit /sharon/prep-a | nilm-prep -c 1 -r 0 /sharon/raw /sharon/sinefit /sharon/prep-a | ||||||
| nilm-prep -c 2 -r 120 /sharon/raw /sharon/sinefit /sharon/prep-b | nilm-prep -c 2 -r 120 /sharon/raw /sharon/sinefit /sharon/prep-b | ||||||
| nilm-prep -c 3 -r 240 /sharon/raw /sharon/sinefit /sharon/prep-c | nilm-prep -c 3 -r 240 /sharon/raw /sharon/sinefit /sharon/prep-c | ||||||
|  |  | ||||||
| # decimate raw and prep data | echo "decimate raw and prep data" | ||||||
| nilm-decimate-auto /sharon/raw /sharon/prep* | nilm-decimate-auto /sharon/raw /sharon/prep* | ||||||
|  |  | ||||||
| # run cleanup | echo "run cleanup" | ||||||
| nilm-cleanup --yes /home/nilm/data/cleanup.cfg | nilm-cleanup --yes /home/nilm/data/cleanup.cfg | ||||||
|   | |||||||
| @@ -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", | ||||||
|   | |||||||
| @@ -84,13 +84,16 @@ def pipewatch(args): | |||||||
|                                      bufsize = -1, close_fds = True, |                                      bufsize = -1, close_fds = True, | ||||||
|                                      stdin = devnull, |                                      stdin = devnull, | ||||||
|                                      stdout = subprocess.PIPE, |                                      stdout = subprocess.PIPE, | ||||||
|                                      stderr = None) |                                      stderr = None, | ||||||
|  |                                      preexec_fn = os.setpgrp) | ||||||
|         consumer = subprocess.Popen(args.consumer, shell = True, |         consumer = subprocess.Popen(args.consumer, shell = True, | ||||||
|                                     bufsize = -11, close_fds = True, |                                     bufsize = -11, close_fds = True, | ||||||
|                                     stdin = subprocess.PIPE, |                                     stdin = subprocess.PIPE, | ||||||
|                                     stdout = None, stderr = None) |                                     stdout = None, | ||||||
|  |                                     stderr = None, | ||||||
|  |                                     preexec_fn = os.setpgrp) | ||||||
|  |  | ||||||
|         queue = Queue.Queue(maxsize = 32) |         queue = Queue.Queue(maxsize = 4) | ||||||
|         reader = threading.Thread(target = reader_thread, |         reader = threading.Thread(target = reader_thread, | ||||||
|                                   args = (queue, generator.stdout.fileno())) |                                   args = (queue, generator.stdout.fileno())) | ||||||
|         reader.start() |         reader.start() | ||||||
| @@ -125,16 +128,21 @@ def pipewatch(args): | |||||||
|                 return proc.poll() |                 return proc.poll() | ||||||
|             try: |             try: | ||||||
|                 if poll_timeout(proc, 0.5) is None: |                 if poll_timeout(proc, 0.5) is None: | ||||||
|                     proc.terminate() |                     os.killpg(proc.pid, signal.SIGTERM) | ||||||
|                     if poll_timeout(proc, 0.5) is None: |                     if poll_timeout(proc, 0.5) is None: | ||||||
|                         proc.kill() |                         os.killpg(proc.pid, signal.SIGKILL) | ||||||
|             except OSError: |             except OSError: | ||||||
|                 pass |                 pass | ||||||
|             return poll_timeout(proc, 0.5) |             return poll_timeout(proc, 0.5) | ||||||
|  |  | ||||||
|         # Wait for them to die, or kill them |         # Wait for them to die, or kill them | ||||||
|         gret = kill(generator) |  | ||||||
|         cret = kill(consumer) |         cret = kill(consumer) | ||||||
|  |         gret = kill(generator) | ||||||
|  |  | ||||||
|  |         # Consume all remaining data in the queue until the reader | ||||||
|  |         # and watcher threads are done | ||||||
|  |         while reader.is_alive() or watcher.is_alive(): | ||||||
|  |             queue.get(True, 0.1) | ||||||
|  |  | ||||||
|         fprintf(sys.stderr, "pipewatch: generator returned %d, " + |         fprintf(sys.stderr, "pipewatch: generator returned %d, " + | ||||||
|                 "consumer returned %d\n", gret, cret) |                 "consumer returned %d\n", gret, cret) | ||||||
|   | |||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -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