Reinforcement Learning
stable-baselines3
Joblib
PyTorch
tabular-regression
xgboost
femtosecond-laser
hydrogel
GelMA
HAMA
laser-machining
SAC
materials-science
manufacturing
ml-intern
Instructions to use TWLab/femtosecond-laser-hydrogel-etching-model with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- stable-baselines3
How to use TWLab/femtosecond-laser-hydrogel-etching-model with stable-baselines3:
from huggingface_sb3 import load_from_hub checkpoint = load_from_hub( repo_id="TWLab/femtosecond-laser-hydrogel-etching-model", filename="{MODEL FILENAME}.zip", ) - Notebooks
- Google Colab
- Kaggle
File size: 2,085 Bytes
e2b220f | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | """
Utility functions: configuration loading, logging setup, reproducibility.
"""
from __future__ import annotations
import logging
import os
import random
from pathlib import Path
from typing import Any, Dict
import numpy as np
import torch
import yaml
def set_seed(seed: int = 42) -> None:
"""Set random seeds for full reproducibility across all libraries."""
random.seed(seed)
np.random.seed(seed)
torch.manual_seed(seed)
torch.cuda.manual_seed_all(seed)
os.environ["PYTHONHASHSEED"] = str(seed)
# Deterministic operations (may reduce performance)
torch.backends.cudnn.deterministic = True
torch.backends.cudnn.benchmark = False
def load_yaml_config(path: str | Path) -> Dict[str, Any]:
"""Load YAML configuration file with validation."""
path = Path(path)
if not path.exists():
raise FileNotFoundError(f"Config not found: {path}")
with open(path) as f:
config = yaml.safe_load(f)
return config
def setup_logging(
level: str = "INFO",
log_file: str | Path | None = None,
) -> None:
"""Configure logging for the project."""
handlers = [logging.StreamHandler()]
if log_file:
log_file = Path(log_file)
log_file.parent.mkdir(parents=True, exist_ok=True)
handlers.append(logging.FileHandler(log_file))
logging.basicConfig(
level=getattr(logging, level.upper()),
format="%(asctime)s [%(levelname)s] %(name)s: %(message)s",
datefmt="%Y-%m-%d %H:%M:%S",
handlers=handlers,
force=True,
)
def get_device() -> str:
"""Get best available compute device."""
if torch.cuda.is_available():
return "cuda"
elif hasattr(torch.backends, "mps") and torch.backends.mps.is_available():
return "mps"
return "cpu"
def format_metrics_table(
metrics_dict: Dict[str, Dict[str, float]],
fmt: str = ".4f",
) -> str:
"""Format metrics dictionary as a publication-ready markdown table."""
import pandas as pd
df = pd.DataFrame(metrics_dict).T
return df.to_markdown(floatfmt=fmt)
|