Skip to content

Commit

Permalink
Loose pandas version requirement for python3.8 support
Browse files Browse the repository at this point in the history
  • Loading branch information
Stonesjtu authored Jul 26, 2024
1 parent e53058d commit f426093
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 6 deletions.
21 changes: 16 additions & 5 deletions pytorch_memlab/line_profiler/line_records.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,10 +57,17 @@ def _line_records(raw_line_records: List[Dict[str, Any]], code_infos: List[Dict[
# Column spec: https://pytorch.org/docs/stable/cuda.html#torch.cuda.memory_stats
qual_names = {
code_hash: info['func'].__qualname__ for code_hash, info in code_infos.items()}
records = (_accumulate_line_records(raw_line_records)
.assign(qual_name=lambda df: df.code_hash.map(qual_names))
.set_index(['qual_name', 'line'])
.drop(['code_hash', 'num_alloc_retries', 'num_ooms', 'prev_record_idx'], axis=1))
# pandas < 2.1.0 support (python3.8)
try:
records = (_accumulate_line_records(raw_line_records)
.assign(qual_name=lambda df: df.code_hash.map(qual_names))
.set_index(['qual_name', 'line'])
.drop(['code_hash', 'num_alloc_retries', 'num_ooms', 'prev_record_idx'], axis=1))
except AttributeError:
records = (_accumulate_line_records(raw_line_records)
.assign(qual_name=lambda df: df.code_hash.applymap(qual_names))
.set_index(['qual_name', 'line'])
.drop(['code_hash', 'num_alloc_retries', 'num_ooms', 'prev_record_idx'], axis=1))
records.columns = pd.MultiIndex.from_tuples(
[c.split('.') for c in records.columns])

Expand Down Expand Up @@ -181,7 +188,11 @@ def __repr__(self):
for qual_name, merged in self._merge_line_records_with_code().items():
maxlen = max(len(c) for c in merged.code)
left_align = '{{:{maxlen}s}}'.format(maxlen=maxlen)
merged[byte_cols] = merged[byte_cols].map(readable_size)
# pandas < 2.1.0 support (python3.8)
try:
merged[byte_cols] = merged[byte_cols].map(readable_size)
except AttributeError:
merged[byte_cols] = merged[byte_cols].applymap(readable_size)

# This is a mess, but I can't find any other way to left-align text strings.
code_header = (left_align.format('code'), '', '')
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
install_requires=[
'setuptools',
'calmsize',
'pandas>=2.1.0',
'pandas',
'torch>=2.0',
],
extras_require={
Expand Down

0 comments on commit f426093

Please sign in to comment.