【AI赋能工作流】一个程序员的自白:我如何利用大语言模型将工作效率提升50%翻译 ChatGPT 会话 之 012 Simplify code with constants
写在前面
- 常量定义?
- 看看 AI 咋做的
Simplify code with constants
2024年7月8日
https://chatgpt.com/share/1b44ae40-ce49-4751-812c-c7d5d38a3383
Simplify code with constants
🧑 User
Fill in the args with constant strings so I can simplify the code
@wrap
def setup():
    worker = ModelWorker(args.controller_address,
                         args.worker_address,
                         worker_id,
                         args.no_register,
                         args.model_path,
                         args.model_base,
                         args.model_name,
                         args.model_type,
                         args.load_8bit,
                         args.load_4bit,
                         args.device)
if name == “main“:
    parser = argparse.ArgumentParser()
    parser.add_argument(“–host”, type=str, default=”localhost”)
    parser.add_argument(“–port”, type=int, default=21002)
    parser.add_argument(“–worker-address”, type=str,
                        default=”http://localhost:21002“)
    parser.add_argument(“–controller-address”, type=str,
                        default=”http://localhost:21001“)
    parser.add_argument(“–model-path”, type=str, default=None)
    parser.add_argument(“–model-base”, type=str, default=None)
    parser.add_argument(“–model-name”, type=str)
    parser.add_argument(“–model-type”, type=str, default=None)
    parser.add_argument(“–device”, type=str, default=”cuda”)
    parser.add_argument(“–multi-modal”, action=”store_true”,
                        help=”Multimodal mode is automatically detected with model name.”)
    parser.add_argument(“–limit-model-concurrency”, type=int, default=5)
    parser.add_argument(“–stream-interval”, type=int, default=1)
    parser.add_argument(“–no-register”, action=”store_true”)
    parser.add_argument(“–load-8bit”, action=”store_true”)
    parser.add_argument(“–load-4bit”, action=”store_true”)
    args = parser.parse_args()
    logger.info(f”args: {args}”)
when run like this
python3 mine2.py –host 0.0.0.0 –port 40000 –controller http://localhost:10000 –worker http://localhost:40000 –model-path ../bunny-phi-2-siglip-lora/ –model-base ../phi-2/ –model-type phi-2
🤖 Assistant
To simplify the code by filling in the arguments with constant strings, you can directly assign the values from the command line arguments to the ModelWorker constructor within the setup function. Here’s how you could adjust your setup function and main block to incorporate the specific arguments you’ve provided:
| 1 | import argparse | 
In this simplified version, I’ve made the following adjustments:
Removed unnecessary command line arguments that are now hardcoded.Directly assigned hardcoded values within the ModelWorker constructor call in the setup function.Kept args.model_name as a command line argument since you mentioned it without a default value, implying it’s required and variable.Assumed worker_id needs to be defined or obtained somehow, as it wasn’t included in your original command line arguments. You might need to adjust this part based on how you intend to assign or obtain the worker_id.Set True for no_register based on your command line setup and assumptions about default values for load_8bit and load_4bit as False, considering they are flags and you did not specify them in your command line example.Adjusted the logging setup to match the simplified context; ensure you configure logging appropriately elsewhere in your code.
Remember, this simplification assumes you’re okay with hardcoding these values and not passing them through the command line anymore, except for the model name which remains variable.
🧑 User
args[‘images’][0] is a base64 encoded image make it pil
🤖 Assistant
To convert a base64 encoded image string to a PIL (Python Imaging Library) image, you first need to decode the base64 string into bytes, and then you can use the BytesIO class from the io module to create a buffer from these bytes. Finally, you use the Image class from the PIL (or its modern fork, Pillow) to open the image from this buffer. Here’s how you can do it:
| 1 | import base64 | 
Make sure you have Pillow installed in your environment, as PIL is outdated and no longer maintained. You can install Pillow using pip if you haven’t already:
| 1 | pip install Pillow | 
This code assumes that the base64 encoded string does not include the data URL scheme (e.g., data:image/png;base64,) that is often used in HTML and CSS. If your base64 string includes this scheme, you’ll need to strip it before decoding, like so:
| 1 | base64_image = args['images'][0].split(",")[-1] | 
This ensures you only attempt to decode the actual base64 data, not the entire data URL.
🧑 User
No do the inverse given image give me base64 function
🤖 Assistant
To convert a PIL (Python Imaging Library) image to a base64 encoded string, you’ll need to first save the image to a bytes buffer using the BytesIO class from the io module, and then encode this buffer using base64. Here’s a function that accomplishes this:
| 1 | import base64 | 
This function:
Takes a PIL Image object as input.Saves the image to a BytesIO buffer in the specified format (defaults to PNG).Encodes the content of this buffer to base64.Decodes the base64 bytes to a UTF-8 string for easier handling and returns it.
You can adjust the format parameter based on the format of your image or your requirements. The resulting base64 string can be used in various contexts, such as embedding images directly into HTML/CSS or for transmitting images over APIs where binary data is not supported.






