lixiang46 commited on
Commit
4e460bd
·
1 Parent(s): 470fd84
Files changed (1) hide show
  1. app.py +36 -30
app.py CHANGED
@@ -11,7 +11,7 @@ import time
11
  from requests.adapters import HTTPAdapter
12
 
13
  def tryon(person_img, garment_img, seed, randomize_seed):
14
- start_time = time.time()
15
  if person_img is None or garment_img is None:
16
  return None, None, "Empty image"
17
  if randomize_seed:
@@ -31,41 +31,47 @@ def tryon(person_img, garment_img, seed, randomize_seed):
31
  "humanImage": encoded_person_img,
32
  "seed": seed
33
  }
34
- response = requests.post(url, headers=headers, data=json.dumps(data), timeout=40)
35
- print("post response code", response.status_code)
36
- if response.status_code == 200:
37
- result = response.json()['result']
38
- status = result['status']
39
- if status == "success":
40
- uuid = result['result']
41
- print(uuid)
42
-
43
  try:
44
- url = "http://" + os.environ['tryon_url'] + "Query?" + uuid
45
- session = requests.Session()
46
- session.mount("http://", HTTPAdapter(max_retries=3))
47
- response = session.get(url, headers=headers, timeout=10)
48
- print("get response code", response.status_code)
49
  if response.status_code == 200:
50
  result = response.json()['result']
51
  status = result['status']
52
  if status == "success":
53
- result = base64.b64decode(result['result'])
54
- result_np = np.frombuffer(result, np.uint8)
55
- result_img = cv2.imdecode(result_np, cv2.IMREAD_UNCHANGED)
56
- result_img = cv2.cvtColor(result_img, cv2.COLOR_RGB2BGR)
57
- info = "Success"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
58
  else:
59
- info = "Try again latter"
60
- else:
61
- print(response.text)
62
- info = "URL error, pleace contact the admin"
63
- except requests.exceptions.ReadTimeout:
64
- print("timeout")
65
- info = "Too many users, please try again later"
66
- raise gr.Error("Too many users, please try again later")
67
- end_time = time.time()
68
- print(f"time used: {end_time-start_time}")
69
 
70
  return result_img, seed, info
71
 
 
11
  from requests.adapters import HTTPAdapter
12
 
13
  def tryon(person_img, garment_img, seed, randomize_seed):
14
+ post_start_time = time.time()
15
  if person_img is None or garment_img is None:
16
  return None, None, "Empty image"
17
  if randomize_seed:
 
31
  "humanImage": encoded_person_img,
32
  "seed": seed
33
  }
 
 
 
 
 
 
 
 
 
34
  try:
35
+ response = requests.post(url, headers=headers, data=json.dumps(data), timeout=30)
36
+ print("post response code", response.status_code)
 
 
 
37
  if response.status_code == 200:
38
  result = response.json()['result']
39
  status = result['status']
40
  if status == "success":
41
+ uuid = result['result']
42
+ print(uuid)
43
+ finally:
44
+ pass
45
+ post_end_time = time.time()
46
+ print(f"time used: {post_end_time-post_start_time}")
47
+
48
+ get_start_time =time.time()
49
+ Max_Retry = 3
50
+ for i in range(Max_Retry):
51
+ try:
52
+ url = "http://" + os.environ['tryon_url'] + "Query?" + uuid
53
+ response = requests.get(url, headers=headers, timeout=10)
54
+ print("get response code", response.status_code)
55
+ if response.status_code == 200:
56
+ result = response.json()['result']
57
+ status = result['status']
58
+ if status == "success":
59
+ result = base64.b64decode(result['result'])
60
+ result_np = np.frombuffer(result, np.uint8)
61
+ result_img = cv2.imdecode(result_np, cv2.IMREAD_UNCHANGED)
62
+ result_img = cv2.cvtColor(result_img, cv2.COLOR_RGB2BGR)
63
+ info = "Success"
64
+ break
65
  else:
66
+ print(response.text)
67
+ info = "URL error, pleace contact the admin"
68
+ except requests.exceptions.ReadTimeout:
69
+ print("timeout")
70
+ info = "Too many users, please try again later"
71
+ raise gr.Error("Too many users, please try again later")
72
+ time.sleep(3)
73
+ get_end_time = time.time()
74
+ print(f"time used: {get_end_time-get_start_time}")
 
75
 
76
  return result_img, seed, info
77