단 한 줄의 코드로 엘릭서를 두 배 빠르게 만들 수 있습니다! PyTorch 2.0이 깜짝 등장하고 LeCun이 열정적으로 이를 전달합니다.
12월 2일, PyTorch 2.0이 공식 출시되었습니다!
이 업데이트는 PyTorch의 성능을 새로운 차원으로 끌어올릴 뿐만 아니라 동적 모양 및 분포에 대한 지원도 추가합니다.
또한 2.0 시리즈에서는 일부 PyTorch 코드를 C++에서 Python으로 다시 이동할 예정입니다.
현재 PyTorch 2.0은 아직 테스트 단계에 있으며 첫 번째 안정 버전은 2023년 3월 초에 출시될 예정입니다.
PyTorch 2.x: 더 빠르고, 더 파이썬적입니다!
지난 몇 년 동안 PyTorch는 1.0부터 최근 1.13까지 혁신과 반복을 거쳐 새로 형성된 PyTorch 재단으로 이동하여 Linux 재단의 일부가 되었습니다.
현재 버전의 PyTorch의 문제점은 열성 모드가 계속 증가하는 GPU 대역폭과 더 열악한 모델 아키텍처를 따라잡는 데 어려움을 겪는다는 것입니다.
PyTorch 2.0의 탄생은 PyTorch가 컴파일러 수준에서 실행되는 방식을 근본적으로 바꾸고 개선할 것입니다.
우리 모두 알고 있듯이 PyTorch의 (Py)는 데이터 과학에서 널리 사용되는 오픈 소스 Python 프로그래밍 언어에서 유래되었습니다.
하지만 PyTorch의 코드는 Python을 완전히 사용하지 않고 일부를 C++에 제공합니다.
그러나 향후 2.x 시리즈에서 PyTorch 프로젝트 팀은 torch.nn 관련 코드를 다시 Python으로 이동할 계획입니다.
게다가 PyTorch 2.0은 완전한 추가 기능(및 선택 사항) 기능이므로 2.0은 이전 버전과 100% 호환됩니다.
즉, 코드 베이스도 같고, API도 같고, 모델을 작성하는 방식도 같습니다.
추가 기술 지원
- TorchDynamo
PyTorch 프로그램을 안전하게 캡처하기 위해 Python 프레임워크 평가 후크를 사용하는 것은 지난 5년 동안 그래프 캡처 팀에서 개발한 주요 혁신입니다.
- AOTAutograd
예측 역추적을 생성하기 위한 추적 자동 비교로 PyTorch의 autograd 엔진을 오버로드합니다.
- PrimTorch
는 ~2000개 이상의 PyTorch 연산자를 개발자가 완전한 PyTorch 백엔드를 구축할 수 있는 ~250개의 기본 연산자의 닫힌 세트로 요약합니다. PyTorch 기능이나 백엔드 작성에 대한 장벽이 크게 낮아졌습니다.
- TorchInductor
여러 가속기와 백엔드를 위한 빠른 코드를 생성할 수 있는 딥 러닝 컴파일러입니다. Nvidia GPU의 경우 OpenAI Triton을 핵심 빌딩 블록으로 사용합니다.
TorchDynamo, AOTAutograd, PrimTorch 및 TorchInductor가 모두 Python으로 작성되었으며 동적 모양을 지원한다는 점은 주목할 가치가 있습니다.
빠른 훈련 속도
새로운 컴파일 모드 "torch.compile"을 도입함으로써 PyTorch 2.0은 코드 한 줄로 모델 훈련을 가속화할 수 있습니다.
여기에는 트릭이 필요하지 않습니다. 그냥 torch.compile()을 실행하면 됩니다:
opt_module = torch.compile(module)
이러한 기술을 검증하기 위해 팀은 이미지 분류, 객체 감지, 이미지 생성 등의 작업은 물론 언어 모델링, 질문 답변, 시퀀스 분류, 추천 시스템 등 다양한 NLP 작업을 포함하는 테스트 벤치마크를 신중하게 생성했습니다. , 강화 학습 등이 있습니다. 그중 벤치마크는 세 가지 범주로 나눌 수 있습니다.
- HuggingFace Transformers의 46개 모델
- TIMM의 61개 모델: Ross Wightman의 최첨단 PyTorch 이미지 모델 컬렉션
- TorchBench의 56개 모델: github 인기 있는 코드 라이브러리 세트
테스트 결과에 따르면 비전, NLP 및 기타 분야를 포괄하는 163개 오픈 소스 모델에서 훈련 속도가 38%-76% 향상되었습니다.
NVIDIA A100 GPU 비교
또한 팀은 일부 인기 오픈 소스 PyTorch 모델에 대한 벤치마크 테스트를 실시한 결과 30%에서 2배로 상당한 속도 향상을 얻었습니다.
개발자 Sylvain Gugger는 다음과 같이 말했습니다. “단 한 줄의 코드로 PyTorch 2.0은 Transformers 모델 학습 시 1.5배에서 2.0배의 속도 향상을 달성할 수 있습니다. 이는 혼합 정밀도 학습이 등장한 이후 가장 흥미로운 것입니다. technical 개요
pytorch의 컴파일러는 세 부분으로 분류 될 수 있습니다. Graph 획득
graph retuction graph compilations, pytorch 컴파일러를 구축 할 때 그래프 획득은 더 어려운 과제입니다. .
- TorchDynamo
팀은 올해 초 Framework Evaluation API라는 PEP-0523에 도입된 CPython 기능을 사용하여 TorchDynamo 작업을 시작했습니다.
이를 위해 팀은 PyTorch로 작성된 7,000개 이상의 Github 프로젝트를 검증 세트로 사용하여 그래프 캡처에 대한 TorchDynamo의 효율성을 검증하기 위해 데이터 기반 접근 방식을 취했습니다.
결과에 따르면 TorchDynamo는 무시할 수 있는 오버헤드로 99%의 시간 동안 정확하고 안전하게 그래프 캡처를 수행할 수 있습니다.
TorchInductor
PyTorch 2.0의 새로운 컴파일러 백엔드의 경우 팀은 사용자가 고성능 사용자 정의 커널을 작성하는 방법에서 영감을 얻었습니다. Triton 언어를 점점 더 많이 사용하고 있습니다.
TorchInductor는 Python으로 정의된 루프별 레벨 IR을 사용하여 PyTorch 모델을 GPU에서 생성된 Triton 코드와 CPU에서 C++/OpenMP에 자동으로 매핑합니다.
TorchInductor의 핵심 루프 수준 IR에는 약 50개의 연산자만 포함되어 있으며 Python으로 구현되어 있어 확장이 쉽습니다.
AOTAutograd
훈련 속도를 높이려면 사용자 수준 코드뿐만 아니라 역전파도 캡처해야 합니다.
AOTAutograd는 PyTorch의 torch_dispatch 확장 메커니즘을 사용하여 Autograd 엔진을 추적하고 역전파를 "미리" 캡처한 다음 TorchInductor를 사용하여 순방향 및 역방향 채널을 가속화할 수 있습니다.
PrimTorch
PyTorch에는 1200개 이상의 연산자가 있으며, 각 연산자의 다양한 오버로드를 고려하면 2000개 이상입니다. 따라서 백엔드 또는 도메인 간 기능을 작성하는 것은 에너지를 소비하는 작업이 됩니다.
PrimTorch 프로젝트에서 팀은 더 작고 안정적인 두 개의 연산자 세트를 정의했습니다.
- Prim ops에는 컴파일러에 적합한 약 250개의 연산자가 있습니다. 레벨이 충분히 낮기 때문에 좋은 성능을 얻으려면 함께 융합하면 됩니다.
- ATen ops에는 있는 그대로 출력하기에 적합한 약 750개의 일반 연산자가 있습니다. 이는 ATEN 수준에 이미 통합되어 있거나 컴파일되지 않은 백엔드에 적합하므로 Prim ops와 같은 낮은 수준 연산자 세트의 성능을 복원합니다.
동적 모양
PyTorch 코드에서 일반성을 지원하는 데 필요한 것이 무엇인지 살펴볼 때 핵심 요구 사항은 동적 모양을 지원하고 모델이 매번 모양을 변경하지 않고 다른 크기의 텐서를 수용할 수 있도록 허용하는 것이었습니다. 재컴파일을 유발합니다.
동적 모양이 지원되지 않는 경우 일반적인 해결 방법은 가장 가까운 2의 거듭제곱으로 패딩하는 것입니다. 그러나 아래 차트에서 볼 수 있듯이 상당한 성능 오버헤드가 발생하고 컴파일 시간도 상당히 길어집니다.
이제 동적 모양을 지원하는 PyTorch 2.0은 Eager보다 최대 40% 더 높은 성능을 달성했습니다.
마지막으로 팀은 PyTorch 2.x 로드맵에서 성능과 확장성 측면에서 컴파일 모델을 더욱 발전시키기를 희망합니다.
위 내용은 단 한 줄의 코드로 엘릭서를 두 배 빠르게 만들 수 있습니다! PyTorch 2.0이 깜짝 등장하고 LeCun이 열정적으로 이를 전달합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











기존 컴퓨팅을 능가할 뿐만 아니라 더 낮은 비용으로 더 효율적인 성능을 달성하는 인공 지능 모델을 상상해 보세요. 이것은 공상과학 소설이 아닙니다. DeepSeek-V2[1], 세계에서 가장 강력한 오픈 소스 MoE 모델이 여기에 있습니다. DeepSeek-V2는 경제적인 훈련과 효율적인 추론이라는 특징을 지닌 전문가(MoE) 언어 모델의 강력한 혼합입니다. 이는 236B 매개변수로 구성되며, 그 중 21B는 각 마커를 활성화하는 데 사용됩니다. DeepSeek67B와 비교하여 DeepSeek-V2는 더 강력한 성능을 제공하는 동시에 훈련 비용을 42.5% 절감하고 KV 캐시를 93.3% 줄이며 최대 생성 처리량을 5.76배로 늘립니다. DeepSeek은 일반 인공지능을 연구하는 회사입니다.

이달 초 MIT와 기타 기관의 연구자들은 MLP에 대한 매우 유망한 대안인 KAN을 제안했습니다. KAN은 정확성과 해석성 측면에서 MLP보다 뛰어납니다. 그리고 매우 적은 수의 매개변수로 더 많은 수의 매개변수를 사용하여 실행되는 MLP보다 성능이 뛰어날 수 있습니다. 예를 들어 저자는 KAN을 사용하여 더 작은 네트워크와 더 높은 수준의 자동화로 DeepMind의 결과를 재현했다고 밝혔습니다. 구체적으로 DeepMind의 MLP에는 약 300,000개의 매개변수가 있는 반면 KAN에는 약 200개의 매개변수만 있습니다. KAN은 MLP와 같이 강력한 수학적 기반을 가지고 있으며, KAN은 Kolmogorov-Arnold 표현 정리를 기반으로 합니다. 아래 그림과 같이 KAN은

Google이 추진하는 JAX의 성능은 최근 벤치마크 테스트에서 Pytorch와 TensorFlow를 능가하여 7개 지표에서 1위를 차지했습니다. 그리고 JAX 성능이 가장 좋은 TPU에서는 테스트가 이루어지지 않았습니다. 개발자들 사이에서는 여전히 Tensorflow보다 Pytorch가 더 인기가 있습니다. 그러나 앞으로는 더 큰 모델이 JAX 플랫폼을 기반으로 훈련되고 실행될 것입니다. 모델 최근 Keras 팀은 기본 PyTorch 구현을 사용하여 세 가지 백엔드(TensorFlow, JAX, PyTorch)와 TensorFlow를 사용하는 Keras2를 벤치마킹했습니다. 첫째, 그들은 주류 세트를 선택합니다.

Boston Dynamics Atlas가 공식적으로 전기 로봇 시대에 돌입했습니다! 어제 유압식 Atlas가 역사의 무대에서 "눈물을 흘리며" 물러났습니다. 오늘 Boston Dynamics는 전기식 Atlas가 작동 중이라고 발표했습니다. 상업용 휴머노이드 로봇 분야에서는 보스턴 다이내믹스가 테슬라와 경쟁하겠다는 각오를 다진 것으로 보인다. 새 영상은 공개된 지 10시간 만에 이미 100만 명이 넘는 조회수를 기록했다. 옛 사람들은 떠나고 새로운 역할이 등장하는 것은 역사적 필연이다. 올해가 휴머노이드 로봇의 폭발적인 해라는 것은 의심의 여지가 없습니다. 네티즌들은 “로봇의 발전으로 올해 개막식도 인간처럼 생겼고, 자유도도 인간보다 훨씬 크다. 그런데 정말 공포영화가 아닌가?”라는 반응을 보였다. 영상 시작 부분에서 아틀라스는 바닥에 등을 대고 가만히 누워 있는 모습입니다. 다음은 입이 떡 벌어지는 내용이다

AI는 실제로 수학을 변화시키고 있습니다. 최근 이 문제에 주목하고 있는 타오저쉬안(Tao Zhexuan)은 '미국수학회지(Bulletin of the American Mathematical Society)' 최신호를 게재했다. '기계가 수학을 바꿀 것인가?'라는 주제를 중심으로 많은 수학자들이 그들의 의견을 표현했습니다. 저자는 필즈상 수상자 Akshay Venkatesh, 중국 수학자 Zheng Lejun, 뉴욕대학교 컴퓨터 과학자 Ernest Davis 등 업계의 유명 학자들을 포함해 강력한 라인업을 보유하고 있습니다. AI의 세계는 극적으로 변했습니다. 이 기사 중 상당수는 1년 전에 제출되었습니다.

표적 탐지는 자율주행 시스템에서 상대적으로 성숙한 문제이며, 그 중 보행자 탐지는 가장 먼저 배포되는 알고리즘 중 하나입니다. 대부분의 논문에서 매우 포괄적인 연구가 수행되었습니다. 그러나 서라운드 뷰를 위한 어안 카메라를 사용한 거리 인식은 상대적으로 덜 연구되었습니다. 큰 방사형 왜곡으로 인해 표준 경계 상자 표현은 어안 카메라에서 구현하기 어렵습니다. 위의 설명을 완화하기 위해 확장된 경계 상자, 타원 및 일반 다각형 디자인을 극/각 표현으로 탐색하고 인스턴스 분할 mIOU 메트릭을 정의하여 이러한 표현을 분석합니다. 제안된 다각형 형태의 모델 fisheyeDetNet은 다른 모델보다 성능이 뛰어나며 동시에 자율 주행을 위한 Valeo fisheye 카메라 데이터 세트에서 49.5% mAP를 달성합니다.

테슬라의 로봇 옵티머스(Optimus)의 최신 영상이 공개됐는데, 이미 공장에서 작동이 가능한 상태다. 정상 속도에서는 배터리(테슬라의 4680 배터리)를 다음과 같이 분류합니다. 공식은 또한 20배 속도로 보이는 모습을 공개했습니다. 작은 "워크스테이션"에서 따고 따고 따고 : 이번에 출시됩니다. 영상에는 옵티머스가 공장에서 이 작업을 전 과정에 걸쳐 사람의 개입 없이 완전히 자율적으로 완료하는 모습이 담겨 있습니다. 그리고 Optimus의 관점에서 보면 자동 오류 수정에 중점을 두고 구부러진 배터리를 집어 넣을 수도 있습니다. NVIDIA 과학자 Jim Fan은 Optimus의 손에 대해 높은 평가를 했습니다. Optimus의 손은 세계의 다섯 손가락 로봇 중 하나입니다. 가장 능숙합니다. 손은 촉각적일 뿐만 아니라

1. 소개 지난 몇 년 동안 YOLO는 계산 비용과 감지 성능 간의 효과적인 균형으로 인해 실시간 객체 감지 분야에서 지배적인 패러다임이 되었습니다. 연구원들은 YOLO의 아키텍처 설계, 최적화 목표, 데이터 확장 전략 등을 탐색하여 상당한 진전을 이루었습니다. 동시에 사후 처리를 위해 NMS(비최대 억제)에 의존하면 YOLO의 엔드투엔드 배포가 방해되고 추론 대기 시간에 부정적인 영향을 미칩니다. YOLO에서는 다양한 구성 요소의 설계에 포괄적이고 철저한 검사가 부족하여 상당한 계산 중복이 발생하고 모델 기능이 제한됩니다. 이는 최적이 아닌 효율성을 제공하며 성능 향상을 위한 상대적으로 큰 잠재력을 제공합니다. 이 작업의 목표는 사후 처리와 모델 아키텍처 모두에서 YOLO의 성능 효율성 경계를 더욱 향상시키는 것입니다. 이를 위해
