Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 5 additions & 2 deletions codeflash/code_utils/time_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,14 @@ def humanize_runtime(time_in_ns: int) -> str:
runtime_human = "%.3g" % (time_micro / (1000**2))
elif units in {"minutes", "minute"}:
runtime_human = "%.3g" % (time_micro / (60 * 1000**2))
else: # hours
elif units in {"hour", "hours"}: #hours
runtime_human = "%.3g" % (time_micro / (3600 * 1000**2))

else: #days
runtime_human = "%.3g" % (time_micro / (24*3600 * 1000**2))
runtime_human_parts = str(runtime_human).split(".")
if len(runtime_human_parts[0]) == 1:
if runtime_human_parts[0]=='1' and len(runtime_human_parts)>1:
units = units+'s'
if len(runtime_human_parts) == 1:
runtime_human = f"{runtime_human_parts[0]}.00"
elif len(runtime_human_parts[1]) >= 2:
Expand Down
1 change: 1 addition & 0 deletions codeflash/discovery/functions_to_optimize.py
Original file line number Diff line number Diff line change
Expand Up @@ -206,6 +206,7 @@ def get_functions_to_optimize(
logger.info(f"Found {functions_count} function{'s' if functions_count > 1 else ''} to optimize")
if optimize_all:
three_min_in_ns = int(1.8e11)
console.rule()
logger.info(
f"It might take about {humanize_runtime(functions_count*three_min_in_ns)} to fully optimize this project. Codeflash "
f"will keep opening pull requests as it finds optimizations."
Expand Down
9 changes: 6 additions & 3 deletions tests/test_humanize_time.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,20 +8,23 @@ def test_humanize_runtime():
assert humanize_runtime(1000000000) == "1.00 second"
assert humanize_runtime(60000000000) == "1.00 minute"
assert humanize_runtime(3600000000000) == "1.00 hour"
assert humanize_runtime(86400000000000) == "1.00 day"

assert humanize_runtime(1) == "1.00 nanosecond"
assert humanize_runtime(12) == "12.0 nanoseconds"
assert humanize_runtime(123) == "123 nanoseconds"
assert humanize_runtime(999) == "999 nanoseconds"
assert humanize_runtime(1234) == "1.23 microsecond"
assert humanize_runtime(1234) == "1.23 microseconds"
assert humanize_runtime(12345) == "12.3 microseconds"
assert humanize_runtime(123456) == "123 microseconds"
assert humanize_runtime(1234567) == "1.23 millisecond"
assert humanize_runtime(1234567) == "1.23 milliseconds"
assert humanize_runtime(12345678) == "12.3 milliseconds"
assert humanize_runtime(123456789) == "123 milliseconds"

assert humanize_runtime(1234567891) == "1.23 second"
assert humanize_runtime(1234567891) == "1.23 seconds"
assert humanize_runtime(12345678912) == "12.3 seconds"
assert humanize_runtime(123456789123) == "2.06 minutes"
assert humanize_runtime(1234567891234) == "20.6 minutes"
assert humanize_runtime(12345678912345) == "3.43 hours"
assert humanize_runtime(98765431298760) == "1.14 days"
assert humanize_runtime(197530862597520) == "2.29 days"
Loading