{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "intended-spectacular",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "from PencilDrawingBySketchAndTone import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77d905fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_pencil_drawing_v2(img, kernel_size, stroke_width=0, num_of_directions=8, smooth_kernel=\"gauss\",\n",
    "                       gradient_method=0, rgb=False, w_group=0, pencil_texture_path=\"\", stroke_darkness=1, tone_darkness=1):\n",
    "    if not rgb:\n",
    "        # Grayscale image:\n",
    "        im = img\n",
    "    else:\n",
    "        # RGB image:\n",
    "        yuv_img = color.rgb2yuv(img)\n",
    "        im = yuv_img[:,:,0]\n",
    "    # Generate the Stroke Map:\n",
    "    S = gen_stroke_map(im, kernel_size, stroke_width=stroke_width, num_of_directions=num_of_directions,\n",
    "                       smooth_kernel=smooth_kernel, gradient_method=gradient_method)\n",
    "    S = np.power(S, stroke_darkness)\n",
    "    # Generate the Tone Map:\n",
    "    J = gen_tone_map(im, w_group=w_group)\n",
    "    \n",
    "    # Read the pencil texture:\n",
    "    if not pencil_texture_path:\n",
    "        pencil_texture = io.imread('drawing-patterns/drawing-pattern-I.jpg', as_gray=True)\n",
    "    else:\n",
    "        pencil_texture = io.imread(pencil_texture_path, as_gray=True)\n",
    "    # Generate the Pencil Texture Map:\n",
    "    T = gen_pencil_texture(im, pencil_texture, J)\n",
    "    T = np.power(T, tone_darkness)\n",
    "    # The final Y channel:\n",
    "    R = np.multiply(S, T)\n",
    "    \n",
    "    if not rgb:\n",
    "        return R\n",
    "    else:\n",
    "        yuv_img[:,:,0] = R\n",
    "        return S,J,T,R,exposure.rescale_intensity(color.yuv2rgb(yuv_img), in_range=(0, 1))\n",
    "\n",
    "directory = 'path/to/imagenet/val/'\n",
    "classes = sorted(entry.name for entry in os.scandir(directory) if entry.is_dir())\n",
    "image_locations = []\n",
    "for cls in classes:\n",
    "    image_locations += sorted([os.path.join(directory,cls,entry.name) for entry in os.scandir(directory+'/'+cls)])\n",
    "\n",
    "os.makedirs('../examples_drawing', exist_ok=True)\n",
    "for idx in [8*50, 9*50+1, 10*50+7, 234*50+5, 779*50+1, 786*50+3, 790*50+5, 794*50+7,\n",
    "            235*50+1, 802*50+0, 803*50+8, 808*50+9, 809*50+2, 814*50+5, 891*50+5, 909*50+0]:\n",
    "    load_path = image_locations[idx]\n",
    "    pencil_tex = 'drawing-patterns/drawing-pattern-I.jpg'\n",
    "    img_pencil = cv2.cvtColor(cv2.imread(pencil_tex), cv2.COLOR_BGR2RGB)\n",
    "    img = cv2.cvtColor(cv2.imread(load_path), cv2.COLOR_BGR2RGB)\n",
    "    img = cv2.resize(img, (256, 256), interpolation = cv2.INTER_AREA)\n",
    "    S,J,T,R,img_drawing = gen_pencil_drawing_v2(img, kernel_size=8, stroke_width=1, num_of_directions=8, smooth_kernel=\"gauss\",\n",
    "                       gradient_method=1, rgb=True, w_group=2, pencil_texture_path=pencil_tex,\n",
    "                               stroke_darkness=2, tone_darkness=1.5)\n",
    "    fig, axs = plt.subplots(1,7,figsize=(15,5))\n",
    "    extension = image_locations[idx].split('.')[-1]\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_imagenet.{extension}', cv2.cvtColor(img, cv2.COLOR_RGB2BGR))\n",
    "    axs[0].imshow(img)\n",
    "    axs[0].axis('off')\n",
    "    axs[0].set_title('Original Image')\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_imagenet_S.{extension}', S*255)\n",
    "    axs[1].imshow(S, cmap='gray')\n",
    "    axs[1].axis('off')\n",
    "    axs[1].set_title('S - Pencil Stroke')\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_imagenet_J.{extension}', J*255)\n",
    "    axs[2].imshow(J, cmap='gray')\n",
    "    axs[2].axis('off')\n",
    "    axs[2].set_title('J - Tonal Map')\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_imagenet_T.{extension}', T*255)\n",
    "    axs[3].imshow(T, cmap='gray')\n",
    "    axs[3].axis('off')\n",
    "    axs[3].set_title('T - Tonal Texture')\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_imagenet_R.{extension}', R*255)\n",
    "    axs[4].imshow(R, cmap='gray')\n",
    "    axs[4].axis('off')\n",
    "    axs[4].set_title('R - Pencil Sketch')\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_imagenet_drawing.{extension}', cv2.cvtColor(np.clip(img_drawing*255, 0, 255).astype(np.uint8),cv2.COLOR_RGB2BGR))\n",
    "    axs[5].imshow(img_drawing)\n",
    "    axs[5].axis('off')\n",
    "    axs[5].set_title('Final Image')\n",
    "    img_drawing_pattern = cv2.resize(img_pencil, (img_pencil.shape[1], img_pencil.shape[0]), interpolation = cv2.INTER_AREA)\n",
    "    cv2.imwrite(f'../examples_drawing/id_{idx}_drawing_pattern.{extension}', img_drawing_pattern)\n",
    "    axs[6].imshow(img_drawing_pattern)\n",
    "    axs[6].axis('off')\n",
    "    axs[6].set_title('Drawing Pattern')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a1800b2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
