From 23e665000e876f9ff8b521a060b0cdb7e58287cb Mon Sep 17 00:00:00 2001 From: jvech Date: Thu, 17 Aug 2023 09:09:01 -0500 Subject: [ADD]: Cli implemented in a different function The program config parameters where encapsulated in a struct to keep track of them without implementing a lot of functions --- src/main.c | 88 +++++--------------------------------------------------------- 1 file changed, 6 insertions(+), 82 deletions(-) (limited to 'src/main.c') diff --git a/src/main.c b/src/main.c index 683447f..0071426 100644 --- a/src/main.c +++ b/src/main.c @@ -16,33 +16,6 @@ typedef struct Array { #define ARRAY_SIZE(x, type) sizeof(x) / sizeof(type) -static void version() -{ - printf("ml 0.1\n"); - printf("Written by vech\n"); - exit(0); -} - -static void usage(int exit_code) -{ - FILE *fp = (!exit_code) ? stdout : stderr; - fprintf(fp, - "Usage: ml train [Options] JSON_FILE\n" - " or: ml predict [-o FILE] FILE\n" - "Train and predict json data\n" - "\n" - "Options:\n" - " -a, --alpha=ALPHA Learning rate (only works with train) [default: 1e-5]\n" - " -e, --epochs=EPOCHS Number of epochs to train the model (only works with train)\n" - " [default: 100]\n" - " -o, --output FILE Output file (only works with predict)\n" - "\n" - "Examples:\n" - " $ ml train -e 150 -a 1e-4 housing.json\n" - " $ ml predict housing.json -o predictions.json\n" - ); - exit(exit_code); -} static void json_read(const char *filepath, Array *input, Array *out, @@ -116,61 +89,12 @@ json_read_error: } int main(int argc, char *argv[]) { - - char **input_keys, **label_keys; - int in_key_size = 0, label_key_size = 0; - char *out_filename = NULL, *in_filename = NULL; - size_t epochs = 100; - double alpha = 1e-5; - - if (argc <= 1) usage(1); - static struct option long_opts[] = { - {"help", no_argument, 0, 'h'}, - {"version", no_argument, 0, 'v'}, - {"epochs", required_argument, 0, 'e'}, - {"alpha", required_argument, 0, 'a'}, - {"output", required_argument, 0, 'o'}, - {0, 0, 0, 0 }, + struct Configs ml_configs = { + .epochs = 100, + .alpha = 1e-5, + .config_filepath = "utils/config.yml", }; - int c; - - while (1) { - c = getopt_long(argc, argv, "hve:a:o:i:l:", long_opts, NULL); - - if (c == -1) { - break; - } - switch (c) { - case 'e': - epochs = (size_t)atol(optarg); - break; - case 'a': - alpha = (double)atof(optarg); - break; - case 'o': - out_filename = optarg; - break; - case 'h': - usage(0); - case 'v': - version(); - default: - usage(1); - } - } - - argv += optind; - argc -= optind; - if (argc != 2) usage(1); - - in_filename = argv[1]; - - if (!strcmp(argv[0], "train")) { - printf("train command\n"); - printf("in_filename: '%s'\n", in_filename); - } else if (!strcmp(argv[0], "predict")) { - } else { - usage(1); - } + util_load_config(&ml_configs); + util_load_cli(&ml_configs, argc, argv); return 0; } -- cgit v1.2.3-70-g09d2