{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Created with lambdify. Signature:\n",
      "\n",
      "func(x, y, s, t)\n",
      "\n",
      "Expression:\n",
      "\n",
      "Matrix([[-2*s*x*(s*Abs(x) - Abs(x))*sign(x)/((2*s*Abs(x) - s -...\n",
      "\n",
      "Source code:\n",
      "\n",
      "def _lambdifygenerated(x, y, s, t):\n",
      "    return array([[-2*s*x*(s*abs(x) - abs(x))*sign(x)/((2*s*abs(x) - s - 1)**2*abs(x)) + x*(s*sign(x) - sign(x))/((2*s*abs(x) - s - 1)*abs(x)) + (s*abs(x) - abs(x))/((2*s*abs(x) - s - 1)*abs(x)) - (s*abs(x) - abs(x))*sign(x)/(x*(2*s*abs(x) - s - 1)), 0], [0, -2*t*y*(t*abs(y) - abs(y))*sign(y)/((2*t*abs(y) - t - 1)**2*abs(y)) + y*(t*sign(y) - sign(y))/((2*t*abs(y) - t - 1)*abs(y)) + (t*abs(y) - abs(y))/((2*t*abs(y) - t - 1)*abs(y)) - (t*abs(y) - abs(y))*sign(y)/(y*(2*t*abs(y) - t - 1))]])\n",
      "\n",
      "\n",
      "Imported modules:\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from sympy import *\n",
    "import numpy as np\n",
    "\n",
    "x, y, s, t, p, q = symbols('x y s t, p, q', real=True)\n",
    "init_printing(use_unicode=True)\n",
    "\n",
    "r_x = abs(x)\n",
    "r_y = abs(y)\n",
    "\n",
    "f1 = x*(s*r_x - r_x)/(2*s*r_x - s - 1) / r_x\n",
    "f2 = y*(t*r_y - r_y)/(2*t*r_y - t - 1) / r_y\n",
    "\n",
    "f = Matrix([f1, f2])\n",
    "X = Matrix([x, y])\n",
    "\n",
    "jac = f.jacobian(X)\n",
    "\n",
    "func = lambdify((x, y, s, t), jac, 'numpy')\n",
    "\n",
    "a = np.random.rand(2, 100)\n",
    "\n",
    "print(func.__doc__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Created with lambdify. Signature:\n",
      "\n",
      "func(x, y, s, t)\n",
      "\n",
      "Expression:\n",
      "\n",
      "Matrix([[x*(1 - 2*Abs(x))*(s*Abs(x) - Abs(x))/((2*s*Abs(x) - s -...\n",
      "\n",
      "Source code:\n",
      "\n",
      "def _lambdifygenerated(x, y, s, t):\n",
      "    return array([[x*(1 - 2*abs(x))*(s*abs(x) - abs(x))/((2*s*abs(x) - s - 1)**2*abs(x)) + x/(2*s*abs(x) - s - 1)], [0]])\n",
      "\n",
      "\n",
      "Imported modules:\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "ds = f.diff(s)\n",
    "\n",
    "func = lambdify((x, y, s, t), ds, 'numpy')\n",
    "print(func.__doc__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\left[\\begin{matrix}- \\frac{2 s x \\left(s \\left|{x}\\right| - \\left|{x}\\right|\\right) \\operatorname{sign}{\\left(x \\right)}}{\\left(2 s \\left|{x}\\right| - s - 1\\right)^{2} \\left|{x}\\right|} + \\frac{x \\left(s \\operatorname{sign}{\\left(x \\right)} - \\operatorname{sign}{\\left(x \\right)}\\right)}{\\left(2 s \\left|{x}\\right| - s - 1\\right) \\left|{x}\\right|} + \\frac{s \\left|{x}\\right| - \\left|{x}\\right|}{\\left(2 s \\left|{x}\\right| - s - 1\\right) \\left|{x}\\right|} - \\frac{\\left(s \\left|{x}\\right| - \\left|{x}\\right|\\right) \\operatorname{sign}{\\left(x \\right)}}{x \\left(2 s \\left|{x}\\right| - s - 1\\right)} & 0\\\\0 & - \\frac{2 t y \\left(t \\left|{y}\\right| - \\left|{y}\\right|\\right) \\operatorname{sign}{\\left(y \\right)}}{\\left(2 t \\left|{y}\\right| - t - 1\\right)^{2} \\left|{y}\\right|} + \\frac{y \\left(t \\operatorname{sign}{\\left(y \\right)} - \\operatorname{sign}{\\left(y \\right)}\\right)}{\\left(2 t \\left|{y}\\right| - t - 1\\right) \\left|{y}\\right|} + \\frac{t \\left|{y}\\right| - \\left|{y}\\right|}{\\left(2 t \\left|{y}\\right| - t - 1\\right) \\left|{y}\\right|} - \\frac{\\left(t \\left|{y}\\right| - \\left|{y}\\right|\\right) \\operatorname{sign}{\\left(y \\right)}}{y \\left(2 t \\left|{y}\\right| - t - 1\\right)}\\end{matrix}\\right]$"
      ],
      "text/plain": [
       "⎡  2⋅s⋅x⋅(s⋅│x│ - │x│)⋅sign(x)   x⋅(s⋅sign(x) - sign(x))        s⋅│x│ - │x│   \n",
       "⎢- ─────────────────────────── + ─────────────────────── + ───────────────────\n",
       "⎢                      2          (2⋅s⋅│x│ - s - 1)⋅│x│    (2⋅s⋅│x│ - s - 1)⋅│\n",
       "⎢     (2⋅s⋅│x│ - s - 1) ⋅│x│                                                  \n",
       "⎢                                                                             \n",
       "⎢                                                                             \n",
       "⎢                                                   0                         \n",
       "⎢                                                                             \n",
       "⎣                                                                             \n",
       "\n",
       "     (s⋅│x│ - │x│)⋅sign(x)                                                    \n",
       "── - ─────────────────────                                                    \n",
       "x│    x⋅(2⋅s⋅│x│ - s - 1)                                                     \n",
       "                                                                              \n",
       "                                                                              \n",
       "                              2⋅t⋅y⋅(t⋅│y│ - │y│)⋅sign(y)   y⋅(t⋅sign(y) - sig\n",
       "                            - ─────────────────────────── + ──────────────────\n",
       "                                                  2          (2⋅t⋅│y│ - t - 1)\n",
       "                                 (2⋅t⋅│y│ - t - 1) ⋅│y│                       \n",
       "\n",
       "                                                     ⎤\n",
       " 0                                                   ⎥\n",
       "                                                     ⎥\n",
       "                                                     ⎥\n",
       "                                                     ⎥\n",
       "n(y))        t⋅│y│ - │y│        (t⋅│y│ - │y│)⋅sign(y)⎥\n",
       "───── + ───────────────────── - ─────────────────────⎥\n",
       "⋅│y│    (2⋅t⋅│y│ - t - 1)⋅│y│    y⋅(2⋅t⋅│y│ - t - 1) ⎥\n",
       "                                                     ⎦"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "jac"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "l2s",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "bd2e4dcb18364cf6748816343f17347a14b50de30c2ca4007709e12fed921ebc"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
