def test_nomenclature_nodes_edges_multi_inheritance2(self):
        tree = nomenclature_2_nodes_n_edges(PATH_NOMENCLATURE_CSV_MOUSE)
        nodes = tree['nodes']

        self.assertEqual(257, len(nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_35'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_36'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_38'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_39'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_40'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_41'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_159'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_161'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_163'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_164'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_162'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_245'
                for node in nodes))

        edges = tree['edges']
        self.assertTrue(("CS202002013_34", "CS202002013_159") in edges)
        self.assertTrue(("CS202002013_35", "CS202002013_159") in edges)
        self.assertTrue(("CS202002013_36", "CS202002013_161") in edges)
        self.assertTrue(("CS202002013_37", "CS202002013_161") in edges)
        self.assertTrue(("CS202002013_38", "CS202002013_163") in edges)
        self.assertTrue(("CS202002013_39", "CS202002013_164") in edges)
        self.assertTrue(("CS202002013_40", "CS202002013_164") in edges)
        self.assertTrue(("CS202002013_41", "CS202002013_162") in edges)
        self.assertTrue(("CS202002013_162", "CS202002013_160") in edges)

        # multi-inheritance
        self.assertTrue(("CS202002013_35", "CS202002013_245") in edges)
        self.assertTrue(("CS202002013_36", "CS202002013_245") in edges)
        # parent of 38 39 40 41
        self.assertTrue(("CS202002013_162", "CS202002013_245") in edges)
        self.assertFalse(("CS202002013_38", "CS202002013_245") in edges)
        self.assertFalse(("CS202002013_163", "CS202002013_245") in edges)
    def test_nomenclature_nodes_edges_multi_inheritance3(self):
        tree = nomenclature_2_nodes_n_edges(PATH_NOMENCLATURE_CSV_MOUSE)
        nodes = tree['nodes']

        self.assertEqual(257, len(nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_114'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_115'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_116'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_237'
                for node in nodes))
        self.assertTrue(
            any(node['cell_set_accession'] == 'CS202002013_231'
                for node in nodes))

        edges = tree['edges']

        self.assertTrue(("CS202002013_116", "CS202002013_237") in edges)
        # multi-inheritance, 114 115 relations
        self.assertTrue(("CS202002013_231", "CS202002013_237") in edges)
Ejemplo n.º 3
0
 def check(self):
     files = [
         f for f in os.listdir(MARKERS_FOLDER)
         if isfile(join(MARKERS_FOLDER, f))
     ]
     for marker_file in files:
         if not is_whitelist_file(marker_file):
             dendrogram_path = join(DENDROGRAMS_FOLDER,
                                    get_taxonomy_file_name(marker_file))
             print("DEND:" + dendrogram_path)
             if os.path.exists(dendrogram_path):
                 headers, marker_records = read_csv_to_dict(join(
                     MARKERS_FOLDER, marker_file),
                                                            delimiter="\t")
                 if str(dendrogram_path).endswith(".json"):
                     dend = dend_json_2_nodes_n_edges(dendrogram_path)
                 else:
                     dend = nomenclature_2_nodes_n_edges(dendrogram_path)
                 dend_dict = index_dendrogram(dend)
                 self.check_cluster_name(dend_dict, marker_records,
                                         marker_file)
             else:
                 message = "Could not find taxonomy file '{}' for marker '{}'." \
                     .format(dendrogram_path, marker_file)
                 self.reports.append(message)
def visualise_tree(root=None, exact_order=True):
    # tree = read_dendrogram_tree(PATH_DEND_JSON)
    dend = nomenclature_2_nodes_n_edges(PATH_NMN_TABLE)
    tree = generate_dendrogram_tree(dend)

    if root is not None:
        tree = dfs_tree(tree, root)
    marker_expressions = read_marker_file(PATH_MARKERS)

    add_label_metadata(tree)
    node_colors, node_labels, node_sizes, pos = decorate_nodes(
        marker_expressions, tree)

    all_leafs = [
        x for x in tree.nodes(data=True) if tree.out_degree(x[0]) == 0
    ]

    position_leaf_nodes(all_leafs, exact_order, pos)
    position_intermediate_nodes(all_leafs, pos, tree)

    # nx.draw_networkx(tree, pos, node_color=color_map, with_labels=False, arrows=False)
    nx.draw_networkx_nodes(tree,
                           pos,
                           node_color=node_colors,
                           node_size=node_sizes)
    nx.draw_networkx_edges(tree,
                           pos,
                           arrows=True,
                           connectionstyle="arc3,rad=0.1")
    text = nx.draw_networkx_labels(tree, pos, node_labels, font_size=7)
    rotate_leaf_labels(text)

    plt.show()
def add_label_metadata(tree):
    # out = dend_json_2_nodes_n_edges(PATH_DEND_JSON)
    out = nomenclature_2_nodes_n_edges(PATH_NMN_TABLE)
    dend_dict = index_dendrogram(out)
    for node in tree.nodes(data=True):
        dend_node = dend_dict[node[0]]
        if "cell_set_preferred_alias" in dend_node:
            node[1]["label"] = dend_node["cell_set_preferred_alias"]
def generate_cross_species_template(taxonomy_file_path, output_filepath):
    taxon = extract_taxonomy_name_from_path(taxonomy_file_path)
    taxonomy_config = read_taxonomy_config(taxon)

    if taxonomy_config:
        if str(taxonomy_file_path).endswith(".json"):
            dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
        else:
            dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        dend_tree = generate_dendrogram_tree(dend)
        subtrees = get_subtrees(dend_tree, taxonomy_config)
        cross_species_template = []

        headers, cs_by_preferred_alias = read_csv_to_dict(
            CROSS_SPECIES_PATH,
            id_column_name="cell_set_preferred_alias",
            id_to_lower=True)
        headers, cs_by_aligned_alias = read_csv_to_dict(
            CROSS_SPECIES_PATH,
            id_column_name="cell_set_aligned_alias",
            id_to_lower=True)

        for o in dend['nodes']:
            if o['cell_set_accession'] in set.union(
                    *subtrees) and (o['cell_set_preferred_alias']
                                    or o['cell_set_additional_aliases']):
                cross_species_classes = set()
                if o["cell_set_aligned_alias"] and str(
                        o["cell_set_aligned_alias"]).lower(
                        ) in cs_by_aligned_alias:
                    cross_species_classes.add(PCL_BASE + get_class_id(
                        cs_by_aligned_alias[str(o["cell_set_aligned_alias"]).
                                            lower()]["cell_set_accession"]))

                if "cell_set_additional_aliases" in o and o[
                        "cell_set_additional_aliases"]:
                    additional_aliases = str(
                        o["cell_set_additional_aliases"]).lower().split(
                            EXPRESSION_SEPARATOR)
                    for additional_alias in additional_aliases:
                        if additional_alias in cs_by_preferred_alias:
                            cross_species_classes.add(PCL_BASE + get_class_id(
                                cs_by_preferred_alias[additional_alias]
                                ["cell_set_accession"]))

                if len(cross_species_classes):
                    d = dict()
                    d['defined_class'] = PCL_BASE + get_class_id(
                        o['cell_set_accession'])
                    d['cross_species_classes'] = EXPRESSION_SEPARATOR.join(
                        cross_species_classes)

                    cross_species_template.append(d)

        class_robot_template = pd.DataFrame.from_records(
            cross_species_template)
        class_robot_template.to_csv(output_filepath, sep="\t", index=False)
def generate_marker_gene_set_template(taxonomy_file_path, output_filepath):
    taxon = extract_taxonomy_name_from_path(taxonomy_file_path)
    taxonomy_config = read_taxonomy_config(taxon)

    if taxonomy_config:
        if str(taxonomy_file_path).endswith(".json"):
            dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
        else:
            dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        dend_tree = generate_dendrogram_tree(dend)
        subtrees = get_subtrees(dend_tree, taxonomy_config)

        if "Reference_gene_list" in taxonomy_config:
            gene_db_path = ENSEMBLE_PATH.format(
                str(taxonomy_config["Reference_gene_list"][0]).strip().lower())
            gene_names = read_gene_data(gene_db_path)
            minimal_markers = read_markers(
                MARKER_PATH.format(taxon.replace("CCN", "").replace("CS", "")),
                gene_names)

        else:
            minimal_markers = {}

        class_seed = [
            'defined_class', 'Marker_set_of', 'Minimal_markers',
            'Brain_region_abbv', 'Species_abbv', 'Brain_region', 'Parent'
        ]
        class_template = []

        for o in dend['nodes']:
            if o['cell_set_accession'] in set.union(
                    *subtrees) and (o['cell_set_preferred_alias']
                                    or o['cell_set_additional_aliases']):
                if o['cell_set_accession'] in minimal_markers:
                    d = dict()
                    d['defined_class'] = PCL_BASE + get_marker_gene_set_id(
                        o['cell_set_accession'])
                    d['Marker_set_of'] = o['cell_set_preferred_alias']
                    d['Minimal_markers'] = minimal_markers[
                        o['cell_set_accession']]
                    if 'Brain_region_abbv' in taxonomy_config:
                        d['Brain_region_abbv'] = taxonomy_config[
                            'Brain_region_abbv'][0]
                    if 'Species_abbv' in taxonomy_config:
                        d['Species_abbv'] = taxonomy_config['Species_abbv'][0]
                    d['Brain_region'] = taxonomy_config['Brain_region'][0]
                    d['Parent'] = "SO:0001260"  # sequence collection

                    for k in class_seed:
                        if not (k in d.keys()):
                            d[k] = ''
                    class_template.append(d)

        class_robot_template = pd.DataFrame.from_records(class_template)
        class_robot_template.to_csv(output_filepath, sep="\t", index=False)
    def test_nomenclature_nodes_edges(self):
        tree = nomenclature_2_nodes_n_edges(PATH_NOMENCLATURE_CSV)
        nodes = tree['nodes']

        self.assertEqual(177, len(nodes))
        self.assertEqual("CS201912131_4", nodes[3]["cell_set_accession"])
        self.assertEqual("CS201912131_21", nodes[20]["cell_set_accession"])
        self.assertEqual("CS201912131_51", nodes[50]["cell_set_accession"])
        self.assertEqual("CS201912131_181", nodes[176]["cell_set_accession"])

        edges = tree['edges']
        self.assertTrue(("CS201912131_41", "CS201912131_163") in edges)
        self.assertTrue(("CS201912131_40", "CS201912131_144") in edges)
        self.assertTrue(("CS201912131_39", "CS201912131_160") in edges)
        self.assertTrue(("CS201912131_38", "CS201912131_162") in edges)
def generate_homologous_to_template(taxonomy_file_path, all_base_files,
                                    output_filepath):
    """
    Homologous_to relations require a separate template. If this operation is driven by the nomenclature tables,
    some dangling classes may be generated due to root classes that don't have a class and should not be aligned.
    So, instead of nomenclature tables, base files are used for populating homologous to relations. This ensures all
    alignments has a corresponding class.
    Args:
        taxonomy_file_path: path of the taxonomy file
        all_base_files: paths of the all class template base files
        output_filepath: template output file path
    """
    taxon = extract_taxonomy_name_from_path(taxonomy_file_path)
    taxonomy_config = read_taxonomy_config(taxon)

    other_taxonomy_aliases = index_base_files(
        [t for t in all_base_files if taxon not in t])

    if taxonomy_config:
        if str(taxonomy_file_path).endswith(".json"):
            dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
        else:
            dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        dend_tree = generate_dendrogram_tree(dend)
        subtrees = get_subtrees(dend_tree, taxonomy_config)

        data_template = []

        for o in dend['nodes']:
            if o['cell_set_accession'] in set.union(
                    *subtrees) and (o['cell_set_preferred_alias']
                                    or o['cell_set_additional_aliases']):
                d = dict()
                d['defined_class'] = PCL_BASE + get_class_id(
                    o['cell_set_accession'])
                homologous_to = list()
                for other_aliases in other_taxonomy_aliases:
                    if "cell_set_aligned_alias" in o and o["cell_set_aligned_alias"] \
                            and str(o["cell_set_aligned_alias"]).lower() in other_aliases:
                        homologous_to.append(other_aliases[str(
                            o["cell_set_aligned_alias"]).lower()]
                                             ["defined_class"])
                d['homologous_to'] = "|".join(homologous_to)

                data_template.append(d)

        robot_template = pd.DataFrame.from_records(data_template)
        robot_template.to_csv(output_filepath, sep="\t", index=False)
Ejemplo n.º 10
0
 def check(self):
     files = [
         f for f in os.listdir(MARKERS_FOLDER)
         if isfile(join(MARKERS_FOLDER, f))
     ]
     for marker_file in files:
         if not is_whitelist_file(marker_file):
             dendrogram_path = join(DENDROGRAMS_FOLDER,
                                    get_taxonomy_file_name(marker_file))
             if os.path.exists(dendrogram_path):
                 marker_records = read_tsv(join(MARKERS_FOLDER,
                                                marker_file))
                 if str(dendrogram_path).endswith(".json"):
                     dend = dend_json_2_nodes_n_edges(dendrogram_path)
                 else:
                     dend = nomenclature_2_nodes_n_edges(dendrogram_path)
                 self.check_all_nodes_exist(dend, marker_records,
                                            marker_file)
def generate_curated_class_template(taxonomy_file_path, output_filepath):
    taxon = extract_taxonomy_name_from_path(taxonomy_file_path)
    taxonomy_config = read_taxonomy_config(taxon)

    if taxonomy_config:
        if str(taxonomy_file_path).endswith(".json"):
            dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
        else:
            dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        dend_tree = generate_dendrogram_tree(dend)
        subtrees = get_subtrees(dend_tree, taxonomy_config)

        class_curation_seed = [
            'defined_class', 'Curated_synonyms', 'Classification',
            'Classification_comment', 'Classification_pub', 'Expresses',
            'Expresses_comment', 'Expresses_pub', 'Projection_type', 'Layers',
            'Cross_species_text', 'Comment'
        ]
        class_template = []

        for o in dend['nodes']:
            if o['cell_set_accession'] in set.union(
                    *subtrees) and (o['cell_set_preferred_alias']
                                    or o['cell_set_additional_aliases']):
                d = dict()
                d['defined_class'] = PCL_BASE + get_class_id(
                    o['cell_set_accession'])
                if o['cell_set_preferred_alias']:
                    d['prefLabel'] = o['cell_set_preferred_alias']
                elif o['cell_set_additional_aliases']:
                    d['prefLabel'] = str(
                        o['cell_set_additional_aliases']).split(
                            EXPRESSION_SEPARATOR)[0]

                for k in class_curation_seed:
                    if not (k in d.keys()):
                        d[k] = ''
                class_template.append(d)

        class_robot_template = pd.DataFrame.from_records(class_template)
        class_robot_template.to_csv(output_filepath, sep="\t", index=False)
Ejemplo n.º 12
0
 def check(self):
     files = [
         f for f in os.listdir(MARKERS_FOLDER)
         if isfile(join(MARKERS_FOLDER, f))
     ]
     for marker_file in files:
         if not is_whitelist_file(marker_file):
             dendrogram_path = join(DENDROGRAMS_FOLDER,
                                    get_taxonomy_file_name(marker_file))
             if os.path.exists(dendrogram_path):
                 headers, marker_records = read_csv_to_dict(join(
                     MARKERS_FOLDER, marker_file),
                                                            delimiter="\t")
                 if str(dendrogram_path).endswith(".json"):
                     dend = dend_json_2_nodes_n_edges(dendrogram_path)
                 else:
                     dend = nomenclature_2_nodes_n_edges(dendrogram_path)
                 dend_dict = index_dendrogram(dend)
                 self.check_all_node_ids_valid(dend_dict, marker_records,
                                               marker_file)
                 self.check_all_node_ids_unique(marker_file)
def generate_app_specific_template(taxonomy_file_path, output_filepath):
    if str(taxonomy_file_path).endswith(".json"):
        dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
    else:
        dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)

    robot_template_seed = {
        'ID': 'ID',
        'TYPE': 'TYPE',
        'cell_set_color': "A ALLENHELP:cell_set_color"
    }
    dl = [robot_template_seed]

    for o in dend['nodes']:
        if "cell_set_color" in o and o["cell_set_color"]:
            d = dict()
            d['ID'] = 'PCL:' + get_individual_id(o['cell_set_accession'])
            d['TYPE'] = 'owl:NamedIndividual'
            d['cell_set_color'] = str(o["cell_set_color"]).strip()
            dl.append(d)

    robot_template = pd.DataFrame.from_records(dl)
    robot_template.to_csv(output_filepath, sep="\t", index=False)
def generate_denormalised_marker_template(taxonomy_file_path, output_marker_path):
    """
    Enriches existing marker file based on inheritance relations extracted from dendrogram file.
    New maker table, following the same format as the input marker table, with each node associated with a
    non-redundant list of all markers associated with the term in the input + all markers associated with parent terms.
    Args:
        dend_json_path: Path of the dendrogram file
        output_marker_path: Path of the new marker file

    """
    path_parts = taxonomy_file_path.split(os.path.sep)
    taxon = path_parts[len(path_parts) - 1].split(".")[0]
    if str(taxonomy_file_path).endswith(".json"):
        dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
    else:
        dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        taxon = path_parts[len(path_parts) - 1].split(".")[0].replace("nomenclature_table_", "")

    taxonomy_config = read_taxonomy_config(taxon)

    root_nodes = get_root_nodes(taxonomy_config)

    marker_path = MARKER_PATH.format(str(taxon).replace("CCN", "").replace("CS", ""))
    generate_denormalised_marker(dend, marker_path, output_marker_path, root_nodes)
def generate_ind_template(taxonomy_file_path, output_filepath):
    path_parts = taxonomy_file_path.split(os.path.sep)
    taxon = path_parts[len(path_parts) - 1].split(".")[0]

    if str(taxonomy_file_path).endswith(".json"):
        dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
    else:
        dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        taxon = path_parts[len(path_parts) - 1].split(".")[0].replace(
            "nomenclature_table_", "")

    dend_tree = generate_dendrogram_tree(dend)
    taxonomy_config = read_taxonomy_config(taxon)
    allen_descriptions = read_allen_descriptions(
        ALLEN_DESCRIPTIONS_PATH, taxonomy_config['Species_abbv'][0])

    subtrees = get_subtrees(dend_tree, taxonomy_config)

    robot_template_seed = {
        'ID': 'ID',
        'Label': 'LABEL',
        'PrefLabel': 'A skos:prefLabel',
        'Entity Type': 'TI %',
        'TYPE': 'TYPE',
        'Property Assertions': "I 'subcluster of' SPLIT=|",
        'Synonyms': 'A oboInOwl:hasExactSynonym SPLIT=|',
        'Cluster_ID': "A 'cluster id'",
        'Function': 'TI capable_of some %',
        'cell_set_preferred_alias': "A n2o:cell_set_preferred_alias",
        'original_label': "A n2o:original_label",
        'cell_set_label': "A n2o:cell_set_label",
        'cell_set_aligned_alias': "A n2o:cell_set_aligned_alias",
        'cell_set_additional_aliases':
        "A n2o:cell_set_additional_aliases SPLIT=|",
        'cell_set_alias_assignee': "A n2o:cell_set_alias_assignee SPLIT=|",
        'cell_set_alias_citation': "A n2o:cell_set_alias_citation SPLIT=|",
        'Metadata': "A n2o:node_metadata",
        'Exemplar_of': "TI 'exemplar data of' some %",
        'Comment': "A rdfs:comment",
        'Aliases': "A oboInOwl:hasRelatedSynonym SPLIT=|",
        'Rank': "A 'cell_type_rank' SPLIT=|"
    }
    dl = [robot_template_seed]

    synonym_properties = [
        'cell_set_aligned_alias', 'cell_set_additional_aliases'
    ]

    for o in dend['nodes']:
        d = dict()
        d['ID'] = 'PCL:' + get_individual_id(o['cell_set_accession'])
        d['TYPE'] = 'owl:NamedIndividual'
        d['Label'] = o['cell_set_label'] + ' - ' + o['cell_set_accession']
        if 'cell_set_preferred_alias' in o and o['cell_set_preferred_alias']:
            d['PrefLabel'] = o['cell_set_preferred_alias']
        else:
            d['PrefLabel'] = o['cell_set_accession']
        d['Entity Type'] = 'PCL:0010001'  # Cluster
        d['Metadata'] = json.dumps(o)
        d['Synonyms'] = '|'.join([
            o[prop] for prop in synonym_properties
            if prop in o.keys() and o[prop]
        ])
        d['Property Assertions'] = '|'.join(
            sorted([
                'PCL:' + get_individual_id(e[1]) for e in dend['edges']
                if e[0] == o['cell_set_accession']
            ]))
        meta_properties = [
            'cell_set_preferred_alias', 'original_label', 'cell_set_label',
            'cell_set_aligned_alias', 'cell_set_additional_aliases',
            'cell_set_alias_assignee', 'cell_set_alias_citation'
        ]
        for prop in meta_properties:
            if prop in o.keys():
                d[prop] = '|'.join([
                    prop_val.strip() for prop_val in str(o[prop]).split("|")
                    if prop_val
                ])
            else:
                d[prop] = ''
        d['Cluster_ID'] = o['cell_set_accession']
        if o['cell_set_accession'] in set().union(
                *subtrees) and o['cell_set_preferred_alias']:
            d['Exemplar_of'] = PCL_BASE + get_class_id(o['cell_set_accession'])

        if "cell_type_card" in o:
            d['Rank'] = '|'.join([
                cell_type.strip().replace("No", "None")
                for cell_type in str(o["cell_type_card"]).split(",")
            ])

        if o['cell_set_accession'] in allen_descriptions:
            allen_data = allen_descriptions[o['cell_set_accession']]
            d['Comment'] = allen_data["summary"][0]
            if allen_data["aliases"][0]:
                d['Aliases'] = '|'.join([
                    alias.strip()
                    for alias in str(allen_data["aliases"][0]).split("|")
                ])

        # There should only be one!
        dl.append(d)
    robot_template = pd.DataFrame.from_records(dl)
    robot_template.to_csv(output_filepath, sep="\t", index=False)
def generate_base_class_template(taxonomy_file_path, output_filepath):
    taxon = extract_taxonomy_name_from_path(taxonomy_file_path)
    taxonomy_config = read_taxonomy_config(taxon)

    if taxonomy_config:
        if str(taxonomy_file_path).endswith(".json"):
            dend = dend_json_2_nodes_n_edges(taxonomy_file_path)
        else:
            dend = nomenclature_2_nodes_n_edges(taxonomy_file_path)
        dend_tree = generate_dendrogram_tree(dend)
        subtrees = get_subtrees(dend_tree, taxonomy_config)

        if "Reference_gene_list" in taxonomy_config:
            gene_db_path = ENSEMBLE_PATH.format(
                str(taxonomy_config["Reference_gene_list"][0]).strip().lower())
            gene_names = read_gene_data(gene_db_path)
            minimal_markers = read_markers(
                MARKER_PATH.format(taxon.replace("CCN", "").replace("CS", "")),
                gene_names)
            allen_markers = read_markers(
                ALLEN_MARKER_PATH.format(
                    taxon.replace("CCN", "").replace("CS", "")), gene_names)
        else:
            minimal_markers = {}
            allen_markers = {}

        class_seed = [
            'defined_class', 'prefLabel', 'Alias_citations',
            'Synonyms_from_taxonomy', 'Gross_cell_type', 'Taxon',
            'Brain_region', 'Minimal_markers', 'Allen_markers', 'Individual',
            'Brain_region_abbv', 'Species_abbv', 'Cluster_ID', 'part_of',
            'has_soma_location', 'aligned_alias', 'marker_gene_set'
        ]
        class_template = []

        for o in dend['nodes']:
            if o['cell_set_accession'] in set.union(
                    *subtrees) and (o['cell_set_preferred_alias']
                                    or o['cell_set_additional_aliases']):
                d = dict()
                d['defined_class'] = PCL_BASE + get_class_id(
                    o['cell_set_accession'])
                if o['cell_set_preferred_alias']:
                    d['prefLabel'] = o['cell_set_preferred_alias']
                elif o['cell_set_additional_aliases']:
                    d['prefLabel'] = str(
                        o['cell_set_additional_aliases']).split(
                            EXPRESSION_SEPARATOR)[0]
                d['Synonyms_from_taxonomy'] = get_synonyms_from_taxonomy(o)
                d['Gross_cell_type'] = get_gross_cell_type(
                    o['cell_set_accession'], subtrees, taxonomy_config)
                d['Taxon'] = taxonomy_config['Species'][0]
                d['Brain_region'] = taxonomy_config['Brain_region'][0]
                d['Cluster_ID'] = o['cell_set_accession']
                if 'cell_set_alias_citation' in o and o[
                        'cell_set_alias_citation']:
                    alias_citations = [
                        citation.strip() for citation in str(
                            o["cell_set_alias_citation"]).split("|")
                        if citation and citation.strip()
                    ]
                    d["Alias_citations"] = "|".join(alias_citations)
                if o['cell_set_accession'] in minimal_markers:
                    d['Minimal_markers'] = minimal_markers[
                        o['cell_set_accession']]
                if o['cell_set_accession'] in allen_markers:
                    d['Allen_markers'] = allen_markers[o['cell_set_accession']]
                else:
                    d['Allen_markers'] = ''
                if 'Brain_region_abbv' in taxonomy_config:
                    d['Brain_region_abbv'] = taxonomy_config[
                        'Brain_region_abbv'][0]
                if 'Species_abbv' in taxonomy_config:
                    d['Species_abbv'] = taxonomy_config['Species_abbv'][0]
                d['Individual'] = PCL_BASE + get_individual_id(
                    o['cell_set_accession'])

                for index, subtree in enumerate(subtrees):
                    if o['cell_set_accession'] in subtree:
                        location_rel = taxonomy_config['Root_nodes'][index][
                            'Location_relation']
                        if location_rel == "part_of":
                            d['part_of'] = taxonomy_config['Brain_region'][0]
                            d['has_soma_location'] = ''
                        elif location_rel == "has_soma_location":
                            d['part_of'] = ''
                            d['has_soma_location'] = taxonomy_config[
                                'Brain_region'][0]

                if "cell_set_aligned_alias" in o and o[
                        "cell_set_aligned_alias"]:
                    d['aligned_alias'] = o["cell_set_aligned_alias"]
                if o['cell_set_accession'] in minimal_markers:
                    d['marker_gene_set'] = PCL_PREFIX + get_marker_gene_set_id(
                        o['cell_set_accession'])

                for k in class_seed:
                    if not (k in d.keys()):
                        d[k] = ''
                class_template.append(d)

        class_robot_template = pd.DataFrame.from_records(class_template)
        class_robot_template.to_csv(output_filepath, sep="\t", index=False)