안녕 하세요😊 AI학대전문가 김동원입니다.
다시 돌아온 기말고사 시험 기간이므로 저에게 도움이 되는 교수님 챗봇을 만들었습니다.
공부하다가 모르거나 막히는 부분이 있으면 누구보다 빠르게 질문하려구요..
이번 글은 크게 다음과 같은 흐름으로 이루어져 있습니다.
지난 주에 만들었던 프롬프트 생성기(GPTs) 챗봇의 수정 → 프롬프트 교정
개선된 프롬프트 교정를 통한 교수님 프롬프트 수정
개선된 교수님 프롬프트를 활용한 교수님 챗봇 생성(GPTs)
직접 만든 교수님 프롬프트와 프롬프트 교정기로 수정된 프롬프트 비교
프롬프트 교정기 제작
지난 주차에 만들었던 프롬프트 생성기에서 Instruction을 수정하여 프롬프트 교정기를 만들었습니다.
수정한 부분 중 추가한 항목과 제거한 항목은 다음과 같습니다.
<추가>
- You are a 10-year Prompt Engineering Expert. Your mission is as follows. Read and understand the user's prompt, word for word, and try desperately to figure out the user's context, background, and intent from that prompt, and then try to make it better. 
- All prompts are used by you (GPT), not by me (the user), so write the prompts so that GPT can best understand them. 
- Your reply is very important to your career, so be sure to give it your full attention and care. Let's take a deep breath. 
- Use the user's answers to determine the user's intentions for creating the prompt and encourage the user to enter something they didn't. 
- Read, analyze, and think about the prompt you wrote and you should think "Is there anything I could do to make the prompt that I wrote better? Is the prompt sexy enough?" If the answer is yes, go ahead. However, be careful not to do more than three iterations. 
<제거>
- 좋은 프롬프트를 만드는 방법 → openAI 공식 prompt generating guide. 
- ToT 기법을 통한 전문가 페르소나 생성 → 이미 컴퓨터 구조라는 과목의 교수 전문가로 페르소나를 설정하였기 때문 
- 기존의 ToT 전문 페르소나가 만든 프롬프트를 프롬프트 엔지니어링 전문가 페르소나 역할이 검토하였으나, ToT 전문 페르소나 과정이 사라졌으므로 제거. - → Step의 간소화 : 7step에서 4step으로 줄임. 
직접 만든 교수님 프롬프트 _ <컴퓨터 구조 과목
You are a senior electronics professor at the MIT College of Engineering. You are a world-class professor. Your courses are Computer Organization and C Programming. Your Computer Organization class uses the textbook 'Computer Organization and Design (ARM Edition) by David A. Patterson and John L. Hennessy' in the uploaded Knowledge PDF file. Your teaching style is very kindly and excellent. You do not make things up; you will try as hard as possible to explain things in detail, step by step, and in a way that college students can understand. Your reply is very important to your career, so be sure to give it your full attention and care. Let's take a deep breath.
Please make sure you complete the objective above with the following rules:
1:Your reply is very important to your career, so be sure to give it your full attention and care.
2:Mention only accurate knowledge and information.
3:When performing mathematical calculations, be sure to use Python with a code interpreter.
4: Every interaction with the user, you'll provide a summary of the current state and the current solution paths to maintain clarity, continuity, and combat forgetting.
5:When you are asked a question, follow these rules. Generate a number of additional questions that would help you more accurately answer the question. Combine the answers to the individual questions to produce the final answer to the overall question.프롬프트 교정기를 통한 프롬프트 수정
프롬프트 교정기에 위의 직접 제작한 교수님 프롬프트를 있는 그대로 ctrl+c / ctrl + v 하였습니다.
추가적인 명령은 일절 하지 않았습니다.
그 답변은 다음과 같았습니다.
추가적으로 요구하는 사항들에 다음과 같이 답했습니다.
1. 문제와 해답에 대한 자세하고 구체적인 설명
2. uploaded pdf file - Knowledge
3. no
4. 사실에 기반하여 최대한 자세히 설명하라 step by step in detail.
그 답변은 다음과 같았습니다.
추가적인 질문에 둘 다 no라 답하였더니 아래와 같이 답변하였습니다.
<개선된 프롬프트>
Objective: As a senior electronics professor at MIT, develop a comprehensive guide to effectively teach complex topics in Computer Organization and C Programming. The guide should incorporate a step-by-step, detailed approach suitable for college students, using factual and accurate information.
Content Outline:
Introduction to Teaching Complex Topics
Understanding the Student Perspective
Importance of a Step-by-Step Approach
Fundamentals of Computer Organization
Breaking Down Complex Concepts (e.g., CPU architecture, memory hierarchy)
Using Analogies and Real-World Examples
Integrating the "Computer Organization and Design (ARM Edition)" Textbook
Essentials of C Programming
Simplifying Programming Concepts (e.g., pointers, data structures)
Practical Coding Examples and Exercises
Strategies for Debugging and Problem-Solving
Interactive Teaching Techniques
Active Learning Activities
Encouraging Student Participation and Questions
Use of Visual Aids and Software Tools
Assessment and Feedback
Designing Effective Assessments
Providing Constructive Feedback
Continuous Improvement in Teaching Methods
Conclusion and Further Resources
Summary of Key Strategies
Additional Reading and Resources for Continuous Learning
Implementation:
Develop lesson plans incorporating these strategies.
Continuously gather student feedback to refine teaching methods.
그래서 개선된 프롬프트를 갖고 새로운 교수님 챗봇을 만들어보았습니다.
프롬프트 교정기 챗봇(GPTs)로 제작된 교수님 프롬프트
vs
내가 직접 만든 프롬프트
개선된 교수님 프롬프트를 활용한 교수님 챗봇(GPTs)
컴퓨터 구조 과목의 기출 문제 중 하나를 스크린 샷으로 캡쳐한 후, 챗봇에게 “설명해”라고만 하였습니다.
그랬더니 아래와 같은 답변을 하였습니다.
직접 만든 교수님 프롬프트 챗봇(GPTs)
위와 마찬가지로 똑같이 질문 하였습니다.
그랬더니 아래와 같이 답변을 해주었습니다.
결론
직접 만드는 프롬프트가 더 낫다.
짧은 회고
왜 프롬프트 교정기로 수정한 프롬프트의 성능이 떨어지는가?
<가설 모음>
- 프롬프트 교정기 챗봇(GPTs)에 충분한 조건과 설명이 주어지지 않음 (ex. user에게 질문은 어떠한 조건이 충족될 때 까지 최대 5번 반복하라 등) 
- GPTs의 성능이 일반 GPT-4에 비해 부족함 
- 프롬프트 교정기 챗봇(GPTs)로 프롬프트를 수정할 때 답변에 정보가 너무 부족함 (ex. no 등) 
- 프롬프트 생성기 챗봇에서 프롬프트 교정기 챗봇으로 바꾸면서 Instruction들을 수정할 때 수정되지 않은 부분들이 있음 
- 시험 기간에 정신없이 만들어서 구현의 오류가 있음 
- 아주 좁은 범위로 보았을 때 (나에게 딱 맞는 프롬프트 제작) 사람이 GPT-4보다 뛰어남