Spaces:
Runtime error
Runtime error
File size: 2,399 Bytes
9aa6aea |
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 78 79 80 81 82 83 84 85 86 87 88 |
# -*- coding: utf-8 -*-
# ===================================================
#
# Author : Fan Zhang
# Email : zhangfan@baai.ac.cn
# Institute : Beijing Academy of Artificial Intelligence (BAAI)
# Create On : 2023-12-13 09:48
# Last Modified : 2023-12-14 01:53
# File Name : utils.py
# Description :
#
# ===================================================
from datetime import datetime
import logging
import logging.config
import hashlib
import os.path as osp
import uuid
from PIL import Image
from decord import VideoReader
def config_logger(logger_name):
logger_config = {
"version": 1,
"formatters": {
"standard": {
"format": "%(asctime)s - %(filename)s: %(lineno)d - [%(levelname)s] - %(message)s",
"datefmt": "%Y-%m-%d %H:%M:%S",
},
},
"handlers": {
"console": {
"class": "logging.StreamHandler",
"formatter": "standard",
"level": "INFO",
},
"file": {
"class": "logging.handlers.TimedRotatingFileHandler",
"filename": osp.join(osp.dirname(__file__), "..", "log", f"{logger_name}.log"),
"formatter": "standard",
"level": "INFO",
"when": "D",
"interval": 7,
"backupCount": 90,
},
},
"loggers": {
logger_name: {
"handlers": ["file", "console"],
"level": "INFO",
"propagate": True,
},
},
}
logging.config.dictConfig(logger_config)
logger = logging.getLogger(logger_name)
return logger
frontend_logger = config_logger("Emu-v2_frontend")
beckend_logger = config_logger("Emu-v2_backend")
def extract_frames(video, num_frames):
video = VideoReader(video)
total_frames = len(video)
segment = int(total_frames // num_frames)
frames = video.get_batch(list(range(int(segment//2), total_frames, segment))).asnumpy()
frames = [Image.fromarray(f) for f in frames]
return frames
def image2md5(image: Image.Image):
md5hash = hashlib.md5(image.tobytes())
return md5hash.hexdigest()
def gen_id():
logid = datetime.now().strftime("%Y%m%d%H%M%d")
logid += f"{uuid.uuid4().hex}"
return logid
|