In nvim, I use plugin fugitive
open two vertical buffer (one form target, another from feature)
1 | :Gvdiffsplit! |
stay on middle and use
1 | :diffget [buffername](local) |
OR
go to target/feature buffer and use
1 | :diffput [buffername](target/feature) |
save the local file and use
1 | :Git add . |
1 | git remote add origin git@github.com:... |
origin
is the name of the repository
Check remote repository settings:
1 | git remote -v |
Before push to remote repository, make sure the branch name is the same.
find all the branch
1 | git branch -a |
find all the branch on remote repository
1 | git remote -r |
Rename
1 | git branch -m oldBranchName newBranchName |
Move to branch:
1 | git checkout [branchname/SHA-1] |
A Git submodule allows a user to include a Git repository as a subdirectory of another Git repository. This can be useful when a project needs to include and use another project. For example, it may be a third-party library or a library developed independently for use in multiple parent projects. With submodules, these libraries can be managed as independent projects while being used in the user’s project. This allows for better organization and management of the code.
To add an existing Git repository as a submodule to a project, the git submodule add
command can be used. The command format is git submodule add <url> <path>
, where <url>
is the URL of the submodule repository and <path>
is the storage path of the submodule in the project. For example, if a user wants to add the remote repository https://github.com/username/repo.git
as a submodule to their project and store it in the my-submodule
directory, they can use the following command:
1 | git submodule add https://github.com/username/repo.git my-submodule |
This will successfully add a submodule named my-submodule
to the user’s project.
1 | git log |
1 | commit 0637340f4d8d288a8d24dd5193855c9e5def776d (HEAD -> main, origin/main, origin/HEAD) |
1 | git reset --hard [version hash] |
1 | git pull |
or locally
1 | git checkout master |
1 | git clone ... |
1 | git log |
link
ALWAYS!
DONE!
WORKING~
raw data : for each subjects(S1,S2 …) , each action(walking, waiting, smoking …), each sub sequence(1/2):
$(n) \times 99$ (np.ndarray, float32)
data_utils.load_data()
used by translate.read_all_data()
train data: the composed dictionary ((suject_id, action, subaction_id, ‘even’) as key) of raw data (just even rows), with one hot encoding columns for action type, if action is specified (normal case), just append an all 1 column to rawdata. Size of each dictionary value:
$(n/2) \times (99 + actions;count)$
complete data: all data joint together, from different subjects, actions, sub sequences:
$(n) \times 99$
translate.read_all_data()
used by translate.train()
train set : normalized train data, throw out data with $std < 1e-4$ (accroding to complete data). Size of each dictionary value:
$(n/2) \times ((99-used;dimension;count) + actions;count)$
After the analyzztion of the complete data, human dimension has been fixed to $54$.
Seq2SeqModel.get_batch()
used by translate.train()
total_seq: $60$ ($[0,59]$)
source_seq_len: $50$
target_seq_len: $10$
batch_size: $16$
encoder_inputs: $16\times 49\times (54+actions;count)$
Interpretation: [batch,frame,dimension]
frame range: $[0,48]$
decoder_inputs: $16\times 10\times (54+actions;count)$
frame range: $[49,58]$
decoder_outputs: $16\times 10\times (54+actions;count)$
frame range: $[50,59]$
encoder_inputs: Tensor form of encoder_inputs from Seq2SeqModel.get_batch()
1 | torch.from_numpy(encoder_inputs).float() |
decoder_inputs: Tensor form of decoder_inputs from Seq2SeqModel.get_batch()
For detailed usage, please see [Adopted] human-motion-prediction-pytorch\src\predict.ipynb
The kinect camera’s output is not guaranteed to be consistent with the input of this model (some features are cut off), so further research is needed.
Run pyKinectAzure\examples\exampleBodyTrackingTransformationComparison
to get the camera output record in pyKinectAzure\saved_data
, saved as .npy