Fine-Grained Task Planning for Service Robot Based on Object Ontology Knowledge via Large Language Models
This code repository is the official resource for the paper "Fine-Grained Task Planning for Service Robot Based on Object Ontology Knowledge via Large Language Models." It comprehensively demonstrates the entire process of the FGTP (Fine-Grained Task Planning) framework. It is important to note that the home item ontology knowledge base used for construction in the paper is not included in this repository due to open-source limitations. As an alternative, we provide an ontology.json file, which structurally mimics the original ontology knowledge base. Readers can build their own knowledge base by referring to the structure of the knowledge base described in the paper and the sample content in the ontology.json file, combined with knowledge of ontology modeling.
The models used in our project include BERT, YOLOv8, ReITR, CLIP, please install the environment of the corresponding model before use.
Download the pre-trained model and place them in the ckpt directory in the root.
Download the bert-base-uncased and place them in the bert-base-uncased directory in the root.
After installing the runtime environment and downloading the pre-trained model, run MainStandard.py, which is the code for the standard task planning process, and note that you have to fill in your own openai key in line 14 of the code:
python MainStandard.py
The code for the anomaly task planning is in MainExceptional.py, and it is important to note that since there is no running of the actual robot involved in the open source code, the code for the semantic building and item searching portions of the original article is not available here, but rather it is assumed that the items can be directly replaced by finding a replacement.
python MainExceptional.py
The results of the run are saved in the results directory in the root directory, where img_cropped.jpg represents the image of the detected item cropped from the original image, img_detected.jpg represents the visualization image of the results of the target detection, and StandardPlanning.txt represents the results of the standard task planning, the ExceptionalPlanning.txt represents the result of abnormal task planning
For more information about VirtualHome, please refer to: VirtualHome