reverseOrder configuration overhaul

This commit is contained in:
Xevion
2019-08-11 03:26:09 -05:00
parent 5329c75f42
commit 2d0f91c5c9
5 changed files with 41 additions and 17 deletions

View File

@@ -18,6 +18,15 @@ The `elements` portion refers to the scores of each element, each being the atom
---
`reverseIndividualOrder` refers to whether or not the program should reverse the output of the lists so that individual list printouts should have elements with higher scores
---
`reverseOrder` refers to the order in which the list of lists is sorted, `False` being longer lists at the top and `True` being shorter lists at the top, and vice-verse for the bottom.
---
`noNegatives` refers to whether it should filter out elements that have a negative score (ie. while using default configs, filter out elements without a score set)
A set of elements with the score (-1, 5) would get filtered out, while a set with the scores (78, 12) would not.

View File

Binary file not shown.

View File

@@ -11,7 +11,7 @@
"9": -1,
"10": -1,
"11": -1,
"12": -1,
"12": 3,
"13": -1,
"14": -1,
"15": -1,
@@ -19,22 +19,22 @@
"17": -1,
"18": -1,
"19": -1,
"20": -1,
"20": 3,
"21": -1,
"22": -1,
"23": -1,
"24": -1,
"25": -1,
"26": -1,
"27": -1,
"27": 1,
"28": -1,
"29": -1,
"30": -1,
"31": -1,
"32": -1,
"33": -1,
"34": -1,
"35": -1,
"33": 1,
"34": 1,
"35": 1,
"36": -1,
"37": -1,
"38": -1,
@@ -120,7 +120,8 @@
"118": -1
},
"minimumScore": 1,
"reverseSorting": false,
"reverseInnerOrder": false,
"reverseOrder" : false,
"noNegatives" : true,
"fullPrint" : true
}

View File

@@ -19,16 +19,20 @@ def formatting(e1, e2):
def hasNegatives(item):
return score(item[0]) < 0 or score(item[1]) < 0
# get the element based on two letters or a digit and attempt to map it to a number
def getElement(element):
if re.match(r'\d+', element):
return mdv.element(int(element))
element = int(element)
if element >= 1 and element <= 118:
return mdv.element(element)
raise ValueError(f'Unknown Element Atomic Number \'{element}\'')
elif re.match(r'\w{1,2}', element):
try:
return mdv.element(element.strip().title())
except:
raise ValueError('Unknown Element \'{}\''.format(element))
raise ValueError(f'Unknown Element \'{element}\'')
else:
raise ValueError('Unknown Element Format \'{}\''.format(element))
raise ValueError(f'Unknown Element Format \'{element}\'')
def bestSelection(select):
select = select.atomic_number
@@ -42,14 +46,20 @@ def bestSelection(select):
# Filter out elements that do not meet the minimum/maximum set
posi = list(filter(lambda item : scoreSum(item)[0] >= config['minimumScore'], posi))
# Sort the elements by the sum of their scores
posi.sort(key=lambda item : scoreSum(item), reverse=not config['reverseSorting'])
posi.sort(key=lambda item : scoreSum(item), reverse=not config['reverseInnerOrder'])
# Build the strings
string1 = '[Best Elements for Element {}, {}]'.format(select, mdv.element(select).name if config['fullPrint'] else mdv.element(select.symbol))
string2 = '\n'.join([formatting(element1, element2) for element1, element2 in posi])
return string1, string2 or '\t{No elements matched the configuration specified}'
selection = input("Choose elements, delimited by whitespace and/or punctuation...\n")
selection = [getElement(e) for e in selection.split()]
print('\n\n'.join(
sorted(['{}\n{}'.format(*bestSelection(E)) for E in selection], key=lambda string : len(string.split('\n')))
))
# Driver code
def main():
selection = input("Choose elements, delimited by whitespace and/or punctuation...\n")
selection = [getElement(e) for e in selection.split()]
print('\n\n'.join(
sorted(['{}\n{}'.format(*bestSelection(E)) for E in selection],
key=lambda string : len([line for line in string.split('\n') if
# hacky solution for reverseOrder config option
'\t{No elements matched the configuration specified}' not in line]),
reverse=not config['reverseOrder'])
))

4
main.py Normal file
View File

@@ -0,0 +1,4 @@
if __name__ == "__main__":
import sys
from fusion import main
sys.exit(main())