[tensorflow] TensorFlow 2.x 에서 1.x 코드 사용하기

 

TensorFlow 2.x는 1.x와 개발 형태가 매우 달라졌다.
2.x에서는 기존 코드를 사용할 수 있는 호환 기능을 제공하지만 기본적으로 아예 새로 만드는 게 좋다.
하지만 대부분의 학습 문서가 아직은 1.x 코드 기준이라 공부하기 어려운 경우가 많다.
이 경우 TensorFlow에서 제공하는 스크립트를 사용하여 1.x의 코드를 2.x에서 돌릴 수 있도록 변환하여 학습을 진행하고 이후 2.x의 코드로 다시 공부해보는 것도 방법일 수 있을 것 같다.

tf_upgrade_v2 변환 스크립트 사용하기

TensorFlow 2.x를 받으면 tf_upgrade_v2 스크립트를 제공한다.

1.x의 코드를 2.x에 호환되도록 변경하려면 아래처럼 변환 스크립트를 사용하면 된다.

tf_upgrade_v2 --infile target.py --outfile result.py

tf_upgrade_v2 encoding 오류 해결

그런데 변환 대상 소스에 한글이 있다면 (보통 주석으로 한글을 쓴 예제 소스가 많다.) 아래와 유사한 형태의 에러가 발생한다.

UnicodeDecodeError: 'cp949' codec can't decode byte 0xed in position 956

이 경우 해당 에러가 발생한 부분의 script의 file 관련 코드를 아래처럼 수정해야 한다.

(설치한 위치의 \Lib\site-packages\tensorflow\tools\compatibility\ast_edits.py 파일의 91x 번대 라인 근처일 것이다.)

# 이런 처리가 되어 있는 부분을
with open(in_filename, "r") as in_file,
    tempfile.NamedTemporaryFile("w", delete=False) as temp_file:

# 이렇게 encoding을 추가해야함
with open(in_filename, "r", encoding='utf8') as in_file,
    tempfile.NamedTemporaryFile("w", delete=False, encoding='utf8') as temp_file:

해당 encoding 설정을 추가한 후 tf_upgrade_v2 스크립트를 다시 실행하면 encoding 오류가 해결된다.

변환된 스크립트의 eager execution 관련 에러 해결

스크립트 변환 후 혹시 아래와 유사한 형태의 에러가 발생한다면

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

tf.placeholder() is not compatible with eager execution.

이 옵션을 추가한다.

tf.compat.v1.disable_eager_execution()

이 에러가 발생한 이유는 2.x에서는 1.x와 다르게 session을 정의하고 run을 수행하는 과정이 생략되고 바로 실행되는 형태로 변경되었기 때문이다.

예를 들면 아래와 같이 변경되었다.

hello = tf.constant('Hello, TensorFlow!')
print(hello)

a = tf.constant(10)
b = tf.constant(32)
c = tf.add(a, b)  # a + b 로도 쓸 수 있음
print(c)

# 1.x의 경우
sess = tf.Session()
print(sess.run(hello))
print(sess.run([a, b, c]))
sess.close()

# 2.x의 경우 Session을 정의해주고 run 해주는 과정이 생략됨
tf.print(hello)
tf.print([a, b, c])
 

출처: https://luvstudy.tistory.com/122 [파란하늘의 지식창고:티스토리]

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25085
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24564
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25943
78 [Kafka] Kafka 한번 살펴보자... Quickstart file 졸리운_곰 2021.06.18 27
77 Java Kafka Producer, Consumer 예제 구현 Java를 이용하여 Kafka Producer와 Kakfa Consumer를 구현해보자. file 졸리운_곰 2021.06.18 105
76 Beginner’s Guide to Understand Kafka file 졸리운_곰 2021.06.18 23
75 [Kafka] Kafka 설치/실행 및 테스트 file 졸리운_곰 2021.06.18 36
74 [java] [kafka] [Kafka] 개념 및 기본예제 file 졸리운_곰 2021.06.16 115
73 Getting started with Apache Kafka in Python file 졸리운_곰 2020.09.10 58
72 [Kafka] 다운로드 및 Quick Start file 졸리운_곰 2020.09.07 35
71 [Kafka] 기본 개념잡기 file 졸리운_곰 2020.09.07 29
70 Flume Integration with Kafka file 졸리운_곰 2019.04.16 103
69 빅데이터: 플럼(Flume) 토폴로지 설계 file 졸리운_곰 2019.04.16 240
68 실시간 처리를 위한 분산 메시징 시스템 카프카(Kafka) file 졸리운_곰 2018.05.12 199
67 Flume과 Kafka를 사용한 초당 100만개 로그 수집 테스트 file 졸리운_곰 2018.05.12 232
66 웹 크롤링 / web crwaling / web scraping / 웹 스크래핑 file 졸리운_곰 2017.07.09 855
65 빅데이터 단지 몇퍼센트의 예측 정확성을 위하여 장애로 가득찬 빅데이터 시스템을 도입하여야 하는가에 대한 의문! file 졸리운_곰 2017.03.20 156
64 빅데이터: 플럼(Flume) 토폴로지 설계 file 졸리운_곰 2017.03.20 129
63 [실시간 분석 시스템] Apache Flume를 활용한 데이터 수집(1) file 졸리운_곰 2017.03.06 111
62 [실시간 분석 시스템] 데이터 수집 #2 Apache Sqoop을 활용하여 RDBMS 데이터 수집(2) file 졸리운_곰 2017.03.06 289
61 [실시간 분석 시스템] 데이터 수집 #2 Apache Sqoop을 활용하여 RDBMS 데이터 수집(1) file 졸리운_곰 2017.03.06 144
60 [실시간 분석 시스템] 데이터 수집 #1 오픈 소스 수집기 비교 file 졸리운_곰 2017.03.06 239
59 [실시간 분석 시스템] 일단 데이터 들여다 보기 file 졸리운_곰 2017.03.06 124
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED