User Tools

Site Tools


sift:tutorials:command_line

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
sift:tutorials:command_line [2024/09/25 14:29] sgrangersift:tutorials:command_line [2025/02/06 16:33] (current) sgranger
Line 1: Line 1:
 ======Batch Command Line Processing Tutorial====== ======Batch Command Line Processing Tutorial======
-In this tutorial, we will guide you through running Sift on the command line. You'll learn how to load a library, execute queries, run PCA (Principal Component Analysis), and use it for outlier detection. After walking through each command step by step, we’ll create a batch script to automate these tasks. We'll also include some logic to further streamline the process. To get started, download the sample data folder. {{automation_tutorial.zip}}+In this tutorial, we will guide you through running Sift on the command line. You'll learn how to load a library, execute queries, run PCA (Principal Component Analysis), and use it for outlier detection. After walking through each command step by step, we’ll create a batch script to automate these tasks. We'll also include some logic to further streamline the process. To get started, download the sample data folder. {{:automation_tutorial.zip}}
  
 =====Running on Command Line===== =====Running on Command Line=====
   - First, we need to run Sift via the command line. On your keyboard, press Windows Key + R, type "cmd" into the run window, and press Enter to open a command prompt. \\ {{:windows_run_dialog.png}}   - First, we need to run Sift via the command line. On your keyboard, press Windows Key + R, type "cmd" into the run window, and press Enter to open a command prompt. \\ {{:windows_run_dialog.png}}
   - Next, navigate to Sift's installation directory. \\ {{:change_directory.png}}   - Next, navigate to Sift's installation directory. \\ {{:change_directory.png}}
-  - To launch Sift, call the .exe file and pass the --NoGUI argument \\ {{:launch_sift.png}}+  - To launch Sift, call the .exe file and pass the -NoGUI argument \\ {{:launch_sift.png}}
   - This will open new console where we can interact with Sift   - This will open new console where we can interact with Sift
-  - In this console, load a library by entering the command: //--LoadLib directory "**Path to downloaded library**"// \\ {{:cl_load_lib.png}} +  - In this console, load a library by entering the command: //-LoadLib directory "**Path to downloaded library**"// \\ {{:cl_load_lib.png}} 
-  - Next load and run a predefined query by entering: //--LoadQuery file "**Path to query definition file**"// \\ {{:cl_load_query.png}} +  - Next load and run a predefined query by entering: //-LoadQuery file "**Path to query definition file**"// \\ {{:cl_load_query.png}} 
-  - Select all signals by running //--SelectSignals// (Ensure all signal groups and work-spaces have been selected) \\ {{:cl_select_signals.png}} +  - Select all signals by running //-SelectSignals// (Ensure all signal groups and work-spaces have been selected) \\ {{:cl_select_signals.png}} 
-  - Run a PCA named "Outlier_PCA" //--RunPCA name "Outlier_PCA"// \\ {{:cl_run_pca.png}} +  - Run a PCA named "Outlier_PCA" //-RunPCA name "Outlier_PCA"// \\ {{:cl_run_pca.png}} 
-  - Now, let's perform the first round of outlier detection. Run a Local Outlier Factor (LOF) test with the command: //--RunLOF grouping "group" autoExclude// This will find any group level outliers and exclude them automatically \\ {{:cl_lof_one.png}} +  - Now, let's perform the first round of outlier detection. Run a Local Outlier Factor (LOF) test with the command: //-RunLOF grouping "group" autoExclude// This will find any group level outliers and exclude them automatically \\ {{:cl_lof_one.png}} 
-  - To export the results of this LOF test, run: //--ExportPCA file "Path to exported txt file" exportFormat "transposed" LOF LOFThrehsold// \\ {{:cl_export_group_outliers.png}} +  - To export the results of this LOF test, run: //-ExportPCA file "Path to exported txt file" exportFormat "transposed" LOF LOFThrehsold// \\ {{:cl_export_group_outliers.png}} 
-  - Next, run another LOF test, this time on workspaces: //--RunLOF grouping "workspace" autoExclude// \\ {{:cl_lof_workspace.png}} +  - Next, run another LOF test, this time on workspaces: //-RunLOF grouping "workspace" autoExclude// \\ {{:cl_lof_workspace.png}} 
-  - Export the results of this LOF test as well: //--ExportPCA file "Path to exported txt file" exportFormat "transposed" LOF LOFThreshold// \\ {{:cl_export_workspace_outliers.png}} +  - Export the results of this LOF test as well: //-ExportPCA file "Path to exported txt file" exportFormat "transposed" LOF LOFThreshold// \\ {{:cl_export_workspace_outliers.png}} 
-  - Finally, save the project to allow for future review in the GUI, if needed: //--SaveProject file "Path to saved project"// \\ {{:cl_save_project.png}}+  - Finally, save the project to allow for future review in the GUI, if needed: //-SaveProject file "Path to saved project"// \\ {{:cl_save_project.png}}
 Now that processing is complete, we have two exports detailing group and workspace-level outliers, along with a saved project file that excludes all detected outliers. This can serve as a baseline for future processing. Now that processing is complete, we have two exports detailing group and workspace-level outliers, along with a saved project file that excludes all detected outliers. This can serve as a baseline for future processing.
  
Line 31: Line 31:
 setlocal setlocal
  
 +:: Set the target directory where the practice data is stored
 set "targetDir=C:\Users\shane\OneDrive\Documents\practice" set "targetDir=C:\Users\shane\OneDrive\Documents\practice"
  
 +:: Loop through each folder (%%d) in the target directory
 for /D %%d in ("%targetDir%\*") do ( for /D %%d in ("%targetDir%\*") do (
 +    
 +    :: Reset the flag to check if an i3d file exists
     set "i3dFileFound="     set "i3dFileFound="
 +    
 +    :: Loop through each .i3d file in the current folder
     for %%f in ("%%d\*.i3d") do (     for %%f in ("%%d\*.i3d") do (
 +        
 +        :: If an i3d file is found, set the flag to true
         if exist "%%f" (         if exist "%%f" (
             set "i3dFileFound=true"             set "i3dFileFound=true"
Line 41: Line 49:
     )     )
          
 +    :: If no i3d file was found, process the folder
     if not defined i3dFileFound (     if not defined i3dFileFound (
 +        
 +        :: Set the folder path that needs processing
         set "folderWithoutI3d=%%d"         set "folderWithoutI3d=%%d"
-        "C:\Program Files (x86)\Sift\Sift.exe" --NoGui --LoadLib directory "%%d" --LoadQuery file "%%d\query_definition.q3d" --selectSignals --RunPCA name "Outlier_PCA" --RunLOF grouping "group" autoExclude --ExportPCA file "%%d\Group Outliers.txt" exportFormat "transposed" lof lofThreshold --RunLOF grouping "workspace" autoExclude --ExportPCA file "%%d\Workspace Outliers.txt" exportFormat "transposed" lof lofThreshold --SaveProject file "%%d\Outliers.i3d" --Exit+         
 +        :: Run Sift with the necessary commands to process the data 
 +        "C:\Program Files\Sift\Sift.exe" -NoGui -LoadLib directory "%%d" -LoadQuery file "%%d\query_definition.q3d" -selectSignals -RunPCA name "Outlier_PCA" -RunLOF grouping "group" autoExclude -ExportPCA file "%%d\Group Outliers.txt" exportFormat "transposed" lof lofThreshold -RunLOF grouping "workspace" autoExclude -ExportPCA file "%%d\Workspace Outliers.txt" exportFormat "transposed" lof lofThreshold -SaveProject file "%%d\Outliers.i3d" -Exit
     )     )
 ) )
  
 +:: End the script and clean up
 endlocal endlocal
 </code> </code>
  
 ====The Execution==== ====The Execution====
-Now that we have script ready to goexecuting our processing will be as easy as double clicking the .bat file, but we can take the automation even further! Leveraging windows Task Scheduler we can set the batch script to execute at a certain time each day+Now that we have our script ready, running the processing is as simple as double-clicking the .bat file. But we can take the automation a step further! By using Windows Task Schedulerwe can set the batch script to run at a specific time each day automatically.
   - Open the start menu and type Task Scheduler into the search bar \\ {{:cl_search_bar.png?500}}   - Open the start menu and type Task Scheduler into the search bar \\ {{:cl_search_bar.png?500}}
-  - Open Task Scheduler \\ {{:cl_search_scheduler.png?500}} +  - Open Task Scheduler from the search results. \\ {{:cl_search_scheduler.png?500}} 
-  - In the Task Scheduler select create basic task in the top right of the screen \\ {{:cl_scheduler.png?700}}  +  - In Task Schedulerselect **Create Basic Task** from the top-right of the screen\\ {{:cl_scheduler.png?700}}  
-  - In the popup dialog enter a meaningful name in this case we went with "Baseline Processing" press next \\ {{:cl_name_task.png?700}} +  - In the popup dialogenter a meaningful name (in this casewe used "Baseline Processing") and press **Next**. \\ {{:cl_name_task.png?700}} 
-  - In the next step ensure daily is selected and press next \\ {{:cl_daily_task.png?700}} +  - On the next screen, select **Daily** and press **Next**. \\ {{:cl_daily_task.png?700}} 
-  - Next select what time of day you would like the task to run, we picked 12:00AM \\ {{:cl_task_time.png?700}} +  - Now, choose the time of day you'like the task to run. We selected 12:00 AM. \\ {{:cl_task_time.png?700}} 
-  - In the next step ensure start program is selected and press next \\ {{:cl_start_program.png?700}} +  - Ensure Start Program is selected on the next screen and press **Next**. \\ {{:cl_start_program.png?700}} 
-  - Now we will browse and select the batch script we created \\ {{:cl_pick_script.png?700}} +  - Browse and select the batch script you created earlier. \\ {{:cl_pick_script.png?700}} 
-  - On the final screen review and press finish \\ {{:cl_finish_task.png?700}} +  - On the final screenreview your settings and press **Finish**. \\ {{:cl_finish_task.png?700}} 
-  - Finally check the existing task to ensure it has been created successfully \\ {{:cl_all_done.png?700}} +  - Lastly, check the list of existing tasks to confirm it was created successfully\\ {{:cl_all_done.png?700}} 
-Now we are finished! We have set it up so our script will execute every night at 12:00AM with no need for any user input at all! +That'it! Your script is now set to run every night at 12:00 AM automatically, with no further input required from you.
sift/tutorials/command_line.1727274553.txt.gz · Last modified: 2024/09/25 14:29 by sgranger