AI prompts
base on GUNDAM is a data management system that prioritizes data using language models. # Golden plUg-iN DAta Manager (GUNDAM)
<img src="assets/logo.jpg">
<p align="center">
<a href="https://jinjiarui.github.io/gundam/">Project</a> |
<a href="https://jinjiarui.github.io/preprints/GUNDAM.pdf">Paper</a> |
<a href="https://gundam-labet.readthedocs.io/en/latest/">Documentation</a>
</p>
**GUNDAM** is a data manager that utilizes language models to efficiently handle textual data, which is built upon [PyTorch](https://pytorch.org).
GUNDAM is:
- **Comprehensive**: GUNDAM provides a data manager including our proposed miner, a GPT-2 based generator, and a demonstration retriever, and all of these components are extendable.
- **Flexible**: GUNDAM supports GPT-2 language models with different sizes.
- **Efficient**: GUNDAM provides an efficient one-to-one miner to check data quality.
--------------------------------------------------------------------------------
## Brief Introduction
GUNDAM is a novel data management framework that measures the sufficiency and necessity of plugging-in demonstrations conditioned on language models.
We show that the proposed sufficiency and necessity metrics
can be operated on both demonstration instances (i.e., instance level) and demonstration sets (i.e., set level).
Thus, the set of sufficient and necessary plug-in data, named as a golden plug-in set, can be regarded as a core set including the informative samples.
Since enumerating and measuring all the possible subsets is infeasible, we design new tree-based search algorithms to mine the golden plug-in set.
Notice that the golden plug-in set could be pre-computed and stored to save online computation costs.
In this regard, non-parametric demonstration retrievers could perform on the stored golden plug-in set instead of the whole data corpus, to avoid retrieving insufficient or unnecessary demonstrations.
Moreover, considering that many real-world data corpus would keep growing, we develop an incremental update algorithm to avoid re-computing GUNDAM over all the changed and unchanged parts.
<img src="assets/overview.jpeg" width=100%>
## Use Cases
The significant advantage of GUNDAM is that GUNDAM can be easily deployed on any existing data management platform because the core idea of GUNDAM is to assign different priority levels to the stored data to show their data qualities regarding the given language model.
## ToDo (Latest Update at 2023/07/24)
- [x] Release basic versions of a one-to-one miner and GPT-2 based generators in both unsupervised learning settings (a.k.a., few-shot inference) and supervised learning settings (a.k.a., warm-up inference).
- [x] Support random-based demonstration retrievers, relevance-based demonstration retrievers, and diversity-based demonstration retrievers.
- [ ] Support pair-to-one miner and GPT-3 based generators.
- [ ] Release textual dataset of sufficiency and necessity.
- [ ] Release detailed document tutorial and readme guidance.
## Citing CORE
```bibtex
@software{GUNDAM,
author = {Jiarui Jin, Yuwei Wu, Mengyue Yang, Xiaoting He, Weinan Zhang, Yiming Yang, Yong Yu, and Jun Wang},
title = {GUNDAM: A Data-Centric Manager for Your Plug-in Data with Language Models},
year = {2023},
publisher = {GitHub},
journal = {GitHub repository},
version = {0.0},
howpublished = {\url{https://github.com/GUNDAM-Labet/GUNDAM}},
}
```
## The Team
Core developers of the GUNDAM system are [Jiarui Jin](https://github.com/Jinjiarui), [Yuwei Wu](https://github.com/Willyoung2017) and [Mengyue Yang](https://github.com/ymy4323460).
## License
GUNDAM is released under the Apache License, Version 2.0.
", Assign "at most 3 tags" to the expected json: {"id":"2881","tags":[]} "only from the tags list I provide: [{"id":77,"name":"3d"},{"id":89,"name":"agent"},{"id":17,"name":"ai"},{"id":54,"name":"algorithm"},{"id":24,"name":"api"},{"id":44,"name":"authentication"},{"id":3,"name":"aws"},{"id":27,"name":"backend"},{"id":60,"name":"benchmark"},{"id":72,"name":"best-practices"},{"id":39,"name":"bitcoin"},{"id":37,"name":"blockchain"},{"id":1,"name":"blog"},{"id":45,"name":"bundler"},{"id":58,"name":"cache"},{"id":21,"name":"chat"},{"id":49,"name":"cicd"},{"id":4,"name":"cli"},{"id":64,"name":"cloud-native"},{"id":48,"name":"cms"},{"id":61,"name":"compiler"},{"id":68,"name":"containerization"},{"id":92,"name":"crm"},{"id":34,"name":"data"},{"id":47,"name":"database"},{"id":8,"name":"declarative-gui "},{"id":9,"name":"deploy-tool"},{"id":53,"name":"desktop-app"},{"id":6,"name":"dev-exp-lib"},{"id":59,"name":"dev-tool"},{"id":13,"name":"ecommerce"},{"id":26,"name":"editor"},{"id":66,"name":"emulator"},{"id":62,"name":"filesystem"},{"id":80,"name":"finance"},{"id":15,"name":"firmware"},{"id":73,"name":"for-fun"},{"id":2,"name":"framework"},{"id":11,"name":"frontend"},{"id":22,"name":"game"},{"id":81,"name":"game-engine "},{"id":23,"name":"graphql"},{"id":84,"name":"gui"},{"id":91,"name":"http"},{"id":5,"name":"http-client"},{"id":51,"name":"iac"},{"id":30,"name":"ide"},{"id":78,"name":"iot"},{"id":40,"name":"json"},{"id":83,"name":"julian"},{"id":38,"name":"k8s"},{"id":31,"name":"language"},{"id":10,"name":"learning-resource"},{"id":33,"name":"lib"},{"id":41,"name":"linter"},{"id":28,"name":"lms"},{"id":16,"name":"logging"},{"id":76,"name":"low-code"},{"id":90,"name":"message-queue"},{"id":42,"name":"mobile-app"},{"id":18,"name":"monitoring"},{"id":36,"name":"networking"},{"id":7,"name":"node-version"},{"id":55,"name":"nosql"},{"id":57,"name":"observability"},{"id":46,"name":"orm"},{"id":52,"name":"os"},{"id":14,"name":"parser"},{"id":74,"name":"react"},{"id":82,"name":"real-time"},{"id":56,"name":"robot"},{"id":65,"name":"runtime"},{"id":32,"name":"sdk"},{"id":71,"name":"search"},{"id":63,"name":"secrets"},{"id":25,"name":"security"},{"id":85,"name":"server"},{"id":86,"name":"serverless"},{"id":70,"name":"storage"},{"id":75,"name":"system-design"},{"id":79,"name":"terminal"},{"id":29,"name":"testing"},{"id":12,"name":"ui"},{"id":50,"name":"ux"},{"id":88,"name":"video"},{"id":20,"name":"web-app"},{"id":35,"name":"web-server"},{"id":43,"name":"webassembly"},{"id":69,"name":"workflow"},{"id":87,"name":"yaml"}]" returns me the "expected json"