{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# Load the RDF data dump" ] }, { "cell_type": "code", "execution_count": 19, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "27864 triples in Biii data graph\n", "CPU times: user 1.45 s, sys: 40.5 ms, total: 1.49 s\n", "Wall time: 1.81 s\n" ] } ], "source": [ "%%time\n", "from rdflib import ConjunctiveGraph\n", "\n", "ns = {\"nb\": \"http://bise-eu.info/core-ontology#\",\n", " \"dc\": \"http://dcterms/\",\n", " \"p-plan\": \"http://purl.org/net/p-plan#\",\n", " \"edam\": \"http://purl.obolibrary.org/obo/edam#\"}\n", "\n", "g = ConjunctiveGraph()\n", "\n", "### latest version of the RDF dataset dump\n", "g.parse(\"https://raw.githubusercontent.com/bio-tools/content/master/datasets/bise-ontology-biii-dump.ttl\", format=\"turtle\")\n", "g.parse(\"bise-linked-data-webapp/static/data/EDAM-bioimaging_alpha03.owl\")\n", "print(str(len(g)) + ' triples in Biii data graph')" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# Critical Entries +++" ] }, { "cell_type": "code", "execution_count": 21, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "No author and no download link: 115\n", "Missing authors or download link: 533\n", "No EDAM annotations: 319\n", "No License (free text): 1055\n", "CPU times: user 1.04 s, sys: 9.52 ms, total: 1.05 s\n", "Wall time: 1.05 s\n" ] } ], "source": [ "%%time\n", "# Entries without authors and without download link\n", "q = \"\"\"\n", "SELECT (count(?s) as ?nb_soft) WHERE {\n", " ?s rdf:type .\n", " FILTER ( NOT EXISTS {?s nb:hasAuthor ?author} \n", " && NOT EXISTS {?s nb:hasLocation ?location} ).\n", "}\n", "\"\"\"\n", "no_authors_no_link = \"\"\n", "results = g.query(q, initNs=ns)\n", "for r in results:\n", " print('No author and no download link: ' + str(r[\"nb_soft\"]))\n", " no_authors_no_link = r[\"nb_soft\"]\n", "\n", " \n", "# Entries with missing authors or download link\n", "q = \"\"\"\n", "SELECT (count(?s) as ?nb_soft) WHERE {\n", " ?s rdf:type .\n", " FILTER ( NOT EXISTS {?s nb:hasAuthor ?author} \n", " || NOT EXISTS {?s nb:hasLocation ?location} ).\n", "}\n", "\"\"\"\n", "no_authors_no_link = \"\"\n", "results = g.query(q, initNs=ns)\n", "for r in results:\n", " print('Missing authors or download link: ' + str(r[\"nb_soft\"]))\n", " no_authors_no_link = r[\"nb_soft\"]\n", " \n", "\n", "# Entries without any EDAM operation\n", "q = \"\"\"\n", "SELECT (count(?s) as ?nb_soft) WHERE {\n", " ?s rdf:type .\n", " FILTER ( NOT EXISTS {?s nb:hasFunction ?function} \n", " && NOT EXISTS {?s nb:hasTopic ?topic} ).\n", "}\n", "\"\"\"\n", "no_EDAM = \"\"\n", "results = g.query(q, initNs=ns)\n", "for r in results:\n", " print('No EDAM annotations: ' + str(r[\"nb_soft\"]))\n", " no_EDAM = r[\"nb_soft\"]\n", "\n", " \n", "# Entries without license\n", "q = \"\"\"\n", "SELECT (count(?s) as ?nb_soft) WHERE {\n", " ?s rdf:type .\n", " FILTER ( NOT EXISTS {?s nb:hasLicense ?license} ).\n", "}\n", "\"\"\"\n", "no_License = \"\"\n", "results = g.query(q, initNs=ns)\n", "for r in results:\n", " print('No License (free text): ' + str(r[\"nb_soft\"]))\n", " no_License = r[\"nb_soft\"]" ] }, { "cell_type": "code", "execution_count": 22, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Bioimage informatics : 505\n", "Fluorescence microscopy : 88\n", "Machine learning : 67\n", "Imaging : 55\n", "Digital histology : 40\n", "Microscopy : 39\n", "Data sharing : 35\n", "Statistics : 31\n", "Electron microscopy : 28\n", "Light-sheet microscopy : 21\n", "High content screening : 19\n", "Light microscopy : 19\n", "Confocal microscopy : 17\n", "Super-resolution microscopy : 16\n", "Confocal fluorescence microscopy : 15\n", "Single molecule localization microscopy : 15\n", "Live sample imaging : 13\n", "Bright field microscopy : 13\n", "Magnetic resonance imaging : 10\n", "Widefield microscopy : 9\n", "Phase contrast microscopy : 9\n", "Tomography : 6\n", "Correlative Light and Electron Microscopy : 6\n", "Supervised learning : 6\n", "Structured illumination microscopy : 6\n", "Serial block-face scanning electron microscopy : 4\n", "In-silico reconstruction : 4\n", "Topic : 3\n", "Fluorescence correlative spectroscopy : 3\n", "Focused ion beam scanning electron microscopy : 3\n", "Computerized tomography : 3\n", "Multi-photon microscopy : 3\n", "Scanning electron microscopy : 3\n", "Electron tomography : 2\n", "In-vivo imaging : 2\n", "Fluctuation based microscopy : 2\n", "Spectroscopy : 2\n", "Image correlation spectroscopy : 2\n", "In-vitro imaging : 2\n", "Fluorescence lifetime imaging microscopy : 2\n", "Point-scanning microscopy : 1\n", "Transmission light microscopy : 1\n", "Cryo electron tomography : 1\n", "CPU times: user 107 ms, sys: 5.47 ms, total: 112 ms\n", "Wall time: 114 ms\n" ] } ], "source": [ "%%time\n", "q = \"\"\"\n", "SELECT ?label (count(distinct ?s1) as ?soft_count) WHERE { \n", " ?s1 a .\n", " ?s1 ?edam_class .\n", " ?edam_class rdfs:label ?label\n", "}\n", "GROUP BY ?edam_class ?label\n", "ORDER BY DESC(?soft_count)\n", "\"\"\"\n", "\n", "results = g.query(q, initNs=ns)\n", "\n", "for r in results:\n", " print (r[\"label\"] + \" : \" + r[\"soft_count\"])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Count the number of tools without any reference publication" ] }, { "cell_type": "code", "execution_count": 23, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "CPU times: user 2 µs, sys: 0 ns, total: 2 µs\n", "Wall time: 6.2 µs\n", "973\n" ] } ], "source": [ "%time\n", "no_doi_query = \"\"\"\n", "SELECT ?s (count(?title) as ?nb_soft) WHERE {\n", " ?s rdf:type .\n", " ?s dc:title ?title .\n", " FILTER NOT EXISTS {?s nb:hasReferencePublication ?publication} .\n", "}\n", "\"\"\"\n", "results = g.query(no_doi_query, initNs=ns)\n", "for r in results:\n", " print(r[\"nb_soft\"])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Count the number of tools with a reference publication" ] }, { "cell_type": "code", "execution_count": 24, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "757\n", "CPU times: user 58.9 ms, sys: 2.33 ms, total: 61.3 ms\n", "Wall time: 60.7 ms\n" ] } ], "source": [ "%%time\n", "doi_query = \"\"\"\n", "SELECT ?s (count(?title) as ?nb_soft) WHERE {\n", " ?s rdf:type .\n", " ?s dc:title ?title .\n", " ?s nb:hasReferencePublication ?publication .\n", "}\n", "\"\"\"\n", "results = g.query(doi_query, initNs=ns)\n", "for r in results:\n", " print(r[\"nb_soft\"])" ] }, { "cell_type": "code", "execution_count": 25, "metadata": { "scrolled": false }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Bioimage informatics : 505\n", "Fluorescence microscopy : 88\n", "Machine learning : 67\n", "Imaging : 55\n", "Digital histology : 40\n", "Microscopy : 39\n", "Data sharing : 35\n", "Statistics : 31\n", "Electron microscopy : 28\n", "Light-sheet microscopy : 21\n", "High content screening : 19\n", "Light microscopy : 19\n", "Confocal microscopy : 17\n", "Super-resolution microscopy : 16\n", "Confocal fluorescence microscopy : 15\n", "Single molecule localization microscopy : 15\n", "Live sample imaging : 13\n", "Bright field microscopy : 13\n", "Magnetic resonance imaging : 10\n", "Widefield microscopy : 9\n", "Phase contrast microscopy : 9\n", "Tomography : 6\n", "Correlative Light and Electron Microscopy : 6\n", "Supervised learning : 6\n", "Structured illumination microscopy : 6\n", "Serial block-face scanning electron microscopy : 4\n", "In-silico reconstruction : 4\n", "Topic : 3\n", "Fluorescence correlative spectroscopy : 3\n", "Focused ion beam scanning electron microscopy : 3\n", "Computerized tomography : 3\n", "Multi-photon microscopy : 3\n", "Scanning electron microscopy : 3\n", "Electron tomography : 2\n", "In-vivo imaging : 2\n", "Fluctuation based microscopy : 2\n", "Spectroscopy : 2\n", "Image correlation spectroscopy : 2\n", "In-vitro imaging : 2\n", "Fluorescence lifetime imaging microscopy : 2\n", "Point-scanning microscopy : 1\n", "Transmission light microscopy : 1\n", "Cryo electron tomography : 1\n", "CPU times: user 102 ms, sys: 3.85 ms, total: 106 ms\n", "Wall time: 107 ms\n" ] } ], "source": [ "%%time\n", "how_many_tools_per_topic = \"\"\"\n", "SELECT ?label (count(distinct ?s1) as ?soft_count) WHERE { \n", " ?s1 a .\n", " ?s1 ?edam_class .\n", " \n", " ?edam_class rdfs:label ?label .\n", "}\n", "GROUP BY ?edam_class ?label\n", "ORDER BY DESC(?soft_count)\n", "\"\"\"\n", "\n", "results = g.query(how_many_tools_per_topic, initNs=ns)\n", "for r in results:\n", " print(r[\"label\"] + \" : \" + r[\"soft_count\"])" ] }, { "cell_type": "code", "execution_count": 26, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Image segmentation : 116\n", "Data handling : 82\n", "Image processing : 73\n", "Visualisation : 70\n", "Image analysis : 69\n", "Image visualisation : 60\n", "Cell segmentation : 56\n", "Object detection : 53\n", "Image registration : 52\n", "Object tracking : 51\n", "Analysis : 44\n", "Filament tracing : 42\n", "Image annotation : 41\n", "Spot detection : 40\n", "Object feature extraction : 40\n", "Image generation : 40\n", "Morphological operation : 37\n", "Neuron image analysis : 32\n", "Image thresholding : 30\n", "Cell tracking : 25\n", "Image deconvolution : 24\n", "Isolated object detection : 24\n", "Colocalisation analysis : 23\n", "Isolated object classification : 23\n", "Image enhancement : 23\n", "Object counting : 22\n", "Interactive segmentation : 22\n", "Shape features : 20\n", "Annotation : 20\n", "Image denoising : 20\n", "Watershed : 19\n", "Rigid registration : 19\n", "Alignment construction : 19\n", "Particle tracking : 18\n", "Pixel classification : 18\n", "Image correction : 18\n", "Image stitching : 18\n", "Active contours : 17\n", "Volume rendering : 17\n", "Image classification : 17\n", "Editing : 17\n", "Smoothing : 17\n", "Image reconstruction : 16\n", "Frequency analysis : 16\n", "Affine registration : 16\n", "Geometrical transform : 16\n", "Conversion : 14\n", "Deformable registration : 14\n", "Synthetic image generation : 14\n", "Skeletonisation : 13\n", "Trajectory analysis : 12\n", "Clustering : 12\n", "Plotting : 12\n", "Object-based colocalisation : 11\n", "Affine : 11\n", "Classification : 11\n", "Image convolution : 11\n", "Illumination correction : 10\n", "Image projection : 10\n", "Pattern recognition : 10\n", "Single molecule localisation : 9\n", "Image crop : 8\n", "Feature enhancement : 8\n", "Landmark detection : 8\n", "Chromatic aberration correction : 7\n", "Pixel-based colocalisation : 7\n", "Distance transform : 7\n", "Drift correction : 7\n", "Rotation : 7\n", "Object registration : 7\n", "Texture extraction : 6\n", "Warping : 6\n", "Closing : 6\n", "Selective plane illumination microscopy reconstruction : 5\n", "Optical flow analysis : 5\n", "Prediction and recognition : 4\n", "Geometric distortion correction : 4\n", "Adaptative thresholding : 4\n", "Overlay : 4\n", "Montage : 4\n", "Isolated object tracking : 4\n", "Dilation : 3\n", "Validation : 3\n", "Operation : 2\n", "Erosion : 2\n", "Local thresholding : 2\n", "Spectral unmixing : 2\n", "Image validation : 2\n", "Optimisation or refinement : 2\n", "Collective object tracking : 2\n", "Wound-healing analysis : 2\n", "Opening : 1\n", "Generation : 1\n", "Homogeneity : 1\n", "Tomography reconstruction : 1\n", "Structured illumination reconstruction : 1\n", "CPU times: user 140 ms, sys: 4.45 ms, total: 144 ms\n", "Wall time: 144 ms\n" ] } ], "source": [ "%%time\n", "how_many_tools_per_operation = \"\"\"\n", "SELECT ?label (count(distinct ?s1) as ?soft_count) WHERE { \n", " ?s1 a .\n", " ?s1 ?edam_class .\n", " \n", " ?edam_class rdfs:label ?label .\n", "}\n", "GROUP BY ?edam_class ?label\n", "ORDER BY DESC(?soft_count)\n", "\"\"\"\n", "\n", "results = g.query(how_many_tools_per_operation, initNs=ns)\n", "for r in results:\n", " print(r[\"label\"] + \" : \" + r[\"soft_count\"])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# Count the number of tool for 2018" ] }, { "cell_type": "code", "execution_count": 27, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "169 registered softwares in 2018\n", "\n", "CPU times: user 211 ms, sys: 2.95 ms, total: 214 ms\n", "Wall time: 213 ms\n" ] } ], "source": [ "%%time\n", "date_query = \"\"\"\n", "SELECT (count(?soft) as ?nb_soft) WHERE {\n", " ?soft a .\n", " ?soft dc:created ?date .\n", " FILTER ((?date > \"2018-01-01T00:00:00\"^^xsd:dateTime) \n", " && (?date < \"2019-01-01T00:00:00\"^^xsd:dateTime))\n", "}\n", "\"\"\"\n", "results = g.query(date_query, initNs=ns)\n", "for r in results:\n", " print('{} registered softwares in 2018'.format(r['nb_soft']))\n", "# print(r[\"label\"] + \" : \" + r[\"soft_count\"])\n", "print()\n" ] }, { "cell_type": "code", "execution_count": 28, "metadata": {}, "outputs": [], "source": [ "import pandas as pd\n", "import matplotlib.pyplot as plt\n", "import matplotlib.dates as mdates" ] }, { "cell_type": "code", "execution_count": 36, "metadata": { "scrolled": false }, "outputs": [ { "data": { "text/plain": [ "" ] }, "execution_count": 36, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "%matplotlib inline\n", "\n", "plt.figure(figsize=(16, 10))\n", "#plt.figure(figsize=(9, 6))\n", "\n", "soft_dates = []\n", "date_query = \"\"\"\n", "SELECT ?soft ?date WHERE {\n", " ?soft a .\n", " ?soft dc:created ?date .\n", "}\n", "\"\"\"\n", "results = g.query(date_query, initNs=ns)\n", "for r in results:\n", " soft_dates.append({'soft':str(r['soft']), 'created':str(r['date'])})\n", "\n", "df = pd.DataFrame(soft_dates)\n", "df[\"created\"] = df[\"created\"].astype(\"datetime64\")\n", "\n", "#df2 = df.groupby([df[\"created\"].dt.year, df[\"created\"].dt.month]).count()\n", "df2 = df.groupby([df[\"created\"].dt.year]).count()\n", "\n", "df2['soft'].cumsum().plot(kind='bar')" ] }, { "cell_type": "code", "execution_count": 39, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
soft
created
2013697
2014150
201513
201653
201799
2018169
2019108
202047
202118
20227
20231
\n", "
" ], "text/plain": [ " soft\n", "created \n", "2013 697\n", "2014 150\n", "2015 13\n", "2016 53\n", "2017 99\n", "2018 169\n", "2019 108\n", "2020 47\n", "2021 18\n", "2022 7\n", "2023 1" ] }, "execution_count": 39, "metadata": {}, "output_type": "execute_result" } ], "source": [ "import seaborn as sns\n", "\n", "per_year_df = df.groupby([df[\"created\"].dt.year]).count()[['soft']]\n", "per_year_df.to_csv('counts_per_year.csv')\n", "per_year_df\n", "\n", "#sns.countplot(per_year_df['soft'])" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [ "\n", "\n" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Ideas of plots : \n", " - cumulative stacked hostogram with : \"no EDAM annotation\" / \"some EDAM annotatino\" to show that we improvve the quality of tool descriptions\n", " - same thing with 4-5 categories for the main Topics\n", " - same thing Tools VS Traing material\n", " - Open Source VS Comercial softwares \n", " " ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": 40, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
TopicCount
0Bioimage informatics505
1Imaging291
2Machine learning70
3Digital histology40
4Data sharing35
5Statistics31
6High content screening19
7In-silico reconstruction4
\n", "
" ], "text/plain": [ " Topic Count\n", "0 Bioimage informatics 505\n", "1 Imaging 291\n", "2 Machine learning 70\n", "3 Digital histology 40\n", "4 Data sharing 35\n", "5 Statistics 31\n", "6 High content screening 19\n", "7 In-silico reconstruction 4" ] }, "execution_count": 40, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#%%time\n", "#get the main Topics\n", "how_many_tools_per_topic = \"\"\"\n", "SELECT ?l (count(distinct ?s1) as ?soft_count) WHERE { \n", "#SELECT ?subclass WHERE { \n", " ?s1 a .\n", " ?c rdfs:subClassOf .\n", " ?c rdfs:label ?l .\n", " ?subclass rdfs:subClassOf* ?c .\n", " ?s1 ?subclass .\n", "}\n", "GROUP BY ?c ?l\n", "ORDER BY DESC(?soft_count)\n", "\"\"\"\n", "\n", "list_of_topics = []\n", "results = g.query(how_many_tools_per_topic, initNs=ns)\n", "for r in results:\n", " list_of_topics.append({'Topic':str(r['l']), 'Count':str(r['soft_count'])}) \n", "#print(list_of_topics)\n", "\n", "df = pd.DataFrame(list_of_topics)\n", "df" ] }, { "cell_type": "code", "execution_count": 41, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
OperationCount
0Analysis543
1Image processing355
2Generation130
3Visualisation128
4Data handling97
5Alignment construction74
6Classification62
7Annotation54
8Conversion14
9Prediction and recognition13
10Clustering12
11Validation5
12Optimisation or refinement2
\n", "
" ], "text/plain": [ " Operation Count\n", "0 Analysis 543\n", "1 Image processing 355\n", "2 Generation 130\n", "3 Visualisation 128\n", "4 Data handling 97\n", "5 Alignment construction 74\n", "6 Classification 62\n", "7 Annotation 54\n", "8 Conversion 14\n", "9 Prediction and recognition 13\n", "10 Clustering 12\n", "11 Validation 5\n", "12 Optimisation or refinement 2" ] }, "execution_count": 41, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#%%time\n", "#get the main Operations\n", "how_many_tools_per_op = \"\"\"\n", "SELECT ?l (count(distinct ?s1) as ?soft_count) WHERE { \n", "#SELECT ?subclass ?l WHERE { \n", " ?s1 a .\n", " ?c rdfs:subClassOf .\n", " ?c rdfs:label ?l .\n", " ?subclass rdfs:subClassOf* ?c .\n", " ?s1 ?subclass .\n", "}\n", "GROUP BY ?c ?l\n", "ORDER BY DESC(?soft_count)\n", "\"\"\"\n", "\n", "list_of_op = []\n", "results = g.query(how_many_tools_per_op, initNs=ns)\n", "for r in results:\n", " list_of_op.append({'Operation':str(r['l']), 'Count':str(r['soft_count'])})\n", "\n", "df = pd.DataFrame(list_of_op)\n", "df" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": 42, "metadata": { "scrolled": true }, "outputs": [], "source": [ "#%%time\n", "list_tools_op_topic = \"\"\"\n", "SELECT ?s1 ?ol ?tl WHERE { \n", " ?s1 a .\n", " ?oc rdfs:subClassOf .\n", " ?oc rdfs:label ?ol .\n", " ?osc rdfs:subClassOf* ?oc .\n", " ?s1 ?osc .\n", " \n", " ?tc rdfs:subClassOf .\n", " ?tc rdfs:label ?tl .\n", " ?tsc rdfs:subClassOf* ?tc .\n", " ?s1 ?tsc .\n", "}\n", "\"\"\"\n", "tools = []\n", "results = g.query(list_tools_op_topic, initNs=ns)\n", "for r in results:\n", " t = {'tool':str(r['s1']), 'operation': str(r['ol']),'topic': str(r['tl'])}\n", " #print(t)\n", " tools.append(t)" ] }, { "cell_type": "code", "execution_count": 44, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "[Text(0, 0, 'Annotation'),\n", " Text(1, 0, 'Visualisation'),\n", " Text(2, 0, 'Data handling'),\n", " Text(3, 0, 'Prediction and recognition'),\n", " Text(4, 0, 'Alignment construction'),\n", " Text(5, 0, 'Analysis'),\n", " Text(6, 0, 'Classification'),\n", " Text(7, 0, 'Generation'),\n", " Text(8, 0, 'Conversion'),\n", " Text(9, 0, 'Image processing'),\n", " Text(10, 0, 'Clustering'),\n", " Text(11, 0, 'Optimisation or refinement'),\n", " Text(12, 0, 'Validation')]" ] }, "execution_count": 44, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "plt.figure(figsize=(16, 10))\n", "\n", "df = pd.DataFrame(tools)\n", "chart = sns.countplot(x=\"operation\", data=df)\n", "chart.set_xticklabels(chart.get_xticklabels(), rotation=45)" ] }, { "cell_type": "code", "execution_count": 45, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "[Text(0, 0, 'Machine learning'),\n", " Text(1, 0, 'Bioimage informatics'),\n", " Text(2, 0, 'Imaging'),\n", " Text(3, 0, 'Data sharing'),\n", " Text(4, 0, 'Digital histology'),\n", " Text(5, 0, 'High content screening'),\n", " Text(6, 0, 'In-silico reconstruction'),\n", " Text(7, 0, 'Statistics')]" ] }, "execution_count": 45, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "plt.figure(figsize=(16, 10))\n", "\n", "df = pd.DataFrame(tools)\n", "chart = sns.countplot(x=\"topic\", data=df)\n", "chart.set_xticklabels(chart.get_xticklabels(), rotation=45)" ] }, { "cell_type": "code", "execution_count": 46, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "[Text(0.5, 0, 'Bioimage informatics'),\n", " Text(1.5, 0, 'Data sharing'),\n", " Text(2.5, 0, 'Digital histology'),\n", " Text(3.5, 0, 'High content screening'),\n", " Text(4.5, 0, 'Imaging'),\n", " Text(5.5, 0, 'In-silico reconstruction'),\n", " Text(6.5, 0, 'Machine learning'),\n", " Text(7.5, 0, 'Statistics')]" ] }, "execution_count": 46, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "plt.figure(figsize=(16, 10))\n", "\n", "df_heatmap = pd.DataFrame(tools) \n", "df_heatmap\n", "df_heatmap_dum = pd.get_dummies(df_heatmap, columns=['operation', 'topic'])\n", "df_heatmap_dum\n", "\n", "df_crosstab = pd.crosstab(df_heatmap['operation'], df_heatmap['topic'])\n", "#df_heatmap_dum.corr()\n", "#sns.heatmap(df_heatmap_dum.corr(), linewidths=.5)\n", "#corr = df_heatmap['operation'].corr(df_heatmap['topic'])\n", "#corr\n", "#sns.heatmap(df_heatmap.corr(), linewidths=.5)\n", "chart = sns.heatmap(df_crosstab, linewidths=5)\n", "chart.set_xticklabels(chart.get_xticklabels(), rotation=45)" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": true }, "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.10" } }, "nbformat": 4, "nbformat_minor": 2 }