-
Notifications
You must be signed in to change notification settings - Fork 4
/
run.sh
executable file
·73 lines (55 loc) · 2.52 KB
/
run.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/bin/bash
## Import functions for workflow management.
## Get the path to this function:
execpath="$0"
scriptpath="$(dirname "$execpath")/ncap_utils"
source "$scriptpath/workflow.sh"
## Import functions for data transfer
source "$scriptpath/transfer.sh"
## Set up error logging.
errorlog
## Declare variables: bucketname,inputpath,grouppath,resultpath,dataname,configname given standard arguments to bin script.
parseargsstd "$1" "$2" "$3" "$4"
## Declare local storage locations:
userhome="/home/ubuntu"
datastore="ncapdata/localdata/"
outstore="ncapdata/localdata/analysis_vids/"
## Make local storage locations
accessdir "$userhome/$datastore" "$userhome/$outstore"
###############################################################################################
## Custom setup for this workflow.
source .dlamirc
export PATH="/home/ubuntu/anaconda3/bin:$PATH"
source activate dlcami
###############################################################################################
## Stereotyped download script for data. The only reason this comes after something custom is because we depend upon the AWS CLI and installed credentials.
echo "$inputpath"
download "$inputpath" "$bucketname" "$datastore"
## Stereotyped download script for config:
echo "$inputpath/$dataname"
download "$configpath" "$bucketname" "$datastore"
###############################################################################################
## Import variables from the configuration file:
read -r XS XA YS YA <<< $(jq -r .Coordinates[] "$userhome/$datastore/$configname")
read -r ext <<< $(jq -r .Ext "$userhome/$datastore/$configname")
#preprocess videos:
cd "$userhome/$datastore/"
counter=0
for i in ./*"$ext" ; do
filenamenoext="$(basename "${i/"$ext"}")"
ffmpeg -y -i "$i" -c copy -f "${ext#"."}" needle.h264
ffmpeg -y -r 40 -i needle.h264 -c copy "conv""$filenamenoext".mp4
ffmpeg -i "conv""$filenamenoext".mp4 -filter:v "crop=$XA:$YA:$XS:$YS" "$filenamenoext""cropped.mp4"
echo "file "$filenamenoext"cropped.mp4" >> output.txt
rm needle.h264
done
ffmpeg -f concat -i output.txt -vcodec copy -acodec copy "analysis_vids/$((counter+1))"$filenamenoext"Final.mp4"
## Run deeplabcut analysis:
cd ../../DeepLabCut/Analysis-tools
python AnalyzeVideos_new.py
cd "$userhome"
## Custom bulk processing.
###############################################################################################
## Stereotyped upload script for the data
echo "$outstore" "$bucketname" "$groupdir" "$resultdir" "mp4"
upload "$outstore" "$bucketname" "$groupdir" "$resultdir" "mp4"