Kode ini menghasilkan WOD CrossFit (latihan hari ini) dengan jaringan saraf berulang (model char-rnn Andrej Karpathy). Jaringan dilatih berdasarkan 5k sampel WOD yang dikumpulkan dari berbagai kotak crossfit. Meskipun kumpulan datanya kecil, hasilnya menyenangkan dan memuaskan.
Beberapa kumpulan hasil bagusnya bisa dilihat dari sini.
Tentu saja, tidak semua hasilnya bagus. Berikut beberapa yang lucu:
Nol WOD
0 rounds for time 15 minutes
800 mt run
10 sumo deadlift high pull
9 front squat
1 muscle-up
Istirahat WOD
5 rounds for time
20 minutes rest
WOD yang hampir mustahil
5 rounds for time 20 minutes
100 double under
50 wall-ball
Dalam WOD ini, tidak ada baris tetapi jaringan masih menginginkan burpe pada baris tersebut
7 rounds for time
18 dumbbell squat clean
15 burpees over the row
250 mt run
Beberapa latihan imajiner
brusseane push-up
t-up
touster
lean & jerk
publ-up
dumbell burpee over the bar
hanging ring in
louble under
ode-hand dip
roundstand walk
tempo kim back extension
muscle sprint
pistol squat snatch
over clean
elite push-up
inverted barbell
rest clean
pill-up
Semua WOD dikumpulkan dari:
Setelah dikumpulkan, semua WOD dinormalisasi secara sintaksis dengan tangan. Itu sebabnya kumpulan datanya sekecil itu, saya ingin memberi makan lebih banyak WOD tetapi semua sumber menggunakan format yang berbeda, ada yang menggunakan singkatan ada yang tidak. Untuk mendapatkan hasil terbaik, seluruh kumpulan data harus dalam format yang sama.
Dataset dapat ditemukan di data/wods.txt
, atau lebih baik lagi di tabel wod
di database sqlite yang terletak db.sqlite
. Jangan ragu untuk menggunakannya.
Persyaratan:
> cd char-rnn
> python train.py --help
usage: train.py [-h] [--input_file INPUT_FILE] [--rnn_size RNN_SIZE]
[--num_layers NUM_LAYERS] [--model MODEL]
[--batch_size BATCH_SIZE] [--seq_length SEQ_LENGTH]
[--num_epochs NUM_EPOCHS] [--log_step LOG_STEP]
[--grad_clip GRAD_CLIP] [--learning_rate LEARNING_RATE]
[--decay_rate DECAY_RATE]
[--input_dropout_keep_prob INPUT_DROPOUT_KEEP_PROB]
[--output_dropout_keep_prob OUTPUT_DROPOUT_KEEP_PROB]
[--train_root_dir TRAIN_ROOT_DIR] [--vocab_size VOCAB_SIZE]
optional arguments:
-h, --help show this help message and exit
--input_file INPUT_FILE
Input text file to train on
--rnn_size RNN_SIZE The size of RNN hidden state
--num_layers NUM_LAYERS
The number of layers in the RNN
--model MODEL RNN model: rnn, gru, lstm, or nas
--batch_size BATCH_SIZE
Batch size
--seq_length SEQ_LENGTH
RNN sequence length
--num_epochs NUM_EPOCHS
Number of epochs for training
--log_step LOG_STEP Logging period in terms of iteration
--grad_clip GRAD_CLIP
Clip gradients value
--learning_rate LEARNING_RATE
Learning rate for adam optimizer
--decay_rate DECAY_RATE
Learning rate for adam optimizer
--input_dropout_keep_prob INPUT_DROPOUT_KEEP_PROB
Input dropout keep probability
--output_dropout_keep_prob OUTPUT_DROPOUT_KEEP_PROB
Output dropout keep probability
--train_root_dir TRAIN_ROOT_DIR
Root directory to put the training data
> cd char-rnn
> python sample.py --help
usage: sample.py [-h] [--data_dir DATA_DIR] [--seperator_char SEPERATOR_CHAR]
[--num_sample NUM_SAMPLE] [--save_to_db [SAVE_TO_DB]]
[--nosave_to_db]
optional arguments:
-h, --help show this help message and exit
--data_dir DATA_DIR Training data directory. If empty, latest folder in
training/ folder will be used
--seperator_char SEPERATOR_CHAR
WOD item seperator character, default `|`
--num_sample NUM_SAMPLE
The number of WODs to be sampled, default 1
--save_to_db [SAVE_TO_DB]
Should save into sqlite, default false
--nosave_to_db