# ~/.bashrc: executed by bash(1) for non-login shells. # see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) # for examples # If not running interactively, don't do anything case $- in *i*) ;; *) return;; esac # don't put duplicate lines or lines starting with space in the history. # See bash(1) for more options HISTCONTROL=ignoreboth # append to the history file, don't overwrite it shopt -s histappend # for setting history length see HISTSIZE and HISTFILESIZE in bash(1) HISTSIZE=1000 HISTFILESIZE=2000 # check the window size after each command and, if necessary, # update the values of LINES and COLUMNS. shopt -s checkwinsize # If set, the pattern "**" used in a pathname expansion context will # match all files and zero or more directories and subdirectories. #shopt -s globstar # make less more friendly for non-text input files, see lesspipe(1) [ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)" # set variable identifying the chroot you work in (used in the prompt below) if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then debian_chroot=$(cat /etc/debian_chroot) fi # set a fancy prompt (non-color, unless we know we "want" color) case "$TERM" in xterm-color|*-256color) color_prompt=yes;; esac # uncomment for a colored prompt, if the terminal has the capability; turned # off by default to not distract the user: the focus in a terminal window # should be on the output of commands, not on the prompt #force_color_prompt=yes if [ -n "$force_color_prompt" ]; then if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then # We have color support; assume it's compliant with Ecma-48 # (ISO/IEC-6429). (Lack of such support is extremely rare, and such # a case would tend to support setf rather than setaf.) color_prompt=yes else color_prompt= fi fi if [ "$color_prompt" = yes ]; then PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ ' else PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ ' fi unset color_prompt force_color_prompt # If this is an xterm set the title to user@host:dir case "$TERM" in xterm*|rxvt*) PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1" ;; *) ;; esac # enable color support of ls and also add handy aliases if [ -x /usr/bin/dircolors ]; then test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)" alias ls='ls --color=auto' #alias dir='dir --color=auto' #alias vdir='vdir --color=auto' alias grep='grep --color=auto' alias fgrep='fgrep --color=auto' alias egrep='egrep --color=auto' fi # colored GCC warnings and errors #export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01' # some more ls aliases alias ll='ls -alF' alias la='ls -A' alias l='ls -CF' # Add an "alert" alias for long running commands. Use like so: # sleep 10; alert alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"' # Alias definitions. # You may want to put all your additions into a separate file like # ~/.bash_aliases, instead of adding them here directly. # See /usr/share/doc/bash-doc/examples in the bash-doc package. if [ -f ~/.bash_aliases ]; then . ~/.bash_aliases fi # enable programmable completion features (you don't need to enable # this, if it's already enabled in /etc/bash.bashrc and /etc/profile # sources /etc/bash.bashrc). if ! shopt -oq posix; then if [ -f /usr/share/bash-completion/bash_completion ]; then . /usr/share/bash-completion/bash_completion elif [ -f /etc/bash_completion ]; then . /etc/bash_completion fi fi # bashrc export PATH="/usr/share/dotnet:$PATH" export PYENV_ROOT="$HOME/.pyenv" export PATH="$PYENV_ROOT/bin:$PATH" if command -v pyenv 1>/dev/null 2>&1; then eval "$(pyenv init -)" fi # Cuda export CUDAHOME=/usr/local/cuda-11.1 export PATH=${CUDAHOME}/bin:${CUDAHOME}/NsightCompute-2019.3${PATH:+:${PATH}} export LD_LIBRARY_PATH=${CUDAHOME}/lib64${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}} # Export paths export nagoya_home=/home/doors export dataset=/home/jitesh/detectron_tutorial/dataset export dl=/home/jitesh/Downloads export nddscontent=/home/jitesh/3d/Dataset_Synthesizer/Source/Content export nddsplug=/home/jitesh/3d/Dataset_Synthesizer/Source/Plugins/DomainRandomizationDNN/Content export FAIRMOT_ROOT=/home/jitesh/prj/FairMOT # Unreal Engine UE_HOME=/home/jitesh/3d/UnrealEngine function unrealbuild { CURR_DIR=`pwd`; PROJ_NAME=$(basename ${1%.uproject}); $UE_HOME/Engine/Build/BatchFiles/Linux/Build.sh $PROJ_NAME Linux Development -editorrecompile "${CURR_DIR}/${PROJ_NAME}.uproject" -progress -editor -game -NoHotReloadFromIDE } complete -f -X '!*.@(uproject)' unrealbuild function unrealeditor { DIR="$( cd "$( dirname "$i" )" && pwd )" $UE_HOME/Engine/Binaries/Linux/UE4Editor $DIR/$1 } complete -f -X '!*.@(uproject)' unrealeditor function unrealgen { DIR="$( cd "$( dirname "$i" )" && pwd )" pushd $UE_HOME ./GenerateProjectFiles.sh -project="$DIR/$1" -game -engine -editor popd } complete -f -X '!*.@(uproject)' unrealgen # For automation tests, if used function unrealtest { DIR="$( cd "$( dirname "$i" )" && pwd )" $UE_HOME/Engine/Binaries/Linux/UE4Editor $DIR/$1 -Game -ExecCmds="Automation RunTests $2" -log } complete -f -X '!*.@(uproject)' unrealtest # Zip into parts slack_zip(){ tar cvzf - $1| split --bytes=950MB - $(basename $1).tar.gz. } zip_targz_in_parts() { # Example: $1=dataset_dir $2=. $3=200MB tar cvzf - $1 | split -b $3 - $(realpath -s $2)/$(basename $1).tar.gz. } unzip_targz_parts() { cat ${1}.* | tar xzvf - } # tar_compress tar_compress() { tar cvzf $(basename $1).tar.gz $1 } tar_extract() { tar xvzf $1 } # zip_slack zip_slack() { CHECK="`du -hs --block-size=M $1`" CHECK=${CHECK%M*} if (($(echo "$CHECK > "999"" |bc -l) )); then echo "big" tar cvzf - $1| split --bytes=950MB - $(basename $1).tar.gz. else echo "small" tar cvzf $(basename $1).tar.gz $1 fi } # NDDS output data postprocessing postprocessing_data.() { /home/jitesh/3d/venv/bin/python /home/jitesh/3d/data/src/data_postprocessing.py -f $1 -c $2 } # Reinstall a repository from PT-ML install-from-pt() { pip install https://github.com/PT-ML/$(basename $1).git } # Reinstall a repository from cm107 reinstall() { pip uninstall $1 pip install https://github.com/cm107/$(basename $1)/archive/master.zip } reinstall.all() { pip uninstall annotation_utils common_utils logger streamer pip install https://github.com/cm107/annotation_utils/archive/master.zip pip install https://github.com/cm107/common_utils/archive/master.zip pip install https://github.com/cm107/logger/archive/master.zip pip install https://github.com/cm107/streamer/archive/master.zip } install-cm-all() { gitcon git clone https://github.com/cm107/annotation_utils.git git clone https://github.com/cm107/common_utils.git git clone https://github.com/cm107/logger.git git clone https://github.com/cm107/streamer.git } alias uninstall-cm='pip uninstall annotation_utils common_utils logger streamer' # Copy multiple times copy2multiple() { tee <(basename $1).png o{$2..$3}.png >/dev/null } # Make a new folder folder() { mkdir $1 && cd $1 } # Replace a string in multiple files replace-in-files() { sed -i 's/$1/$2/g' $3 } # Connecting Diff Server alias diff="sshpass -p 'pas' ssh doors@172.xx.xx.xxx -X" copy_to_diff_server() { scp -r $1 doors@172.xx.xx.xxx:$2 } copy_from_diff_server() { scp -r doors@172.xx.xx.xxx:$1 $2 } # Reinstall a repository from cm107 reinstall() { pip uninstall $1 pip install pyclay-$(basename $1) } reinstall.all() { yes | pip uninstall pyclay-annotation_utils pyclay-common_utils pyclay-logger pyclay-streamer pip install pyclay-annotation_utils pip install pyclay-common_utils pip install pyclay-logger pip install pyclay-streamer } # Copy multiple times copy2multiple() { tee <(basename $1).png o{$2..$3}.png >/dev/null } # Make a new folder folder() { mkdir $1 && cd $1 } # Replace a string in multiple files replace-in-files() { sed -i 's/$1/$2/g' $3 } nvdu(){ current_path="`pwd`" cd ~/3d venv cd $current_path nvdu_viz } mp4_2_gif() { ffmpeg -i $1.mp4 $1.gif } # >>> conda initialize >>> # !! Contents within this block are managed by 'conda init' !! __conda_setup="$('/home/jitesh/miniconda3/bin/conda' 'shell.bash' 'hook' 2> /dev/null)" if [ $? -eq 0 ]; then eval "$__conda_setup" else if [ -f "/home/jitesh/miniconda3/etc/profile.d/conda.sh" ]; then . "/home/jitesh/miniconda3/etc/profile.d/conda.sh" else export PATH="/home/jitesh/miniconda3/bin:$PATH" fi fi unset __conda_setup # <<< conda initialize <<< export PYENV_ROOT="$HOME/.pyenv" export PATH="$PYENV_ROOT/bin:$PATH" if command -v pyenv 1>/dev/null 2>&1; then eval "$(pyenv init -)" fi upload_graph() { ts python upload_events.py --folder $1 } export HARUHOME="/home/haru" # # doc-18 Unity-Ros interaction # ## My PC # export ROS_MASTER_URI=http://$HOSTNAME:11311 # export ROS_HOSTNAME=$HOSTNAME # export ROS_IP=$(ip route get 8.8.8.8 | awk -F"src " 'NR==1{split($2,a," ");print a[1]}') ### Use Real Haru export ROS_MASTER_HOSTNAME="haru-47" export ROS_MASTER_URI=http://$ROS_MASTER_HOSTNAME:11311/ export MY_IP=$(ip route get 8.8.8.8 | awk -F"src " 'NR==1{split($2,a," ");print a[1]}') export ROS_IP=$MY_IP export ROS_HOSTNAME=$ROS_IP alias connect-haru="ssh haru@$ROS_MASTER_HOSTNAME" alias connect-har="sshpass -p haru ssh haru@$ROS_MASTER_HOSTNAME" # Make a new folder folder() { mkdir $1 && cd $1 } # Replace a string in multiple files replace-in-files() { sed -i 's/$1/$2/g' $3 } copy_file_from_haru() { scp haru@haru-29:$1 $2 } copy_file_to_haru() { scp $1 haru@haru-29:$2 } ros-source() { source "/home/jitesh/workspaces/$1_ws/devel/setup.bash" } convert-mov-to-webm() { IFS="." read -a strarr <<< "$1" echo "Converting from $1 to ${strarr[0]}.webm" mkdir webm # ffmpeg -i "$1" -c:v libvpx-vp9 -crf 33 -b:v 0 -speed 4 "${strarr[0]}.webm" yes | ffmpeg -i "$1" -c:v libvpx -quality good -cpu-used 0 -b:v 7000k -qmin 10 -qmax 42 -maxrate 500k -bufsize 1500k -threads 8 -vf scale=-1:1080 -c:a libvorbis -b:a 192k -f webm "${strarr[0]}.webm" mv "${strarr[0]}.webm" webm/ echo "Moved ${strarr[0]}.webm to webm/ directory" } convert-all-mov-to-webm() { for file in $1/*.mov do convert-mov-to-webm "$file" done } branch-list() { local base_path="${1:-.}" find $base_path -type d -name '.git' -exec echo {} \; -exec git -C {} branch \; } all-git-branch() { local base_path="${1:-.}" find $base_path -type d -name '.git' -exec echo {} \; -exec git -C {} branch \; } all-git-pull() { local base_path="${1:-.}" find $base_path \ -maxdepth 2 -type d \ -name ".git" \ -execdir python -c 'import os; print(os.path.abspath("."))' \; \ -execdir git branch \; \ -execdir git pull \; } # Android export JAVA_HOME="$HOME/JDK/jdk-11.0.18" export ANDROID_HOME="$HOME/Android" export ANDROID_SDK_ROOT="$HOME/Android/Sdk" PATH="$JAVA_HOME/bin:$ANDROID_SDK_ROOT:$ANDROID_HOME/Sdk/cmdline-tools:$ANDROID_HOME/Sdk/platform-tools:$PATH"