2023-07-02 17:16:13 +00:00
|
|
|
from logging import getLogger
|
2023-11-19 00:13:13 +00:00
|
|
|
from typing import Optional
|
2023-07-02 17:16:13 +00:00
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
|
|
|
from ..params import ImageParams, StageParams, UpscaleParams
|
|
|
|
from ..server import ServerContext
|
|
|
|
from ..worker import WorkerContext
|
2023-11-18 23:18:23 +00:00
|
|
|
from .base import BaseStage
|
2023-11-19 00:08:38 +00:00
|
|
|
from .result import StageResult
|
2023-07-02 17:16:13 +00:00
|
|
|
|
|
|
|
logger = getLogger(__name__)
|
|
|
|
|
|
|
|
|
2023-07-02 23:21:21 +00:00
|
|
|
class UpscaleSimpleStage(BaseStage):
|
2023-07-02 17:16:13 +00:00
|
|
|
def run(
|
|
|
|
self,
|
2023-07-15 23:54:54 +00:00
|
|
|
_worker: WorkerContext,
|
2023-07-02 17:16:13 +00:00
|
|
|
_server: ServerContext,
|
|
|
|
_stage: StageParams,
|
|
|
|
_params: ImageParams,
|
2023-11-19 00:08:38 +00:00
|
|
|
sources: StageResult,
|
2023-07-02 17:16:13 +00:00
|
|
|
*,
|
|
|
|
method: str,
|
|
|
|
upscale: UpscaleParams,
|
|
|
|
stage_source: Optional[Image.Image] = None,
|
|
|
|
**kwargs,
|
2023-11-19 00:08:38 +00:00
|
|
|
) -> StageResult:
|
2023-07-02 17:16:13 +00:00
|
|
|
if upscale.scale <= 1:
|
|
|
|
logger.debug(
|
|
|
|
"simple upscale stage run with scale of %s, skipping", upscale.scale
|
|
|
|
)
|
2023-07-04 18:29:58 +00:00
|
|
|
return sources
|
|
|
|
|
|
|
|
outputs = []
|
2024-01-06 02:11:58 +00:00
|
|
|
for source in sources.as_images():
|
2023-07-04 18:29:58 +00:00
|
|
|
scaled_size = (source.width * upscale.scale, source.height * upscale.scale)
|
2023-07-02 17:16:13 +00:00
|
|
|
|
2023-07-04 18:29:58 +00:00
|
|
|
if method == "bilinear":
|
|
|
|
logger.debug("using bilinear interpolation for highres")
|
2023-11-20 00:39:39 +00:00
|
|
|
outputs.append(
|
|
|
|
source.resize(scaled_size, resample=Image.Resampling.BILINEAR)
|
|
|
|
)
|
2023-07-04 18:29:58 +00:00
|
|
|
elif method == "lanczos":
|
|
|
|
logger.debug("using Lanczos interpolation for highres")
|
2023-11-20 00:39:39 +00:00
|
|
|
outputs.append(
|
|
|
|
source.resize(scaled_size, resample=Image.Resampling.LANCZOS)
|
|
|
|
)
|
2023-07-04 18:29:58 +00:00
|
|
|
else:
|
|
|
|
logger.warning("unknown upscaling method: %s", method)
|
2023-07-02 17:16:13 +00:00
|
|
|
|
2024-01-06 02:11:58 +00:00
|
|
|
return StageResult(images=outputs, metadata=sources.metadata)
|