Skip to main content
Glama
phuihock

TA-Lib MCP Server

by phuihock

calculate_sarext

Calculate Parabolic SAR Extended (SAREXT) for technical analysis of financial markets, identifying potential trend reversals and stop-loss levels.

Instructions

Calculate Parabolic SAR Extended (SAREXT).

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
kwargsYes

Implementation Reference

  • The MCP tool handler for 'calculate_sarext', decorated with @mcp.tool() for registration, delegates to SAREXTIndicator.calculate()
    @mcp.tool() async def calculate_sarext(high: List[float], low: List[float], startvalue: Optional[float] = None, offsetonreverse: float = 0.0, acceleration_initlong: float = 0.02, acceleration_long: float = 0.02, acceleration_maxlong: float = 0.2, acceleration_initshort: float = 0.02, acceleration_short: float = 0.02, acceleration_maxshort: float = 0.2) -> Dict[str, Any]: try: indicator = registry.get_indicator("sarext") if not indicator: raise ValueError("SAREXT indicator not found") market_data = MarketData(close=[0], high=high, low=low) opts = {"startvalue": startvalue, "offsetonreverse": offsetonreverse, "acceleration_initlong": acceleration_initlong, "acceleration_long": acceleration_long, "acceleration_maxlong": acceleration_maxlong, "acceleration_initshort": acceleration_initshort, "acceleration_short": acceleration_short, "acceleration_maxshort": acceleration_maxshort} result = await indicator.calculate(market_data, opts) if result.success: return {"success": True, "values": result.values, "metadata": result.metadata} return {"success": False, "error": result.error_message} except Exception as e: return {"success": False, "error": str(e)}
  • Input schema definition for the SAREXT indicator, matching the tool parameters.
    @property def input_schema(self) -> Dict[str, Any]: return { "type": "object", "properties": { "high_prices": {"type": "array", "items": {"type": "number"}}, "low_prices": {"type": "array", "items": {"type": "number"}}, "startvalue": {"type": ["number", "null"]}, "offsetonreverse": {"type": "number", "default": 0.0}, "acceleration_initlong": {"type": "number", "default": 0.02}, "acceleration_long": {"type": "number", "default": 0.02}, "acceleration_maxlong": {"type": "number", "default": 0.2}, "acceleration_initshort": {"type": "number", "default": 0.02}, "acceleration_short": {"type": "number", "default": 0.02}, "acceleration_maxshort": {"type": "number", "default": 0.2}, }, "required": ["high_prices", "low_prices"], }
  • Registration of SAREXTIndicator in the indicators registry under key 'sarext', used by the tool handler.
    registry.register("sarext", SAREXTIndicator)
  • Core calculation logic using TA-Lib's SAREXT function, called by the tool handler.
    async def calculate(self, market_data: MarketData, options: Dict[str, Any] = None) -> IndicatorResult: if options is None: options = {} high = np.asarray(market_data.high or [], dtype=float) low = np.asarray(market_data.low or [], dtype=float) # Map our input option keys (snake_case) to TA-Lib SAREXT parameter names key_map = { "startvalue": "startvalue", "offsetonreverse": "offsetonreverse", "acceleration_initlong": "accelerationinitlong", "acceleration_long": "accelerationlong", "acceleration_maxlong": "accelerationmaxlong", "acceleration_initshort": "accelerationinitshort", "acceleration_short": "accelerationshort", "acceleration_maxshort": "accelerationmaxshort", } params = {} for src_key, ta_key in key_map.items(): if src_key in options and options.get(src_key) is not None: params[ta_key] = options.get(src_key) try: out = ta.SAREXT(high, low, **params) return IndicatorResult(indicator_name=self.name, success=True, values={"sarext": out.tolist()}, metadata={"input_points": len(high), "output_points": len(out)}) except Exception as e: return IndicatorResult(indicator_name=self.name, success=False, values={}, error_message=str(e))

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/phuihock/mcp-talib'

If you have feedback or need assistance with the MCP directory API, please join our Discord server