đ CodeTrans model for code documentation generation go
This is a pre - trained model for the Go programming language, leveraging the T5 base model architecture. It was initially released in this repository. The model is trained on tokenized Go code functions, and it performs optimally with such tokenized functions.
⨠Features
- Based on the
t5 - base
model with its own SentencePiece vocabulary model.
- Trained using single - task training on the CodeSearchNet Corpus Go dataset.
- Can generate descriptions for Go functions or be fine - tuned for other Go code tasks.
- Can handle unparsed and untokenized Go code, but performs better with tokenized code.
đĻ Installation
No installation steps are provided in the original document, so this section is skipped.
đģ Usage Examples
Basic Usage
Here is how to use this model to generate Go function documentation using Transformers SummarizationPipeline:
from transformers import AutoTokenizer, AutoModelWithLMHead, SummarizationPipeline
pipeline = SummarizationPipeline(
model=AutoModelWithLMHead.from_pretrained("SEBIS/code_trans_t5_base_code_documentation_generation_go"),
tokenizer=AutoTokenizer.from_pretrained("SEBIS/code_trans_t5_base_code_documentation_generation_go", skip_special_tokens=True),
device=0
)
tokenized_code = "func ( pr * Progress ) needSnapshotAbort ( ) bool { return pr . State == ProgressStateSnapshot && pr . Match >= pr . PendingSnapshot }"
pipeline([tokenized_code])
Run this example in colab notebook.
đ Documentation
Model description
This CodeTrans model is based on the t5 - base
model. It has its own SentencePiece vocabulary model. It used single - task training on CodeSearchNet Corpus Go dataset.
Intended uses & limitations
The model could be used to generate the description for the Go function or be fine - tuned on other Go code tasks. It can be used on unparsed and untokenized Go code. However, if the Go code is tokenized, the performance should be better.
đ§ Technical Details
The supervised training tasks datasets can be downloaded on Link
đ License
No license information is provided in the original document, so this section is skipped.
Evaluation results
For the code documentation tasks, different models achieve the following results on different programming languages (in BLEU score):
Test results :
Language / Model |
Python |
Java |
Go |
Php |
Ruby |
JavaScript |
CodeTrans - ST - Small |
17.31 |
16.65 |
16.89 |
23.05 |
9.19 |
13.7 |
CodeTrans - ST - Base |
16.86 |
17.17 |
17.16 |
22.98 |
8.23 |
13.17 |
CodeTrans - TF - Small |
19.93 |
19.48 |
18.88 |
25.35 |
13.15 |
17.23 |
CodeTrans - TF - Base |
20.26 |
20.19 |
19.50 |
25.84 |
14.07 |
18.25 |
CodeTrans - TF - Large |
20.35 |
20.06 |
19.54 |
26.18 |
14.94 |
18.98 |
CodeTrans - MT - Small |
19.64 |
19.00 |
19.15 |
24.68 |
14.91 |
15.26 |
CodeTrans - MT - Base |
20.39 |
21.22 |
19.43 |
26.23 |
15.26 |
16.11 |
CodeTrans - MT - Large |
20.18 |
21.87 |
19.38 |
26.08 |
15.00 |
16.23 |
CodeTrans - MT - TF - Small |
19.77 |
20.04 |
19.36 |
25.55 |
13.70 |
17.24 |
CodeTrans - MT - TF - Base |
19.77 |
21.12 |
18.86 |
25.79 |
14.24 |
18.62 |
CodeTrans - MT - TF - Large |
18.94 |
21.42 |
18.77 |
26.20 |
14.19 |
18.83 |
State of the art |
19.06 |
17.65 |
18.07 |
25.16 |
12.16 |
14.90 |
Created by Ahmed Elnaggar | LinkedIn and Wei Ding | LinkedIn