Changeset 711 for mds-and-trees
- Timestamp:
- 10/06/17 17:08:12 (7 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
mds-and-trees/tree-genealogy.py
r710 r711 727 727 return creature 728 728 729 def load_creature_props(creature): 730 creature_id = get_id(creature["ID"]) 731 for prop in creature: 732 if prop not in default_props: 733 if prop not in self.props: 734 self.props[prop] = [0 for i in range(nodes)] 735 self.props[prop][creature_id] = creature[prop] 736 737 def load_born_props(creature): 738 nonlocal max_time 739 creature_id = get_id(creature["ID"]) 740 if "Time" in creature: 741 self.time[creature_id] = creature["Time"] + time_offset 742 max_time = max(self.time[creature_id], max_time) 743 744 def load_offspring_props(creature): 745 creature_id = get_id(creature["ID"])#, False) 746 if "FromIDs" in creature: 747 # make sure that ID's of parents are lower than that of their children 748 for i in range(0, len(creature["FromIDs"])): 749 if creature["FromIDs"][i] not in self.ids: 750 get_id("virtual_parent") 751 752 753 # we assign to each parent its contribution to the genotype of the child 754 for i in range(0, len(creature["FromIDs"])): 755 if creature["FromIDs"][i] in self.ids: 756 parent_id = get_id(creature["FromIDs"][i]) 757 else: 758 if creature["FromIDs"][i] not in merged_with_virtual_parent: 759 merged_with_virtual_parent.append(creature["FromIDs"][i]) 760 parent_id = get_id("virtual_parent") 761 inherited = (creature["Inherited"][i] if 'Inherited' in creature else 1) 762 self.parents[creature_id][parent_id] = inherited 763 764 if "Kind" in creature: 765 self.kind[creature_id] = creature["Kind"] 766 else: 767 raise LoadingError("[OFFSPRING] misses the 'FromIDs' field!") 729 768 730 769 # counting the number of expected nodes 731 732 nodes = 0 770 nodes_born, nodes_offspring = 0, 0 733 771 for filename in filenames: 734 772 file = open(filename) … … 739 777 line_arr = line_arr[1].split(' ', 1) 740 778 if line_arr[0] == "[BORN]": 741 nodes += 1 742 779 nodes_born += 1 780 if line_arr[0] == "[OFFSPRING]": 781 nodes_offspring += 1 782 # assuming that either BORN or OFFSPRING is present for each individual (as it should...) 783 nodes = max(nodes_born, nodes_offspring) 743 784 nodes = min(nodes, max_nodes if max_nodes != 0 else nodes)+1 785 744 786 self.parents = [{} for x in range(nodes)] 745 787 self.children = [[] for x in range(nodes)] … … 776 818 break 777 819 778 creature_id = get_id(creature["ID"]) 779 780 # debug 781 if loaded_so_far%1000 == 0: 782 #print(". " + str(creature_id) + " " + str(timelib.time() - lasttime)) 783 lasttime = timelib.time() 784 785 if "Time" in creature: 786 self.time[creature_id] = creature["Time"] + time_offset 787 max_time = max(self.time[creature_id], max_time) 788 789 for prop in creature: 790 if prop not in default_props: 791 if prop not in self.props: 792 self.props[prop] = [0 for i in range(nodes)] 793 self.props[prop][creature_id] = creature[prop] 794 795 loaded_so_far += 1 820 if get_id(creature["ID"], False) is None: 821 loaded_so_far += 1 822 823 load_born_props(creature) 824 load_creature_props(creature) 796 825 797 826 if line_arr[0] == "[OFFSPRING]": … … 801 830 break 802 831 803 if "FromIDs" in creature: 804 # make sure that ID's of parents are lower than that of their children 805 for i in range(0, len(creature["FromIDs"])): 806 if creature["FromIDs"][i] not in self.ids: 807 get_id("virtual_parent") 808 809 creature_id = get_id(creature["ID"])#, False) 810 811 # we assign to each parent its contribution to the genotype of the child 812 for i in range(0, len(creature["FromIDs"])): 813 if creature["FromIDs"][i] in self.ids: 814 parent_id = get_id(creature["FromIDs"][i]) 815 else: 816 if creature["FromIDs"][i] not in merged_with_virtual_parent: 817 merged_with_virtual_parent.append(creature["FromIDs"][i]) 818 parent_id = get_id("virtual_parent") 819 inherited = (creature["Inherited"][i] if 'Inherited' in creature else 1) 820 self.parents[creature_id][parent_id] = inherited 821 822 if "Kind" in creature: 823 self.kind[creature_id] = creature["Kind"] 824 else: 825 raise LoadingError("[OFFSPRING] misses the 'FromIDs' field!") 826 827 if line_arr[0] == "[DIED]" or line_arr[0] == "[BORN]": 832 if get_id(creature["ID"], False) is None: 833 loaded_so_far += 1 834 # load time only if there was no [BORN] yet 835 load_born_props(creature) 836 837 load_offspring_props(creature) 838 839 if line_arr[0] == "[DIED]": 828 840 creature = try_to_load(line_arr[1]) 829 841 if not creature: 830 842 nodes -= 1 831 843 break 832 creature_id = get_id(creature["ID"], False) 833 if creature_id is not None: 834 for prop in creature: 835 if prop not in default_props: 836 if prop not in self.props: 837 self.props[prop] = [0 for i in range(nodes)] 838 self.props[prop][creature_id] = creature[prop] 844 if get_id(creature["ID"], False) is not None: 845 load_creature_props(creature) 846 else: 847 print("NOTE: entry about the death of individual " + creature["ID"] + " before it was born") 848 849 # debug 850 if loaded_so_far%1000 == 0: 851 #print(". " + str(creature_id) + " " + str(timelib.time() - lasttime)) 852 lasttime = timelib.time() 839 853 840 854 # breaking both loops
Note: See TracChangeset
for help on using the changeset viewer.