(மேலுள்ள படத்தை கிளிக் செய்து இந்த பாடத்தின் வீடியோவை பார்வையிடவும்)
கருவிகள் சுவாரசியமானவை, ஏனெனில் அவை AI எஜெண்ட்களுக்கு பரபரப்பான திறன்களை வழங்குகின்றன. எஜெண்ட் செய்யக்கூடிய படிகமான செயல் வரம்பை விட, ஒரு கருவியைச் சேர்ப்பதன் மூலம், எஜெண்ட் பலவகை செயல்களை செய்ய முடியும். இந்த அத்தியாயத்தில், AI எஜெண்ட்கள் தங்கள் குறிக்கோள்களை அடைய குறிப்பிட்ட கருவிகளை எவ்வாறு பயன்படுத்த முடியும் என்பதைக் கூறும் கருவி பயன்பாடு வடிவமைப்பு Pattern ஐப் பார்க்கப்போகிறோம்.
இந்த பாடத்தில், கீழ்கண்ட கேள்விகளுக்கு பதிலளிப்பதே நோக்கம்:
இந்த பாடத்தை முடித்த பிறகு, நீங்கள்:
கருவி பயன்பாட்டு வடிவமைப்பு Pattern LLM களை குறிப்பிட்ட குறிக்கோள்களை அடைவதற்கு வெளிப்புற கருவிகளுடன் தொடர்பு கொள்ளும் திறனை வழங்கும். கருவிகள் என்பது ஒரு எஜெண்ட் செயல்களை மேற்கொள்ள செயல்படுத்தக்கூடிய கோட் ஆகும். ஒரு கருவி எளிய function ஆக இருக்கலாம், எடுத்துக்காட்டாக கணக்கிடும் இயந்திரம், அல்லது பங்கு விலை தேடல் அல்லது வானிலை முன்னறிக்கையைப் பெறும் third-party சேவைக்கு API அழைப்பு ஆக இருக்கலாம். AI எஜெண்ட்களின் சூழலில், கருவிகள் மாதிரி-உருவாக்கிய function அழைப்புகளுக்கு பதிலளித்து எஜெண்ட்களால் செயல்பட வடிவமைக்கப்படுகின்றன.
AI எஜெண்ட்கள் கருவிகளை பயன்படுத்தி சிக்கலான பணிகளை முடிக்க, தகவல்களை பெற, அல்லது முடிவுகளை எடுக்க முடியும். கருவி பயன்பாடு வடிவமைப்பு Pattern பெரும்பாலும் வெளியீட்டு அமைப்புகளுடன் டைனமிக் தொடர்புகொள்ள வேண்டிய சூழலில் பயன்படுகிறது, எடுத்துக்காட்டாக தரவுத்தளம், வலை சேவைகள் அல்லது கோடுகளைப் புரிந்துகொள்ளும் நிரலர்கள். இதன் திறன் பலவகை பயன்பாடுகளுக்கு பயனுள்ளதாக இருக்கிறது:
இந்த கட்டமைப்புகள் AI எஜெண்டுக்கு பரபரப்பான பணிகளை செய்வதற்கு வேண்டிய ஆதாரங்கள். கருவி பயன்பாட்டு Design Pattern செயல்படுத்த தேவையான முக்கிய கூறுகள்:
Function/Tool திட்டங்கள்: கிடைக்கும் கருவிகளின் விரிவான வரைவுகள், அதில் function பெயர், நோக்கு, தேவையான அளவுருக்கள் மற்றும் எதிர்பார்க்கப்படும் வெளியீடுகள். இந்த திட்டங்கள் LLM க்கு கிடைக்கும் கருவிகளைக் புரிந்து கொண்டு சரியான வேண்டுகோள்களை உருவாக்க உதவுகின்றன.
Function செயல்படுத்தும் விதிகள்: பயனர் நோக்கம் மற்றும் உரையாடல் சூழலைப் பொருத்து எந்த நேரத்தில் கருவி அழைக்கப்படவேண்டும் என்பதைக் கையாள்கிறது. இதில் திட்டமிடல் முறைகள், வழிப் பாய்வு முறைகள் அல்லது நிபந்தனை அடிப்படையிலான வழிகள் அடங்கலாம்.
செய்தி கையாளும் அமைப்பு: பயனர் உள்ளீடுகள், LLM பதில்கள், கருவி அழைப்புகள் மற்றும் கருவி வெளியீடுகள் இடையேயான உரையாடல் ஓட்டத்தை நிர்வகிக்கும் கூறுகள்.
கருவி ஒருங்கிணைப்பு சட்டமேல் தொகுப்பு: எஜெண்டை பல கருவிகளுடன், எளிய function கள் ஆக இருந்தாலும், கிளப்பி பெரிய வெளிப்புற சேவைகள் ஆக இருந்தாலும் இணைக்கும் கட்டமைப்பு.
பிழை கையாளும் மற்றும் சரிபார்ப்பு: கருவி செயல்பாட்டில் தோல்விகளை கையாள, அளவுருக்கள் சரிபார்க்க, எதிர்பாராத பதில்களை நிர்வகிக்க பயன்படும் முறைகள்.
அமைப்பு மேலாண்மை: உரையாடல் சூழல், முந்தைய கருவி தொடர்புகள் மற்றும் நீடித்த தரவுகளை கண்காணித்து, பல சுற்றுக்களுக்குள் பொருந்துதலை உறுதிசெய்கிறது.
அடுத்து, Function/Tool அழைப்பைப் விரிவாக பார்க்கலாம்.
Function அழைப்பு என்பது Large Language Models (LLMs) கருவிகளுடன் தொடர்புகொள்ள முதன்மையான முறை. பொதுவாக ‘Function’ மற்றும் ‘Tool’ என்றவை பரிமாறி பயன்படுத்தப்படுகின்றன, ஏனெனில் ‘functions’ (மறு பயன்பாட்டுக்கான கோட் தொகுதிகள்) என்பது எஜெண்ட்கள் பணிகள் செய்ய பயன்படும் ‘tools’ ஆகும். ஒரு function கோடு அழைக்கப்பட வேண்டுமானால், LLM பயனர் கோரிக்கையை அந்த function விளக்கத்துடன் ஒப்பிட வேண்டும். அதற்கு கிடைக்கும் அனைத்து functions விளக்கங்களைக் கொண்ட ஒரு திட்டத்தை LLM க்கு அனுப்ப வேண்டும். LLM அவற்றுள் மிக பொருத்தமான function ஐ தேர்ந்தெடுத்து அதன் பெயர் மற்றும் அளவுருக்களை திருப்பி விடும். தேர்ந்தெடுக்கப்பட்ட function அழைக்கப்படுகிறது, பதில் LLM க்கு செல்லும், பின்னர் அது பயனர் கோரிக்கைக்கு பதிலளிக்க தகவலைப் பயன்படுத்தும்.
எஜெண்ட்கள் Function அழைப்பை செயல்படுத்த, நீங்கள் தேவையென்பவை:
ஒரு நகரின் தற்போதைய நேரத்தைப் பெறும் உதாரணத்தைப் பயன்படுத்தி விளக்குகிறோம்:
Function அழைப்பை ஆதரிக்கும் LLM ஐ துவக்கவும்:
எல்லா மாதிரிகளும் Function அழைப்பை ஆதரிக்காது, எனவே நீங்கள் பயன்படுத்தும் LLM இதை ஆதரிக்கிறதா என்பதை உறுதி செய்ய வேண்டும். Azure OpenAI Function அழைப்பை ஆதரிக்கிறது. Azure OpenAI கிளையண்டை துவக்கம் செய்துக்கொள்ள முடியும்.
# Azure OpenAI க்ளையன்ட்டை ஆரம்பிக்கவும்
client = AzureOpenAI(
azure_endpoint = os.getenv("AZURE_AI_PROJECT_ENDPOINT"),
api_key=os.getenv("AZURE_OPENAI_API_KEY"),
api_version="2024-05-01-preview"
)
Function திட்டத்தை உருவாக்குக:
அடுத்ததாக, function பெயர், அதன் செயலில் விளக்கம் மற்றும் function அளவுருக்கள் பெயர் மற்றும் விளக்கங்கள் உள்ள JSON திட்டத்தை வரையறுக்கிறோம். இந்த திட்டத்தை முன்பு உருவாக்கிய கிளையண்டுக்கு மற்றும் பயனர் கோரிக்கையை, உதாரணமாக San Francisco நேரம் பெற உத்தரவிடுவோம். முக்கியமாக கருத வேண்டியது என்னவென்றால் கருவி அழைப்பு மட்டுமே திருப்பப்படுகிறது, கேள்வியின் இறுதி பதில் அல்ல. LLM தேர்ந்தெடுத்த function பெயர் மற்றும் அதன் அளவுருக்கள் திருப்பும் என முன் கூறப்பட்டதுபோல்.
# படிக்க மாதிரிக்கு செயல்பாட்டு விளக்கம்
tools = [
{
"type": "function",
"function": {
"name": "get_current_time",
"description": "Get the current time in a given location",
"parameters": {
"type": "object",
"properties": {
"location": {
"type": "string",
"description": "The city name, e.g. San Francisco",
},
},
"required": ["location"],
},
}
}
]
# ஆரம்ப பயனர் செய்தி
messages = [{"role": "user", "content": "What's the current time in San Francisco"}]
# முதல் API அழைப்பு: மாதிரியை செயல்பாட்டைப் பயன்படுத்த கேளுங்கள்
response = client.chat.completions.create(
model=deployment_name,
messages=messages,
tools=tools,
tool_choice="auto",
)
# மாதிரியின் பதிலை செயலாக்கு
response_message = response.choices[0].message
messages.append(response_message)
print("Model's response:")
print(response_message)
Model's response:
ChatCompletionMessage(content=None, role='assistant', function_call=None, tool_calls=[ChatCompletionMessageToolCall(id='call_pOsKdUlqvdyttYB67MOj434b', function=Function(arguments='{"location":"San Francisco"}', name='get_current_time'), type='function')])
பணியை நிறைவேற்ற தேவையான function கோட்:
LLM தேர்வு செய்த function இப்போது செயல்படுத்தப்பட வேண்டும். Python-ல் தற்போதைய நேரத்தைப் பெறுவதற்கான கோட்டை உருவாக்கலாம். பதில் செய்தியிலிருந்து பெயர் மற்றும் அளவுருக்களை எடுத்து இறுதி முடிவை பெறுமாறு கோட் எழுத வேண்டும்.
def get_current_time(location):
"""Get the current time for a given location"""
print(f"get_current_time called with location: {location}")
location_lower = location.lower()
for key, timezone in TIMEZONE_DATA.items():
if key in location_lower:
print(f"Timezone found for {key}")
current_time = datetime.now(ZoneInfo(timezone)).strftime("%I:%M %p")
return json.dumps({
"location": location,
"current_time": current_time
})
print(f"No timezone data found for {location_lower}")
return json.dumps({"location": location, "current_time": "unknown"})
# செயல்பாட்டு அழைப்புகளை கையாளவும்
if response_message.tool_calls:
for tool_call in response_message.tool_calls:
if tool_call.function.name == "get_current_time":
function_args = json.loads(tool_call.function.arguments)
time_response = get_current_time(
location=function_args.get("location")
)
messages.append({
"tool_call_id": tool_call.id,
"role": "tool",
"name": "get_current_time",
"content": time_response,
})
else:
print("No tool calls were made by the model.")
# இரண்டாவது API அழைப்பு: மாதிரியில் இருந்து இறுதி பதிலை பெற்றுகொள்ளவும்
final_response = client.chat.completions.create(
model=deployment_name,
messages=messages,
)
return final_response.choices[0].message.content
get_current_time called with location: San Francisco
Timezone found for san francisco
The current time in San Francisco is 09:24 AM.
Function Calling என்பது பெரும்பாலும், இல்லையெனில் அனைத்து எஜெண்ட் கருவி பயன்பாட்டுக் வடிவமைப்புகளின் மையம் ஆகும், ஆனால் அதை பூஜ்ஜியமாக உருவாக்குவது சில நேரங்களில் சிரமமாக இருக்கலாம். Lesson 2 இல் கற்றதுபோல், எஜெண்ட் சட்டமேல் தொகுப்புகள் கருவி பயன்பாட்டைக் கையாளுவதற்கான முன் தயாரிக்கப்பட்ட கட்டமைப்புகளை வழங்குகின்றன.
வேறுபட்ட எஜெண்ட் சட்டமேல் தொகுப்புகளை பயன்படுத்தி கருவி பயன்பாடு Design Pattern இப்படி செயல்படுத்தலாம்:
Microsoft Agent Framework என்பது AI எஜெண்ட்கள் உருவாக்கும் திறனைக் கொடுக்கும் ஓப்பன்-சோர்ஸ் AI சட்டமேல் தொகுப்பு. இது function அழைப்பை எளிமையாக்கி, Python functions ஐ @tool அலங்காரச்சொல்லுடன் வரையறுக்க அனுமதிக்கிறது. மாதிரி மற்றும் உங்கள் கோட்டின் இடையேயான தொடர்பினை சட்டமேல் கையாளும். மேலும், AzureAIProjectAgentProvider வாயிலாக File Search மற்றும் Code Interpreter போன்ற முன் தயாரிக்கப்பட்ட கருவிகளையும் அணுகலாம்.
Microsoft Agent Framework உடன் Function calling செயல்முறை இதுபோல இருக்கிறது:

Microsoft Agent Framework இல், கருவிகள் அலங்காரம் செய்யப்பட்ட functions ஆக வரையறுக்கப்படுகின்றன. முன்பு பார்த்த get_current_time function ஐ @tool அலங்காரச்சொல்லுடன் கருவியாக மாற்றலாம். சட்டமேல் function மற்றும் அதன் அளவுருக்களை தானாகவே உருமாற்றி, LLM க்குப் கிடைக்கும் திட்டத்தை உருவாக்கும்.
from agent_framework import tool
from agent_framework.azure import AzureAIProjectAgentProvider
from azure.identity import AzureCliCredential
@tool
def get_current_time(location: str) -> str:
"""Get the current time for a given location"""
...
# கிளையண்டை உருவாக்கவும்
provider = AzureAIProjectAgentProvider(credential=AzureCliCredential())
# ஒரு முகவரியை உருவாக்கி கருவியுடன் இயக்கவும்
agent = await provider.create_agent(name="TimeAgent", instructions="Use available tools to answer questions.", tools=get_current_time)
response = await agent.run("What time is it?")
Azure AI Agent Service என்பது புதிதாக வரும் எஜெண்ட் சட்டமேல் தொகுப்பு. இது டெவலப்பர்களுக்கு நிலையான கணினி மற்றும் சேமிப்பு வளங்களை நிர்வகிக்காவிட்டாலும், பாதுகாப்பாக உயர்தர மற்றும் விரிவாக்கமுடியுமாய்ச் AI எஜெண்ட்கள் உருவாக்க, பிரயோகிப்பதில் உதவுகிறது. இது, குறிப்பாக நிறுவன பயன்பாடுகளுக்கு ஏற்ற ஒருங்கிணைந்த, பாதுகாப்பான முழுமையான சேவையாகும்.
LLM API உடன் நேரடியாக உருவாக்குவதும் Azure AI Agent சேவையைப்போல் பார்க்கும்போது, கீழ்காணும் நன்மைகள் உள்ளன:
Azure AI Agent சேவையில் கிடைக்கும் கருவிகள் இரண்டு வகையாக பிரிக்கப்படுகின்றன:
Agent Service இல் இந்த கருவிகளை toolset ஆக பயன்படுத்த முடியும். மேலும், குறிப்பிட்ட உரையாடலின் செய்தி வரலாறு இனைப்பதாக threads ஐ பயன்படுத்துகிறது.
நீங்கள் “Contoso” என்ற நிறுவனத்தில் விற்பனை எஜெண்ட் ஆக இருக்கிறீர்கள் என்று கனவுகாணுங்கள். உங்கள் விற்பனை தரவுகள் தொடர்பான கேள்விகளுக்கு பதிலளிக்கும் உரையாடல் எஜெண்டை உருவாக்க விரும்புகிறீர்கள்.
Azure AI Agent Service உபயோகித்து உங்கள் விற்பனை தரவுகளைப் பகுப்பாய்வு செய்வதை இந்த படம் விளக்குகிறது:

இந்த சேவையுடன் எந்த ஒரு கருவியையும் பயன்படுத்த, நாம் கிளையண்ட் உருவாக்கி கருவி அல்லது கருவிப் தொகுப்பை வரையறுக்கலாம். இதில் பயனர் உருவாக்கிய fetch_sales_data_using_sqlite_query function அல்லது முன் தயாரிக்கப்பட்ட Code Interpreter உடன் LLM கருவி தொகுப்பைக் கண்டு பயன்படுத்த முடியும்.
import os
from azure.ai.projects import AIProjectClient
from azure.identity import DefaultAzureCredential
from fetch_sales_data_functions import fetch_sales_data_using_sqlite_query # fetch_sales_data_using_sqlite_query என்ற செயல்பாடு fetch_sales_data_functions.py கோப்பில் காணப்படலாம்.
from azure.ai.projects.models import ToolSet, FunctionTool, CodeInterpreterTool
project_client = AIProjectClient.from_connection_string(
credential=DefaultAzureCredential(),
conn_str=os.environ["PROJECT_CONNECTION_STRING"],
)
# கருவி தொகுப்பை ஆரம்பிப்பது
toolset = ToolSet()
# fetch_sales_data_using_sqlite_query செயல்பாட்டுடன் மற்றும் அதை கருவி தொகுப்பில் சேர்த்துக் கொண்டு function calling agent ஐ ஆரம்பித்தல்
fetch_data_function = FunctionTool(fetch_sales_data_using_sqlite_query)
toolset.add(fetch_data_function)
# Code Interpreter கருவியைக் INIT செய்து அதை கருவி தொகுப்பில் சேர்த்தல்.
code_interpreter = code_interpreter = CodeInterpreterTool()
toolset.add(code_interpreter)
agent = project_client.agents.create_agent(
model="gpt-4o-mini", name="my-agent", instructions="You are helpful agent",
toolset=toolset
)
LLM-கள் உருவாக்கும் SQL-வைப் பற்றிய பொதுவான கவலைவாக பாதுகாப்பு உள்ளது, குறிப்பாக SQL injection அல்லது தீங்கான செயல்கள் (தரவுத்தளத்தை drop செய்வது அல்லது மாற்றுவது போன்ற) காரணமாக. இத்தகைய கவலைகள் உண்மையானவை, ஆனால் தரவுத்தள அணுகல் அனுமதிகளை சரியாக கட்டமைத்தால் மிகுந்த பாதுகாப்பு ஏற்படுகிறது. பெரும்பாலான தரவுத்தளங்களில், தரவுத்தளம் படிக்க மட்டுமே அனுமதிக்கப்பட வேண்டும். PostgreSQL அல்லது Azure SQL போன்ற சேவைகளுக்கு, செயலிக்கு read-only (SELECT) பங்கு ஒதுக்கப்படும்.
செயலியை பாதுகாப்பான சூழலில் ஓட்டுவது அமைச்சர் பாதுகாப்பை மேம்படுத்தும். நிறுவன சூழல்களில், தரவு பொதுவாக இயங்கும் அமைப்புகளிலிருந்து படித்து மாற்றப்பட்டு படிக்க மட்டும் அனுமதிக்கப்படும் தரவுத்தளமாக மாற்றப்படும். இது தரவின் பாதுகாப்பையும், செயல்திறனையும், மற்றும் பயன்பாட்டின் கட்டுப்பட்ட படிக்கவேண்டிய அணுகலை உறுதிசெய்கிறது.
Microsoft Foundry Discord இல் சேர்ந்து மற்ற கற்றுதலாளர்களை சந்தித்து, அலுவலக நேரங்களில் பங்கேற்று, உங்கள் AI எஜெண்ட்கள் தொடர்பான கேள்விகளுக்கு பதில் பெறுங்கள்.
Agentic Design Patterns புரிதல்
மறுப்பு:
இந்த ஆவணம் AI மொழிபெயர்ப்பு சேவையான Co-op Translator மூலம் மொழிபெயர்க்கப்பட்டுள்ளது. நாங்கள் துல்லியத்திற்காக முயற்சித்தாலும், தானாக செய்யப்பட்ட மொழிபெயர்ப்புகளில் பிழைகள் அல்லது தவறுகள் இருக்கக்கூடும் என்பதை கவனத்தில் கொள்ளவும். அசல் ஆவணம் அதன் உள்ளூர் மொழியில் அதிகாரப்பூர்வ ஆதாரமாக கருதப்பட வேண்டும். முக்கியமான தகவல்களுக்கு, தொழில்முறை மனித மொழிபெயர்ப்பை பரிந்துரைக்கிறோம். இந்த மொழிபெயர்ப்பின் பயன்பாட்டிலிருந்து ஏற்படும் எந்தத் தவறுகளுக்கும் நாங்கள் பொறுப்பேற்கமாட்டோம்.