{ "nbformat": 4, "nbformat_minor": 0, "metadata": { "colab": { "name": "Cellpose_cell_segmentation_2D_prediction_only.ipynb", "provenance": [], "collapsed_sections": [] }, "kernelspec": { "display_name": "Python 3", "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.7.6" }, "accelerator": "GPU" }, "cells": [ { "cell_type": "markdown", "metadata": { "id": "Nb90LCrotIx4" }, "source": [ "#**Cellpose Prediction for 2D v0.2**\n", "A generalist algorithm for cell and nucleus segmentation.\n", "\n", "***Cellpose code: Carsen Stringer & Marius Pachitariu***\n", "\n", "[Link to Paper](https://www.nature.com/articles/s41592-020-01018-x)\n", "\n", "[Link to Video talk](https://t.co/JChCsTD0SK?amp=1) \n", "\n", "Github Repo: https://github.com/MouseLand/cellpose\n", "\n", "The notebook is for processing **2D** images using the Cellpose package on Google Colab using the GPU. It processes images within the folder specified by the user. It will generate a folder called Masks which will contain the label images generated by Cellpose. \n", "\n", "The user can fine-tune and preview the parameters on one image before running it on all images within the folder. The user-specified channel will be used on all images for segmentation.\n", "\n", "This notebook was inspired by the [ZeroCostDL4Mic notebook series](https://github.com/HenriquesLab/ZeroCostDL4Mic/wiki). It was also adapted from colab notebook by Matteo Carandini hosted on the Cellpose github page. \n", "\n", "I have only tested it on jpg and tiff files. Feel free to email me if you have any questions. \n", "\n", "v0.2 update:\n", "\n", "* New models added (Cyto2, Omnipose...) in the notebook, which is quite similar to ZerCostDL4Mic notebook implementation\n", "* Parameters used in cellpose will be saved as a txt file (Thanks for suggestion Kota Miura)\n", "\n", "***Author of this notebook: Pradeep Rajasekhar***\n", "\n", "***Walter and Eliza Hall Institute of Medical Research, Melbourne, Australia***\n", "\n", "rajasekhar.p@wehi.edu.au" ] }, { "cell_type": "markdown", "metadata": { "id": "VbqFni8kuFar" }, "source": [ "#**Configuration**" ] }, { "cell_type": "markdown", "metadata": { "id": "Z0s2fz5hUk75" }, "source": [ "### Make sure you have GPU access enabled by going to Runtime -> Change Runtime Type -> Hardware accelerator and selecting GPU\n", "\n", "![image.png]()" ] }, { "cell_type": "code", "metadata": { "id": "cJdG639F8uRL", "cellView": "form" }, "source": [ "#@markdown ##Step 1: Run this cell to connect your Google Drive to colab\n", "\n", "#@markdown * Click on the URL. \n", "\n", "#@markdown * Sign in your Google Account. \n", "\n", "#@markdown You will either have to:\n", "#@markdown * copy the authorisation code and enter it into box below OR\n", "\n", "#@markdown * in the new google colab, you can just click \"Allow\" and it should connect.\n", "\n", "#@markdown * Click on \"Folder\" icon on the Left, press the refresh button. Your Google Drive folder should now be available here as \"gdrive\". \n", "\n", "# mount user's Google Drive to Google Colab.\n", "from google.colab import drive\n", "drive.mount('/content/gdrive')" ], "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "yH4zTaWwvH9x" }, "source": [ "###**How to get google drive path to your images**\n", "\n", "The above step allows this colab notebook to access your images from google drive. Now, you need the path of your folder containing the images. On the left of your notebook you will see a file icon:\n", "\n", "![image.png]()\n", "\n", "Click on the icon and it will give you:\n", "\n", "![image.png]()\n", "\n", "Your Google drive is under \"gdrive\". Click on the triangle icon on left of gdrive and it will be a dropdown view of your whole drive. Navigate to the folder containing your images. Once you are there, click on the three dots on the right of the folder and select \"Copy Path\"\n", "\n", "![image.png]()\n", "\n", "Copy and paste this path under the **Input_Directory** location below" ] }, { "cell_type": "markdown", "metadata": { "id": "h_iAN7cAthma" }, "source": [ "\n", "\n", "---\n", "\n", "\n", "# **Setup Cellpose**\n", "\n", "\n", "\n", "Install GPU version of Cellpose and configure dependencies\n" ] }, { "cell_type": "code", "metadata": { "id": "hG3LSmJmLylT", "cellView": "form" }, "source": [ "#@markdown ##Step 2: Click Play to Install Cellpose\n", "#@markdown * After cellpose installation, the runtime will restart a warning that it has **crashed**, which is fine. This is essential to configure the environment.\n", "\n", "\n", "#@markdown * On occasion, you may not be able to see the folders on the left panel. Just refresh your browser webpage and it should appear.\n", "#!pip install git+https://www.github.com/mouseland/cellpose.git #to install development version\n", "!pip install cellpose\n", "!pip install torch torchvision torchaudio\n", "\n", "#Fix opencv error: ImportError: cannot import name '_registerMatType' from 'cv2.cv2'\n", "!pip install \"opencv-python-headless<4.3\"\n", "exit(0) #Restart Runtime to use newly installed numpy \n", "#or may get the error: ValueError: numpy.ndarray size changed, may indicate binary incompatibility. Expected 88 from C header, got 80 from PyObject\n", "\n" ], "execution_count": null, "outputs": [] }, { "cell_type": "code", "source": [ "#@markdown ##Step 3: Click Play to configure Cellpose, dependencies and check GPU access\n", "\n", "#@markdown *Models will be downloaded when running for the first time*\n", "#disabled installation and import of mxnet as pytorch is the default neural net\n", "import numpy as np\n", "import time, os, sys, random\n", "from urllib.parse import urlparse\n", "import skimage.io\n", "import matplotlib.pyplot as plt\n", "import matplotlib as mpl\n", "%matplotlib inline\n", "mpl.rcParams['figure.dpi'] = 300\n", "\n", "from urllib.parse import urlparse\n", "import shutil\n", "\n", "#from tifffile import imread, imsave\n", "\n", "\n", "print (\"Downloading Models\")\n", "from cellpose import models,core\n", "\n", "\n", "#https://stackoverflow.com/questions/8924173/how-do-i-print-bold-text-in-python\n", "BOLD = '\\033[1m'\n", "UNDERLINE = '\\033[4m'\n", "END = '\\033[0m'\n", "\n", "#Check if colab notebook instance has GPU access\n", "if core.use_gpu()==False: \n", " #Warnings from the ZeroCost StarDist notebook\n", " print(BOLD+UNDERLINE+'You do not have GPU access.'+END)\n", " print('Did you change your runtime ?') \n", " print('If the runtime setting is correct then Google did not allocate a GPU for your session')\n", " print('Expect slow performance. To access GPU try reconnecting later')\n", " use_GPU=False\n", "else:\n", " print(BOLD+UNDERLINE+\"You have access to the GPU.\"+END+\"\\nDetails are:\")\n", " print(\"*************************************************\")\n", " !nvidia-smi\n", " use_GPU=True\n", "\n", "print(\"*************************************************\")\n", "print(\"Libraries imported and configured\")\n" ], "metadata": { "cellView": "form", "id": "5ydQ-fggSiUm" }, "execution_count": null, "outputs": [] }, { "cell_type": "code", "metadata": { "id": "-lZP6alpUAfY", "cellView": "form" }, "source": [ "#@markdown ###Step 4: Enter Directory path containing the images: \n", "#@markdown ##### Existing Masks directory will be deleted. (Does not read images in subfolders)\n", "Input_Directory = \"/content/gdrive/MyDrive/test_imgs\" #@param {type:\"string\"}\n", "input_dir = os.path.join(Input_Directory, \"\") #adds separator to the end regardless if path has it or not\n", "\n", "#@markdown ###Optional: Enter image extension here to read only files/images of specified extension (.tif,.jpg..): \n", "#@markdown ###### Leave empty if not specifying anything\n", "image_format = \"tif\" #@param {type:\"string\"}\n", "\n", "##@markdown ###Tick if image is RGB: \n", "#RGB= False #@param {type:\"boolean\"}\n", "#rgb=RGB\n", "save_dir = input_dir+\"Masks/\"\n", "if not os.path.exists(save_dir):\n", " os.makedirs(save_dir)\n", "else:\n", " print(\"Existing Mask Directory found. Deleting it.\")\n", " shutil.rmtree(save_dir)\n", "\n", "#@markdown ##### Save Directory will be created in the input path under Masks\n", "\n", "##@markdown ###Advanced Parameters\n", "#Use_Default_Advanced_Parameters = True #@param {type:\"boolean\"}\n", "\n", "\n", "# r=root, d=directories, f = files\n", "files=[]\n", "\n", "for r, d, f in os.walk(input_dir):\n", " for fil in f:\n", " if (image_format):\n", " if fil.endswith(image_format):\n", " files.append(os.path.join(r, fil))\n", " else:\n", " files.append(os.path.join(r, fil))\n", " break #only read the root directory; can change this to include levels\n", "if(len(files)==0):\n", " print(\"Number of images loaded: %d.\" %(len(files)))\n", " print(\"Cannot read image files. Check if folder has images\")\n", "else:\n", " print(\"Number of images loaded: %d.\" %(len(files)))\n", "\n", "\n" ], "execution_count": null, "outputs": [] }, { "cell_type": "code", "metadata": { "id": "98DA8zm4A__m", "cellView": "form" }, "source": [ "#@markdown ###Step 5: Read and Load all the images\n", "#@markdown #####A random image will be shown as an example with each channel separated. If it is a single channel image, only the one channel will be shown\n", "#imgs = [imread(f) for f in files]\n", "\n", "imgs=[] #store all images\n", "#Read images\n", "for f in files:\n", " im=skimage.io.imread(f)\n", " n_dim=len(im.shape) #shape of image\n", " dim=im.shape #dimensions of image\n", " channel=min(dim) #channel will be dimension with min value usually\n", " channel_position=dim.index(channel)\n", " #if no of dim is 3 and channel is first index, swap channel to last index\n", " if n_dim==3 and channel_position==0: \n", " #print(dim)\n", " im=im.transpose(1,2,0)\n", " dim=im.shape\n", " #print(\"Shape changed\")\n", " #print(dim)\n", " imgs.append(im)\n", "\n", "nimg = len(imgs)\n", "print(\"No of images loaded are: \", nimg)\n", "\n", "print(\"Example Image:\")\n", "\n", "random_idx = random.choice(range(len(imgs)))\n", "x=imgs[random_idx]\n", "n_dim=len(x.shape)\n", "file_name=os.path.basename(files[random_idx])\n", "print(file_name+\" has \"+str(n_dim)+\" dimensions/s\")\n", "if n_dim==3:\n", " channel_image=x.shape[2]\n", " fig, axs = plt.subplots(1, channel_image,figsize=(12,5))\n", " print(\"Image: %s\" %(file_name))\n", " for channel in range(channel_image):\n", " axs[channel].imshow(x[:,:,channel])\n", " axs[channel].set_title('Channel '+str(channel+1),size=5)\n", " axs[channel].axis('off')\n", " fig.tight_layout()\n", "elif n_dim==2:\n", " print(\"One Channel\")\n", " plt.imshow(x)\n", "else:\n", " print(\"Channel number invalid or dimensions wrong. Image shape is: \"+str(x.shape))" ], "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "3JRxBPmatrK7" }, "source": [ "\n", "\n", "---\n", "\n", "\n", "# **Run Cellpose**\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "id": "CDIgdlDYHnq4" }, "source": [ "####**Step 6**. Choose the model based on what you want to segment, Cytoplasm to segment whole cell if there is a cytoplasmic marker. \n", "####Choose nucleus to segment the nuclei.\n", "#### If you are using cytoplasm model and have a nuclear channel, this will assist with *segmentation*\n" ] }, { "cell_type": "code", "metadata": { "id": "XcYskYudMajM", "cellView": "form" }, "source": [ "\n", "\n", "#updated the models\n", "\n", "Model_Choice = \"Cytoplasm2\" #@param [\"Cytoplasm\",\"Cytoplasm2\", \"Cytoplasm2_Omnipose\", \"Bacteria_Omnipose\", \"Nuclei\"]\n", "model_choice=Model_Choice\n", "\n", "print(\"Using model \",model_choice)\n", "\n", "#@markdown If the image has only one channel, leave it as 0\n", "Channel_for_segmentation=\"0\" #@param[0,1,2,3]\n", "segment_channel=int(Channel_for_segmentation)\n", "\n", "# @markdown ###If you choose cytoplasm, tick if you have a nuclear channel\n", "Use_nuclear_channel= False #@param {type:\"boolean\"}\n", "Nuclear_channel=\"3\" #@param[1,2,3]\n", "nuclear_channel=int(Nuclear_channel)\n", "\n", "# @markdown ###If cells are elongated or have branches, tick this. It will use omnipose\n", "\n", "omni= False #@param {type:\"boolean\"}\n", "\n", "\n", "#@markdown ### Diameter of cell (pixels):\n", "#@markdown #### Enter 0 if you don't know and cellpose will estimate it automatically. You can define this later as well.\n", "Diameter = 0#@param {type:\"number\"}\n", "diameter=Diameter\n", "\n", "# define CHANNELS to run segementation on\n", "# grayscale=0, R=1, G=2, B=3\n", "# channels = [cytoplasm, nucleus]\n", "# if NUCLEUS channel does not exist, set the second channel to 0\n", "# channels = [0,0]\n", "# IF ALL YOUR IMAGES ARE THE SAME TYPE, you can give a list with 2 elements\n", "# channels = [0,0] # IF YOU HAVE GRAYSCALE\n", "# channels = [2,3] # IF YOU HAVE G=cytoplasm and B=nucleus\n", "# channels = [2,1] # IF YOU HAVE G=cytoplasm and R=nucleus\n", "\n", "\n", "if model_choice==\"Cytoplasm\":\n", " model_type=\"cyto\"\n", "\n", "elif model_choice==\"Cytoplasm2\":\n", " model_type=\"cyto2\"\n", "\n", "elif model_choice==\"Cytoplasm2_Omnipose\":\n", " model_type=\"cyto2_omni\"\n", "\n", "elif model_choice==\"Bacteria_Omnipose\":\n", " model_type=\"bact_omni\" \n", " diameter = 0\n", "\n", "elif model_choice==\"Nuclei\":\n", " model_type=\"nuclei\" \n", "\n", "\n", "# channels = [cytoplasm, nucleus]\n", "if model_choice not in \"Nucleus\":\n", " if Use_nuclear_channel:\n", " channels=[segment_channel,nuclear_channel]\n", " else:\n", " channels=[segment_channel,0]\n", "else: #nucleus\n", " channels=[segment_channel,0]\n", "\n", "\n", "\n", "\n", "# DEFINE CELLPOSE MODEL\n", "# model_type='cyto' or model_type='nuclei'\n", "model = models.Cellpose(gpu=use_GPU, model_type=model_type, omni = omni)\n", "\n", "# define CHANNELS to run segementation on\n", "# grayscale=0, R=1, G=2, B=3\n", "# channels = [cytoplasm, nucleus]\n", "# if NUCLEUS channel does not exist, set the second channel to 0\n", "# channels = [0,0]\n", "# IF ALL YOUR IMAGES ARE THE SAME TYPE, you can give a list with 2 elements\n", "# channels = [0,0] # IF YOU HAVE GRAYSCALE\n", "# channels = [2,3] # IF YOU HAVE G=cytoplasm and B=nucleus\n", "# channels = [2,1] # IF YOU HAVE G=cytoplasm and R=nucleus\n", "\n", "# or if you have different types of channels in each image\n", "#channels = [[2,3], [0,0], [0,0]]\n", "\n", "# if diameter is set to None, the size of the cells is estimated on a per image basis\n", "# you can set the average cell `diameter` in pixels yourself (recommended) \n", "# diameter can be a list or a single number for all images\n", "if diameter is 0:\n", " diameter = None\n", " print(\"Diameter is set to None. The size of the cells will be estimated on a per image basis\")" ], "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "_obeWmo9R4Fb" }, "source": [ "####**Step 6: Test cellpose on an image. You can tune the parameters below based on your image** \n", "\n", "The cell below gives you an opportunity to test different parameters and figure out the right combination that gives your output of interest\n", "\n", "The ***Flow_threshold parameter*** is the maximum allowed error of the flows for each mask. The default is 0.4. \n", "\n", "* **Increase** this threshold if cellpose is not returning as many masks as you’d expect\n", "\n", "* **Decrease** this threshold if cellpose is returning too many ill-shaped masks. \n", "\n", "The ***Cell Probability Threshold*** determines proability that a detected object is a cell. The default is 0.0. \n", "\n", "* **Decrease** this threshold if cellpose is not returning as many masks as you’d expect or if masks are too small\n", "\n", "* **Increase** this threshold if cellpose is returning too many masks esp from dull/dim areas. \n", "\n", "If you do not know **diameter** of the cells OR if cells are of varying diameters, enter 0 in the Diameter box and cellpose will automatically estimate the diameter\n", "\n", "For more information on the parameters: https://cellpose.readthedocs.io/_/downloads/en/latest/pdf/" ] }, { "cell_type": "code", "metadata": { "id": "Rr0UozRm42CA", "cellView": "form" }, "source": [ "from skimage.util import img_as_ubyte\n", "\n", "Image_Number = 1#@param {type:\"number\"}\n", "Image_Number-=1 #indexing starts at zero\n", "#print(Image_Number)\n", "Diameter = 0#@param {type:\"number\"}\n", "#Flow_Threshold=0.4#@param {type:\"number\"}\n", "Flow_Threshold = 0.3 #@param {type:\"slider\", min:0.1, max:1.1, step:0.1}\n", "flow_threshold=Flow_Threshold\n", "\n", "#Cell_Probability_Threshold=-5#@param {type:\"number\"}\n", "#Using slider to restrict values\n", "Cell_Probability_Threshold=-1 #@param {type:\"slider\", min:-6, max:6, step:1}\n", "cellprob_threshold=Cell_Probability_Threshold\n", "\n", "\n", "diameter=Diameter\n", "if diameter is 0:\n", " diameter = None\n", "if Image_Number is -1:\n", " Image_Number=0\n", " #print(\"Image_Number is set to zero, opening first image.\")\n", "try:\n", " image = imgs[Image_Number]\n", "except IndexError as i:\n", " print(\"Image number does not exist\",i)\n", " print(\"Actual no of images in folder: \",len(imgs))\n", "print(\"Image: %s\" %(os.path.splitext(os.path.basename(files[Image_Number]))[0]))\n", "img1=imgs[Image_Number]\n", "\n", "import cv2\n", "\n", "masks, flows, styles, diams = model.eval(img1, diameter=diameter, flow_threshold=flow_threshold,cellprob_threshold=cellprob_threshold, channels=channels)\n", "\n", "\n", "\n", "# DISPLAY RESULTS\n", "from cellpose import plot\n", "maski = masks\n", "flowi = flows[0]\n", "\n", "#convert to 8-bit if not so it can display properly in the graph\n", "if img1.dtype!='uint8':\n", " img1=img_as_ubyte(img1)\n", "\n", "fig = plt.figure(figsize=(24,8))\n", "plot.show_segmentation(fig, img1, maski, flowi, channels=channels)\n", "plt.tight_layout()\n", "plt.show()" ], "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "Y4FwOpghSE8w" }, "source": [ "\n", "\n", "---\n", "\n", "\n", "## **USE CELLPOSE TO SEGMENT CELLS**\n", "The values defined above will be used for segmentation.\n", "\n", "The masks will be saved automatically.\n", "\n", "Saving the flow image/s are optional. Tick if you want to save them.\n", "\n" ] }, { "cell_type": "code", "metadata": { "id": "XVEQ_G1sI-VB", "cellView": "form" }, "source": [ "#@markdown ### **Step 8. Run Cellpose on folder of images**\n", "\n", "#@markdown ###Tick if you want to save the flow image/s: \n", "Save_Flow= False #@param {type:\"boolean\"}\n", "#@markdown ##### *Flow image will be resized when saved\n", "save_flow=Save_Flow\n", "\n", "print(\"Running segmentation on channel %s\" %(segment_channel))\n", "print(\"Using the model: \",model_choice)\n", "if diameter is None:\n", " print(\"Diameter will be estimated from the image/s\")\n", "else:\n", " print(f\"Cellpose will use a diameter of {diameter}\")\n", "\n", "print(f\"Using a flow threshold of: {flow_threshold} and a cell probability threshold of: {cellprob_threshold}\")\n", "\n", "#if too many images, it will lead to memory error. \n", "#will evaluate on a per image basis\n", "#masks, flows, styles, diams = model.eval(imgs, diameter=diameter, flow_threshold=flow_threshold,cellprob_threshold=cellprob_threshold, channels=channels)\n", "\n", "\n", "#save images in folder with the diameter value used in cellpose\n", "print(\"Segmentation Done. Saving Masks and flows now\")\n", "print(\"Save Directory is: \",save_dir)\n", "if (not os.path.exists(save_dir)):\n", " os.mkdir(save_dir)\n", "\n", "if save_flow:\n", " print(\"Saving Flow\")\n", " flows_save_dir=save_dir+\"flows\"+os.sep\n", " print(\"Save Directory for flows is: \",flows_save_dir)\n", " if (not os.path.exists(flows_save_dir)):\n", " os.mkdir(flows_save_dir)\n", "\n", "\n", "for img_idx, img in enumerate(imgs):\n", " file_name=os.path.splitext(os.path.basename(files[img_idx]))[0]\n", " print(\"\\nSegmenting: \",file_name)\n", " mask, flow, style, diam = model.eval(img, diameter=diameter, flow_threshold=flow_threshold,cellprob_threshold=cellprob_threshold, channels=channels)\n", " #save images in folder with the diameter value used in cellpose\n", " print(\"Segmentation complete . Saving Masks and flows\")\n", " #Output name for masks\n", " mask_output_name=save_dir+\"MASK_\"+file_name+\".tif\"\n", " #Save mask as 16-bit in case this has to be used for detecting than 255 objects\n", " mask=mask.astype(np.uint16)\n", " #Save flow as 8-bit\n", " skimage.io.imsave(mask_output_name,mask, check_contrast=False)\n", " if save_flow:\n", " #Output name for flows\n", " flow_output_name=flows_save_dir+\"FLOWS_\"+file_name+\".tif\"\n", " #Save as 8-bit\n", " flow_image=flow[0].astype(np.uint8)\n", " skimage.io.imsave(flow_output_name,flow_image, check_contrast=False)\n", "\n", "#Save parameters used in Cellpose\n", "parameters_file=save_dir+\"Cellpose_parameters_used.txt\" \n", "outFile=open(parameters_file, \"w\") \n", "outFile.write(\"CELLPOSE PARAMETERS\\n\") \n", "outFile.write(\"Model: \"+model_choice+\"\\n\") \n", "if diameter == 0:\n", " diameter = \"Automatically estimated by cellpose\"\n", "outFile.write(\"Omni Flag: \"+str(omni)+\"\\n\") \n", "outFile.write(\"Diameter: \"+str(diameter)+\"\\n\") \n", "outFile.write(\"Flow Threshold: \"+str(flow_threshold)+\"\\n\") \n", "outFile.write(\"Cell probability Threshold: \"+str(cellprob_threshold)+\"\\n\") \n", "outFile.close() \n", "print(\"\\nSegmentation complete and files saved\")" ], "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "Drx_6GbEHIOj" }, "source": [ "---\n", "#**How to extract the ROIs from the mask or label maps using FIJI**\n", "\n", "The masks will be saved as a 16-bit label image, where each cell/ROI is a different colour or label. If you are using ImageJ/FIJI and want to convert this to ROIs for the ROI Manager, there are a few options to convert into ROIs:\n", "\n", "\n", "* SCF plugin (Update site:\thttps://sites.imagej.net/SCF-MPI-CBG/). After [installing the plugin](https://imagej.net/How_to_follow_a_3rd_party_update_site), go to SCF-> Segmentation -> LabelMap to ROI Manager (2D). This should generate the ROIs in ROI Manager\n", "\n", "* Another really nice plugin: [LabelsToROIs](https://github.com/ariel-waisman/LabelsToROis). It has some nice features to adjust the size of the ROIs and generate measurements \n" ] }, { "cell_type": "markdown", "metadata": { "id": "MvpagyDxY1B7" }, "source": [ "###**Save Files as *.npy**\n", "\n", "If you want to save the files so as to view it in the Cellpose GUI, you can save it as an *_seg.npy files in colab that you can download and open in the GUI.\n", "\n", "The file/s will be saved in the Input_Directory\n" ] }, { "cell_type": "code", "metadata": { "cellView": "form", "id": "s7NAuncdY618" }, "source": [ "#@markdown ### **Run this cell to save output of the model as an npy file**\n", "from cellpose import io\n", "\n", "#save output of model eval to be loaded in GUI\n", "io.masks_flows_to_seg(imgs, masks, flows, diams, files, channels)" ], "execution_count": null, "outputs": [] }, { "cell_type": "markdown", "metadata": { "id": "DllTSOoD9lnU" }, "source": [ "\n", "\n", "---\n", "**Acknowledgments:**\n", "\n", "Thanks to Lior Pytowski from University of Oxford for testing this notebook out and giving some really good suggestions\n" ] } ] }