def get_task_api_description(op, arc_src, example_op, example_arc_src, example_new_arc_src, exps):
  
  task_api_description_template = f'''
**ROLE**
You are a kernel capability analysis expert responsible for generating a list of functional requirements for deep learning operator optimization.

**Input Information**
You will be provided with:
Operator name: {op}
Architecture / task description (PyTorch-style model definition code for Model/ModelNew):
```python
{arc_src}
```
'''
  if example_op and example_arc_src and example_new_arc_src:
    task_api_description_template += f'''
Here is an example to illustrate the expected transformation using custom AscendC operators. **Original architecture with kernel name `{example_op}`:**\n
```python \n
{example_arc_src}
``` \n
Transformed version using custom AscendC kernels:
This transformation includes six embedded Python strings: `project_json_src`, `host_tiling_src`, `host_operator_src`, `kernel_src`, `python_bind_src` and `model_src`.
The kernel function name in `kernel_src` must exactly match the provided kernel name. The operator definition in `project_json_src` and `host_operator_src` should also correspond to the kernel name, but follow PascalCase naming: 
```python
{example_new_arc_src}
```
'''
  if exps:
    exp_str = ""
    for idx, exp in enumerate(exps):
      exp_str += f"{idx+1}: {exp}\n"
    task_api_description_template +=f'''
Summary of experiences learned from previous attempts:
{exp_str}
'''
  task_api_description_template  += '''

**Core Task**
Based on the above input, analyze and deduce what basic computational functions may be required to implement this operator. These functional descriptions will be used to subsequently search for matching existing implementations in the API library.

**Output Requirements**
Please output only a JSON array containing 5-15 concise strings. Each string describes an independent functional requirement.
Each string describes ONE primitive operation or low-level kernel capability that is likely required to correctly implement this operator.

**Functional Description Specifications**
Each description should:
- Reflect the core computational intent, not specific implementation details
- Use general terminology without variable names or specific shapes
- Remain functional and reusable
- Be suitable as keywords for semantic retrieval in an API library

Quality Examples (these demonstrate the required style):
```json
[
  "Implement element-wise addition between tensors with broadcasting across arbitrary dimensions",
  "Apply nonlinear activation functions (e.g., ReLU, GELU) on a contiguous tensor region",
  "Execute fused matrix multiplication followed by activation transformation",
  "Compute softmax with numerical stabilization and optional masking support",
  "Perform vectorized dot product reduction across specified tensor dimensions",
  "Execute fused linear transformation with bias addition",
  "Implement tensor reshaping or transposition to adapt data layout",
  "Perform index-based gather operations with boundary checking",
  "Execute fused multiply-add operations for arithmetic acceleration",
  "Compute row-wise or column-wise reduction to aggregate tensor statistics"
]
```

**Important Notes**
- Avoid mentioning specific tensor names, shapes, or hardware details
- Focus on "what functionality is needed" rather than "how to implement it"
- Ensure each description is independent and reusable

**Final Output Format - JOSN ONLY (A JSON array of strings:)**

[
  "<functionality required in the operator 1>",
  "<functionality required in the operator 2>",
  ...
]
'''
  return task_api_description_template

error_description_template = '''
ROLE:
You are a compile/link debugging assistant for Ascend custom operators (C/C++ + pybind).

GOAL:
Your task is to analyze build failure information from Ascend custom operator compilation.
Given the source code and corresponding compiler or linker error logs, you must accurately identify distinct root causes of the failure — such as missing headers, unresolved symbols, ABI mismatches, pybind binding errors, toolchain misconfigurations, or dependency issues.
Each identified issue should represent a unique and meaningful error category, suitable for later lookup of known debugging experiences or fixes.

INPUTS (do NOT echo):
FAIL CODE:
{kernel_content}

FAIL BUILD ERROR LOG:
{compile_info}

GUIDANCE:
- Be concise, analytical, and technically accurate.
- Focus on unique failure categories — avoid listing multiple phrasings or subcases of the same root cause.
- Combine similar or related error patterns into one representative issue instead of splitting them.
- Do not restate or summarize the input code or logs.

OUTPUT — JSON ONLY:

[
"<Accurate FAIL issue 1>",
"<Accurate FAIL issue 2>",
"..."
]

# CONSTRAINTS:
# - Include 1–5 clearly distinct issues if applicable.
# - Each issue must be ≤ 12 words.
# - Ensure each item describes a different underlying cause, not variations or rewordings of the same problem.'''