Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Modify _log_input_summary function #7811

Open
wants to merge 20 commits into
base: dev
Choose a base branch
from
Open
Changes from 3 commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
bf9db2c
Modify _log_input_summary function
hyacinth97223 May 27, 2024
7f2633e
Modify "_log_input_summary" function
hyacinth97223 May 27, 2024
aa3d6ac
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 27, 2024
bacd791
Merge branch 'Project-MONAI:dev' into fix-issue-7513
hyacinth97223 Jun 6, 2024
0c7857a
Merge branch 'Project-MONAI:dev' into fix-issue-7513
hyacinth97223 Sep 12, 2024
60b9947
modify _log_input_summary function.
hyacinth97223 Sep 12, 2024
4fe7d52
Merge branch 'fix-issue-7513' of https://github.com/hyacinth97223/MON…
hyacinth97223 Sep 12, 2024
1fda340
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Sep 12, 2024
93ad7a5
fix: auto-fix imports in scripts.py
hyacinth97223 Sep 12, 2024
930ce2c
fix: auto-fix imports in scripts.py
hyacinth97223 Sep 12, 2024
c55e9c7
fix: auto-fix imports in scripts.py
hyacinth97223 Sep 12, 2024
d914f4e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Sep 12, 2024
dec4b0c
Merge branch 'Project-MONAI:dev' into fix-issue-7513
hyacinth97223 Sep 18, 2024
e7fcd41
Merge branch 'Project-MONAI:dev' into fix-issue-7513
hyacinth97223 Sep 18, 2024
9440c80
Merge branch 'Project-MONAI:dev' into fix-issue-7513
hyacinth97223 Sep 19, 2024
43ca23d
Fix log_input_summary function
hyacinth97223 Sep 19, 2024
7eb7b79
Merge branch 'fix-issue-7513' of https://github.com/hyacinth97223/MON…
hyacinth97223 Sep 19, 2024
a9507ad
Merge branch 'Project-MONAI:dev' into fix-issue-7513
hyacinth97223 Sep 23, 2024
69001d7
Fix log_input_summary
hyacinth97223 Sep 23, 2024
a4ae330
Merge branch 'fix-issue-7513' of https://github.com/hyacinth97223/MON…
hyacinth97223 Sep 23, 2024
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
11 changes: 8 additions & 3 deletions monai/bundle/scripts.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
# limitations under the License.

from __future__ import annotations
from io import StringIO

import ast
import json
Expand Down Expand Up @@ -116,10 +117,14 @@ def _pop_args(src: dict, *args: Any, **kwargs: Any) -> tuple:


def _log_input_summary(tag: str, args: dict) -> None:
logger.info(f"--- input summary of monai.bundle.scripts.{tag} ---")
log_buffer = StringIO()

log_buffer.write(f"--- input summary of monai.bundle.scripts.{tag} ---\n")
for name, val in args.items():
logger.info(f"> {name}: {pprint_edges(val, PPRINT_CONFIG_N)}")
logger.info("---\n\n")
log_buffer.write(f"> {name}: {pprint_edges(val, PPRINT_CONFIG_N)}\n")
log_buffer.write("---\n\n")

logger.info(log_buffer.getvalue())
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change may still not solve the issue mentioned in #7513?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What it seems to me will happen here is the message will be written all at once with one call to logger.info() which has a greater chance of appearing all at once in the output in the presence of multiple GPUs. This is only by chance and isn't guaranteed. What we need in the case of multiple GPUs is to identify which process is rank 0 and only it writes to the logger by default but with an option to allow everyone to write if desired. With the torch.distributed package this would be:

import torch.distributed as dist
...
rank = dist.get_rank() if dist.is_initialized() else 0

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ericspod Thanks for your advise. I will try it.



def _get_var_names(expr: str) -> list[str]:
Expand Down
Loading