PyTorch-퀵 가이드
PyTorch는 Python 용 오픈 소스 머신 러닝 라이브러리로 정의됩니다. 자연어 처리와 같은 응용 프로그램에 사용됩니다. 처음에는 Facebook 인공 지능 연구 그룹과 Uber의 Pyro 소프트웨어를 기반으로하는 확률 적 프로그래밍을 위해 개발했습니다.
원래 PyTorch는 Torch 프레임 워크를 기반으로하는 LusJIT 용 Python 래퍼로 Hugh Perkins에 의해 개발되었습니다. 두 가지 PyTorch 변형이 있습니다.
PyTorch는 백엔드 코드에 대해 동일한 핵심 C 라이브러리를 공유하면서 Python에서 Torch를 재 설계하고 구현합니다. PyTorch 개발자는 Python을 효율적으로 실행하기 위해이 백엔드 코드를 조정했습니다. 그들은 또한 GPU 기반 하드웨어 가속과 Lua 기반 Torch를 만든 확장 성 기능을 유지했습니다.
풍모
PyTorch의 주요 기능은 다음과 같습니다.
Easy Interface− PyTorch는 사용하기 쉬운 API를 제공합니다. 따라서 운영이 매우 간단하고 Python에서 실행되는 것으로 간주됩니다. 이 프레임 워크에서 코드 실행은 매우 쉽습니다.
Python usage−이 라이브러리는 Python 데이터 과학 스택과 원활하게 통합되는 Pythonic으로 간주됩니다. 따라서 Python 환경에서 제공하는 모든 서비스와 기능을 활용할 수 있습니다.
Computational graphs− PyTorch는 동적 계산 그래프를 제공하는 우수한 플랫폼을 제공합니다. 따라서 사용자는 런타임 중에 변경할 수 있습니다. 이것은 개발자가 신경망 모델을 만드는 데 필요한 메모리 양을 모를 때 매우 유용합니다.
PyTorch는 아래와 같이 세 가지 수준의 추상화를 가지고있는 것으로 알려져 있습니다.
Tensor-GPU에서 실행되는 명령형 n 차원 배열.
Variable-계산 그래프의 노드. 이것은 데이터와 그라디언트를 저장합니다.
Module-상태 또는 학습 가능한 가중치를 저장할 신경망 계층.
PyTorch의 장점
다음은 PyTorch의 장점입니다-
코드를 디버그하고 이해하기 쉽습니다.
토치로 많은 레이어를 포함합니다.
그것은 많은 손실 함수를 포함합니다.
GPU에 대한 NumPy 확장으로 간주 할 수 있습니다.
구조가 계산 자체에 의존하는 네트워크를 구축 할 수 있습니다.
TensorFlow 대 PyTorch
아래에서 TensorFlow와 PyTorch의 주요 차이점을 살펴 보겠습니다.
파이 토치 | TensorFlow |
---|---|
PyTorch는 Facebook에서 활발하게 사용되는 lua 기반 Torch 프레임 워크와 밀접한 관련이 있습니다. |
TensorFlow는 Google Brain에서 개발했으며 Google에서 적극적으로 사용합니다. |
PyTorch는 다른 경쟁 기술에 비해 상대적으로 새롭습니다. |
TensorFlow는 새로운 것이 아니며 많은 연구자 및 업계 전문가에 의해 이동 도구로 간주됩니다. |
PyTorch는 모든 것을 명령적이고 역동적 인 방식으로 포함합니다. |
TensorFlow는 정적 및 동적 그래프를 조합으로 포함합니다. |
PyTorch의 계산 그래프는 런타임 중에 정의됩니다. |
TensorFlow에는 런타임 옵션이 포함되어 있지 않습니다. |
PyTorch에는 모바일 및 임베디드 프레임 워크 용 배포 기능이 포함되어 있습니다. |
TensorFlow는 임베디드 프레임 워크에서 더 잘 작동합니다. |
PyTorch는 인기있는 딥 러닝 프레임 워크입니다. 이 자습서에서는 "Windows 10"을 운영 체제로 간주합니다. 성공적인 환경 설정을위한 단계는 다음과 같습니다.
1 단계
다음 링크에는 PyTorch에 적합한 패키지가 포함 된 패키지 목록이 포함되어 있습니다.
https://drive.google.com/drive/folders/0B-X0-FlSGfCYdTNldW02UGl4MXM다음 스크린 샷과 같이 각 패키지를 다운로드하고 설치하기 만하면됩니다.
2 단계
Anaconda Framework를 사용하여 PyTorch 프레임 워크의 설치를 확인하는 작업이 포함됩니다.
다음 명령은 동일한 것을 확인하는 데 사용됩니다-
conda list
“Conda list”는 설치된 프레임 워크 목록을 보여줍니다.
강조 표시된 부분은 PyTorch가 시스템에 성공적으로 설치되었음을 보여줍니다.
수학은 모든 기계 학습 알고리즘에서 중요하며 특정 방식으로 설계된 올바른 알고리즘을 얻기위한 다양한 핵심 수학 개념을 포함합니다.
기계 학습 및 데이터 과학에 대한 수학 주제의 중요성은 다음과 같습니다.
이제 자연어 처리 관점에서 중요한 기계 학습의 주요 수학적 개념에 초점을 맞 춥니 다.
벡터
벡터는 연속적이거나 이산적인 숫자의 배열로 간주되며 벡터로 구성된 공간을 벡터 공간이라고합니다. 벡터의 공간 차원은 유한하거나 무한 할 수 있지만 기계 학습 및 데이터 과학 문제가 고정 길이 벡터를 처리하는 것으로 관찰되었습니다.
벡터 표현은 아래와 같이 표시됩니다.
temp = torch.FloatTensor([23,24,24.5,26,27.2,23.0])
temp.size()
Output - torch.Size([6])
기계 학습에서 우리는 다차원 데이터를 다룹니다. 따라서 벡터는 매우 중요하며 모든 예측 문제 설명에 대한 입력 특성으로 간주됩니다.
스칼라
스칼라는 하나의 값만 포함하는 차원이 0 개라고합니다. PyTorch의 경우 차원이 0 인 특수 텐서를 포함하지 않습니다. 따라서 선언은 다음과 같이 작성됩니다.
x = torch.rand(10)
x.size()
Output - torch.Size([10])
행렬
대부분의 구조화 된 데이터는 일반적으로 표 또는 특정 행렬의 형태로 표현됩니다. Python scikit-learn 기계 학습 라이브러리에서 쉽게 사용할 수있는 Boston House Price라는 데이터 세트를 사용합니다.
boston_tensor = torch.from_numpy(boston.data)
boston_tensor.size()
Output: torch.Size([506, 13])
boston_tensor[:2]
Output:
Columns 0 to 7
0.0063 18.0000 2.3100 0.0000 0.5380 6.5750 65.2000 4.0900
0.0273 0.0000 7.0700 0.0000 0.4690 6.4210 78.9000 4.9671
Columns 8 to 12
1.0000 296.0000 15.3000 396.9000 4.9800
2.0000 242.0000 17.8000 396.9000 9.1400
신경망의 주요 원리는 인공 뉴런 또는 퍼셉트론과 같은 기본 요소 모음을 포함합니다. 여기에는 x1, x2… .. xn과 같은 몇 가지 기본 입력이 포함되어 있으며 합계가 활성화 전위보다 클 경우 이진 출력을 생성합니다.
샘플 뉴런의 개략도는 아래에 언급되어 있습니다.
생성 된 출력은 활성화 전위 또는 바이어스가있는 가중치 합으로 간주 될 수 있습니다.
$$ Output = \ sum_jw_jx_j + Bias $$
일반적인 신경망 아키텍처는 다음과 같습니다.
입력과 출력 사이의 계층을 은닉 계층이라고하며 계층 간의 연결 밀도와 유형이 구성입니다. 예를 들어, 완전 연결 구성에는 L 층의 모든 뉴런이 L + 1의 뉴런에 연결되어 있습니다. 보다 뚜렷한 지역화를 위해 우리는 9 개의 뉴런과 같은 지역 이웃 만 다음 레이어에 연결할 수 있습니다. 그림 1-9는 조밀 한 연결이있는 두 개의 숨겨진 레이어를 보여줍니다.
다양한 유형의 신경망은 다음과 같습니다.
피드 포워드 신경망
피드 포워드 신경망에는 신경망 제품군의 기본 단위가 포함됩니다. 이러한 유형의 신경망에서 데이터의 이동은 현재 숨겨진 계층을 통해 입력 계층에서 출력 계층으로 이동합니다. 한 레이어의 출력은 네트워크 아키텍처의 모든 종류의 루프에 대한 제한이있는 입력 레이어 역할을합니다.
순환 신경망
Recurrent Neural Networks는 데이터 패턴이 일정 기간 동안 결과적으로 변경되는 경우입니다. RNN에서는 입력 매개 변수를 받아들이고 지정된 신경망에 출력 매개 변수를 표시하기 위해 동일한 계층이 적용됩니다.
torch.nn 패키지를 사용하여 신경망을 구축 할 수 있습니다.
단순한 피드 포워드 네트워크입니다. 입력을 받아 여러 레이어를 차례로 통과시킨 다음 마지막으로 출력을 제공합니다.
PyTorch의 도움으로 신경망에 대한 일반적인 훈련 절차를 위해 다음 단계를 사용할 수 있습니다.
- 학습 가능한 매개 변수 (또는 가중치)가있는 신경망을 정의합니다.
- 입력 데이터 세트를 반복합니다.
- 네트워크를 통해 입력을 처리합니다.
- 손실을 계산합니다 (출력이 정확하지 않은 정도).
- 그라디언트를 네트워크의 매개 변수로 다시 전파합니다.
- 일반적으로 아래와 같이 간단한 업데이트를 사용하여 네트워크의 가중치를 업데이트합니다.
rule: weight = weight -learning_rate * gradient
인공 지능은 오늘날 더 큰 추세를 보이고 있습니다. 기계 학습과 딥 러닝은 인공 지능을 구성합니다. 아래에 언급 된 벤 다이어그램은 머신 러닝과 딥 러닝의 관계를 설명합니다.
기계 학습
기계 학습은 컴퓨터가 설계되고 프로그래밍 된 알고리즘에 따라 작동 할 수 있도록하는 과학 기술입니다. 많은 연구자들은 기계 학습이 인간 수준의 AI로 발전하는 가장 좋은 방법이라고 생각합니다. 그것은 다음과 같은 다양한 유형의 패턴을 포함합니다-
- 지도 학습 패턴
- 비지도 학습 패턴
딥 러닝
딥 러닝은 관련 알고리즘이 인공 신경망이라고하는 뇌의 구조와 기능에서 영감을받은 기계 학습의 하위 분야입니다.
딥 러닝은지도 학습 또는 레이블이 지정된 데이터 및 알고리즘에서 학습을 통해 많은 중요성을 얻었습니다. 딥 러닝의 각 알고리즘은 동일한 프로세스를 거칩니다. 여기에는 입력의 비선형 변환 계층이 포함되며 통계 모델을 출력으로 만드는 데 사용됩니다.
기계 학습 프로세스는 다음 단계를 사용하여 정의됩니다.
- 관련 데이터 세트를 식별하고 분석을 위해 준비합니다.
- 사용할 알고리즘 유형을 선택합니다.
- 사용 된 알고리즘을 기반으로 분석 모델을 구축합니다.
- 테스트 데이터 세트에서 모델을 훈련시키고 필요에 따라 수정합니다.
- 모델을 실행하여 테스트 점수를 생성합니다.
이 장에서는 머신 러닝 개념과 딥 러닝 개념의 주요 차이점에 대해 설명합니다.
데이터 양
머신 러닝은 다양한 양의 데이터로 작동하며 주로 소량의 데이터에 사용됩니다. 반면에 딥 러닝은 데이터 양이 빠르게 증가하면 효율적으로 작동합니다. 다음 다이어그램은 데이터 양과 관련하여 머신 러닝 및 딥 러닝의 작동을 보여줍니다.
하드웨어 종속성
딥 러닝 알고리즘은 기존의 머신 러닝 알고리즘과 달리 하이 엔드 머신에 크게 의존하도록 설계되었습니다. 딥 러닝 알고리즘은 엄청난 하드웨어 지원이 필요한 대량의 행렬 곱셈 연산을 수행합니다.
기능 엔지니어링
기능 엔지니어링은 데이터의 복잡성을 줄이고 학습 알고리즘에서 볼 수있는 패턴을 만들기 위해 도메인 지식을 지정된 기능에 넣는 프로세스입니다.
예를 들어, 전통적인 기계 학습 패턴은 기능 엔지니어링 프로세스에 필요한 픽셀 및 기타 속성에 중점을 둡니다. 딥 러닝 알고리즘은 데이터의 높은 수준의 기능에 중점을 둡니다. 모든 새로운 문제에 대해 새로운 기능 추출기를 개발하는 작업을 줄입니다.
PyTorch에는 신경망을 만들고 구현하는 특수 기능이 포함되어 있습니다. 이 장에서는 단일 출력 단위를 개발하는 하나의 히든 레이어가있는 간단한 신경망을 생성합니다.
PyTorch를 사용하여 첫 번째 신경망을 구현하기 위해 다음 단계를 사용할 것입니다.
1 단계
먼저 아래 명령을 사용하여 PyTorch 라이브러리를 가져와야합니다.
import torch
import torch.nn as nn
2 단계
모든 레이어와 배치 크기를 정의하여 아래와 같이 신경망 실행을 시작합니다.
# Defining input size, hidden layer size, output size and batch size respectively
n_in, n_h, n_out, batch_size = 10, 5, 1, 10
3 단계
신경망은 각각의 출력 데이터를 얻기 위해 입력 데이터의 조합을 포함하므로 아래에 주어진 것과 동일한 절차를 따를 것입니다.
# Create dummy input and target tensors (data)
x = torch.randn(batch_size, n_in)
y = torch.tensor([[1.0], [0.0], [0.0],
[1.0], [1.0], [1.0], [0.0], [0.0], [1.0], [1.0]])
4 단계
내장 함수를 사용하여 순차 모델을 만듭니다. 아래 코드 줄을 사용하여 순차 모델을 만듭니다.
# Create a model
model = nn.Sequential(nn.Linear(n_in, n_h),
nn.ReLU(),
nn.Linear(n_h, n_out),
nn.Sigmoid())
5 단계
아래와 같이 Gradient Descent Optimizer를 사용하여 손실 함수를 구성하십시오.
Construct the loss function
criterion = torch.nn.MSELoss()
# Construct the optimizer (Stochastic Gradient Descent in this case)
optimizer = torch.optim.SGD(model.parameters(), lr = 0.01)
6 단계
주어진 코드 라인으로 반복 루프를 사용하여 경사 하강 법 모델을 구현합니다.
# Gradient Descent
for epoch in range(50):
# Forward pass: Compute predicted y by passing x to the model
y_pred = model(x)
# Compute and print loss
loss = criterion(y_pred, y)
print('epoch: ', epoch,' loss: ', loss.item())
# Zero gradients, perform a backward pass, and update the weights.
optimizer.zero_grad()
# perform a backward pass (backpropagation)
loss.backward()
# Update the parameters
optimizer.step()
7 단계
생성 된 출력은 다음과 같습니다.
epoch: 0 loss: 0.2545787990093231
epoch: 1 loss: 0.2545052170753479
epoch: 2 loss: 0.254431813955307
epoch: 3 loss: 0.25435858964920044
epoch: 4 loss: 0.2542854845523834
epoch: 5 loss: 0.25421255826950073
epoch: 6 loss: 0.25413978099823
epoch: 7 loss: 0.25406715273857117
epoch: 8 loss: 0.2539947032928467
epoch: 9 loss: 0.25392240285873413
epoch: 10 loss: 0.25385022163391113
epoch: 11 loss: 0.25377824902534485
epoch: 12 loss: 0.2537063956260681
epoch: 13 loss: 0.2536346912384033
epoch: 14 loss: 0.25356316566467285
epoch: 15 loss: 0.25349172949790955
epoch: 16 loss: 0.25342053174972534
epoch: 17 loss: 0.2533493936061859
epoch: 18 loss: 0.2532784342765808
epoch: 19 loss: 0.25320762395858765
epoch: 20 loss: 0.2531369626522064
epoch: 21 loss: 0.25306645035743713
epoch: 22 loss: 0.252996027469635
epoch: 23 loss: 0.2529257833957672
epoch: 24 loss: 0.25285571813583374
epoch: 25 loss: 0.25278574228286743
epoch: 26 loss: 0.25271597504615784
epoch: 27 loss: 0.25264623761177063
epoch: 28 loss: 0.25257670879364014
epoch: 29 loss: 0.2525072991847992
epoch: 30 loss: 0.2524380087852478
epoch: 31 loss: 0.2523689270019531
epoch: 32 loss: 0.25229987502098083
epoch: 33 loss: 0.25223103165626526
epoch: 34 loss: 0.25216227769851685
epoch: 35 loss: 0.252093642950058
epoch: 36 loss: 0.25202515721321106
epoch: 37 loss: 0.2519568204879761
epoch: 38 loss: 0.251888632774353
epoch: 39 loss: 0.25182053446769714
epoch: 40 loss: 0.2517525553703308
epoch: 41 loss: 0.2516847252845764
epoch: 42 loss: 0.2516169846057892
epoch: 43 loss: 0.2515493929386139
epoch: 44 loss: 0.25148195028305054
epoch: 45 loss: 0.25141456723213196
epoch: 46 loss: 0.2513473629951477
epoch: 47 loss: 0.2512802183628082
epoch: 48 loss: 0.2512132525444031
epoch: 49 loss: 0.2511464059352875
딥 러닝 알고리즘 훈련에는 다음 단계가 포함됩니다.
- 데이터 파이프 라인 구축
- 네트워크 아키텍처 구축
- 손실 함수를 사용하여 아키텍처 평가
- 최적화 알고리즘을 사용하여 네트워크 아키텍처 가중치 최적화
특정 딥 러닝 알고리즘을 훈련하는 것은 아래와 같이 신경망을 기능 블록으로 변환하는 정확한 요구 사항입니다.
위의 다이어그램과 관련하여 모든 딥 러닝 알고리즘에는 입력 데이터를 가져 와서 여러 계층이 포함 된 각 아키텍처를 구축하는 작업이 포함됩니다.
위의 다이어그램을 관찰하면 신경망 가중치 최적화와 관련하여 손실 함수를 사용하여 정확도를 평가합니다.
이 장에서는 PyTorch에서 가장 일반적으로 사용되는 용어에 대해 설명합니다.
PyTorch NumPy
PyTorch 텐서는 NumPy 배열과 동일합니다. 텐서는 n 차원 배열이며 PyTorch와 관련하여 이러한 텐서에서 작동하는 많은 함수를 제공합니다.
PyTorch 텐서는 일반적으로 GPU를 사용하여 숫자 계산을 가속화합니다. PyTorch에서 생성 된 이러한 텐서는 2 계층 네트워크를 임의의 데이터에 맞추는 데 사용할 수 있습니다. 사용자는 네트워크를 통해 순방향 및 역방향 패스를 수동으로 구현할 수 있습니다.
변수 및 Autograd
autograd를 사용할 때 네트워크의 정방향 패스는 computational graph − 그래프의 노드는 Tensor가되고 Edge는 입력 Tensor에서 출력 Tensor를 생성하는 함수가됩니다.
PyTorch Tensor는 변수가 계산 그래프에서 노드를 나타내는 변수 객체로 생성 될 수 있습니다.
동적 그래프
정적 그래프는 사용자가 그래프를 미리 최적화 할 수 있기 때문에 좋습니다. 프로그래머가 동일한 그래프를 반복해서 재사용하는 경우, 동일한 그래프가 반복해서 반복되므로 잠재적으로 비용이 많이 드는 사전 최적화를 유지할 수 있습니다.
이들 사이의 주요 차이점은 Tensor Flow의 계산 그래프는 정적이고 PyTorch는 동적 계산 그래프를 사용한다는 것입니다.
최적화 패키지
PyTorch의 optim 패키지는 다양한 방식으로 구현되는 최적화 알고리즘의 아이디어를 추상화하고 일반적으로 사용되는 최적화 알고리즘의 그림을 제공합니다. import 문 내에서 호출 할 수 있습니다.
다중 처리
다중 처리는 동일한 작업을 지원하므로 모든 텐서는 여러 프로세서에서 작동합니다. 큐는 데이터를 공유 메모리로 이동하고 핸들을 다른 프로세스로만 보냅니다.
PyTorch에는 데이터 세트를로드하고 준비하는 데 사용되는 torchvision이라는 패키지가 포함되어 있습니다. 여기에는 데이터 세트의 변환 및로드를 돕는 Dataset 및 DataLoader라는 두 가지 기본 함수가 포함되어 있습니다.
데이터 세트
데이터 세트는 주어진 데이터 세트에서 데이터 포인트를 읽고 변환하는 데 사용됩니다. 구현할 기본 구문은 다음과 같습니다.
trainset = torchvision.datasets.CIFAR10(root = './data', train = True,
download = True, transform = transform)
DataLoader는 데이터를 섞고 배치하는 데 사용됩니다. 다중 처리 작업자와 병렬로 데이터를로드하는 데 사용할 수 있습니다.
trainloader = torch.utils.data.DataLoader(trainset, batch_size = 4,
shuffle = True, num_workers = 2)
예 : CSV 파일로드
Python 패키지 Panda를 사용하여 csv 파일을로드합니다. 원본 파일의 형식은 다음과 같습니다 (이미지 이름, 랜드 마크 68 개-각 랜드 마크에는 축, y 좌표가 있음).
landmarks_frame = pd.read_csv('faces/face_landmarks.csv')
n = 65
img_name = landmarks_frame.iloc[n, 0]
landmarks = landmarks_frame.iloc[n, 1:].as_matrix()
landmarks = landmarks.astype('float').reshape(-1, 2)
이 장에서는 TensorFlow를 사용한 선형 회귀 구현의 기본 예제에 초점을 맞출 것입니다. 로지스틱 회귀 또는 선형 회귀는 순서 불연속 범주의 분류를위한지도 머신 러닝 접근 방식입니다. 이 장의 목표는 사용자가 예측 변수와 하나 이상의 독립 변수 간의 관계를 예측할 수있는 모델을 구축하는 것입니다.
이 두 변수 간의 관계는 선형으로 간주됩니다. 즉, y가 종속 변수이고 x가 독립 변수로 간주되면 두 변수의 선형 회귀 관계는 아래에 언급 된 방정식과 같습니다.
Y = Ax+b
다음으로, 우리는 아래에 주어진 두 가지 중요한 개념을 이해할 수있는 선형 회귀 알고리즘을 설계 할 것입니다.
- 비용 함수
- 경사 하강 법 알고리즘
선형 회귀의 도식 표현은 아래에 언급되어 있습니다.
결과 해석
$$ Y = ax + b $$
의 가치 a 경사입니다.
의 가치 b 이다 y − intercept.
r 이다 correlation coefficient.
r2 이다 correlation coefficient.
선형 회귀 방정식의 그래픽보기는 다음과 같습니다.
다음 단계는 PyTorch를 사용하여 선형 회귀를 구현하는 데 사용됩니다-
1 단계
아래 코드를 사용하여 PyTorch에서 선형 회귀를 만드는 데 필요한 패키지를 가져옵니다.
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation
import seaborn as sns
import pandas as pd
%matplotlib inline
sns.set_style(style = 'whitegrid')
plt.rcParams["patch.force_edgecolor"] = True
2 단계
아래와 같이 사용 가능한 데이터 세트로 단일 훈련 세트를 만듭니다.
m = 2 # slope
c = 3 # interceptm = 2 # slope
c = 3 # intercept
x = np.random.rand(256)
noise = np.random.randn(256) / 4
y = x * m + c + noise
df = pd.DataFrame()
df['x'] = x
df['y'] = y
sns.lmplot(x ='x', y ='y', data = df)
3 단계
아래에 언급 된대로 PyTorch 라이브러리로 선형 회귀를 구현하십시오.
import torch
import torch.nn as nn
from torch.autograd import Variable
x_train = x.reshape(-1, 1).astype('float32')
y_train = y.reshape(-1, 1).astype('float32')
class LinearRegressionModel(nn.Module):
def __init__(self, input_dim, output_dim):
super(LinearRegressionModel, self).__init__()
self.linear = nn.Linear(input_dim, output_dim)
def forward(self, x):
out = self.linear(x)
return out
input_dim = x_train.shape[1]
output_dim = y_train.shape[1]
input_dim, output_dim(1, 1)
model = LinearRegressionModel(input_dim, output_dim)
criterion = nn.MSELoss()
[w, b] = model.parameters()
def get_param_values():
return w.data[0][0], b.data[0]
def plot_current_fit(title = ""):
plt.figure(figsize = (12,4))
plt.title(title)
plt.scatter(x, y, s = 8)
w1 = w.data[0][0]
b1 = b.data[0]
x1 = np.array([0., 1.])
y1 = x1 * w1 + b1
plt.plot(x1, y1, 'r', label = 'Current Fit ({:.3f}, {:.3f})'.format(w1, b1))
plt.xlabel('x (input)')
plt.ylabel('y (target)')
plt.legend()
plt.show()
plot_current_fit('Before training')
생성 된 플롯은 다음과 같습니다.
딥 러닝은 기계 학습의 한 부분이며 최근 수십 년 동안 연구자들이 취한 중요한 단계로 간주됩니다. 딥 러닝 구현의 예에는 이미지 인식 및 음성 인식과 같은 애플리케이션이 포함됩니다.
두 가지 중요한 유형의 심층 신경망은 다음과 같습니다.
- 컨볼 루션 신경망
- 반복 신경망.
이 장에서는 첫 번째 유형 인 CNN (Convolutional Neural Networks)에 초점을 맞출 것입니다.
컨볼 루션 신경망
컨볼 루션 신경망은 여러 계층의 배열을 통해 데이터를 처리하도록 설계되었습니다. 이러한 유형의 신경망은 이미지 인식 또는 얼굴 인식과 같은 애플리케이션에 사용됩니다.
CNN과 다른 일반 신경망의 주요 차이점은 CNN이 입력을 2 차원 배열로 취하고 다른 신경망이 집중하는 특징 추출에 초점을 맞추지 않고 이미지에서 직접 작동한다는 것입니다.
CNN의 지배적 인 접근 방식에는 인식 문제에 대한 솔루션이 포함됩니다. Google 및 Facebook과 같은 최고 기업은 더 빠른 속도로 활동을 수행하기 위해 인식 프로젝트의 연구 개발 프로젝트에 투자했습니다.
모든 컨볼 루션 신경망에는 세 가지 기본 아이디어가 포함됩니다.
- 지역별 분야
- Convolution
- Pooling
이러한 각 용어를 자세히 이해하겠습니다.
지역별 분야
CNN은 입력 데이터 내에 존재하는 공간 상관 관계를 활용합니다. 신경망의 동시 계층에서 각각은 일부 입력 뉴런을 연결합니다. 이 특정 영역을 Local Receptive Field라고합니다. 숨겨진 뉴런에만 집중합니다. 은닉 뉴런은 언급 된 필드 내부의 입력 데이터를 처리하여 특정 경계 밖의 변경 사항을 인식하지 못합니다.
로컬 각 필드를 생성하는 다이어그램 표현은 다음과 같습니다.
회선
위의 그림에서 우리는 각 연결이 한 레이어에서 다른 레이어로의 이동과 관련된 연결로 숨겨진 뉴런의 가중치를 학습하는 것을 관찰합니다. 여기에서 개별 뉴런은 수시로 전환을 수행합니다. 이 프로세스를 "컨볼 루션"이라고합니다.
입력 계층에서 숨겨진 특징 맵으로의 연결 매핑은 "공유 가중치"로 정의되고 포함 된 편향은 "공유 편향"이라고합니다.
풀링
컨벌루션 신경망은 CNN 선언 직후에 위치하는 풀링 레이어를 사용합니다. 컨볼 루션 네트워크에서 나오는 기능 맵으로 사용자의 입력을 받아 압축 된 기능 맵을 준비합니다. 풀링 레이어는 이전 레이어의 뉴런으로 레이어를 만드는 데 도움이됩니다.
PyTorch 구현
다음 단계는 PyTorch를 사용하여 Convolutional Neural Network를 만드는 데 사용됩니다.
1 단계
간단한 신경망을 만드는 데 필요한 패키지를 가져옵니다.
from torch.autograd import Variable
import torch.nn.functional as F
2 단계
컨벌루션 신경망의 배치 표현이있는 클래스를 만듭니다. 입력 x에 대한 배치 모양은 차원이 (3, 32, 32)입니다.
class SimpleCNN(torch.nn.Module):
def __init__(self):
super(SimpleCNN, self).__init__()
#Input channels = 3, output channels = 18
self.conv1 = torch.nn.Conv2d(3, 18, kernel_size = 3, stride = 1, padding = 1)
self.pool = torch.nn.MaxPool2d(kernel_size = 2, stride = 2, padding = 0)
#4608 input features, 64 output features (see sizing flow below)
self.fc1 = torch.nn.Linear(18 * 16 * 16, 64)
#64 input features, 10 output features for our 10 defined classes
self.fc2 = torch.nn.Linear(64, 10)
3 단계
첫 번째 컨볼 루션 크기 변경의 활성화를 (3, 32, 32)에서 (18, 32, 32)로 계산합니다.
치수 크기가 (18, 32, 32)에서 (18, 16, 16)으로 변경됩니다. 크기가 (18, 16, 16)에서 (1, 4608)로 변경되는 신경망 입력 계층의 데이터 차원을 재구성합니다.
-1은 주어진 다른 차원에서이 차원을 유추합니다.
def forward(self, x):
x = F.relu(self.conv1(x))
x = self.pool(x)
x = x.view(-1, 18 * 16 *16)
x = F.relu(self.fc1(x))
#Computes the second fully connected layer (activation applied later)
#Size changes from (1, 64) to (1, 10)
x = self.fc2(x)
return(x)
순환 신경망은 순차적 접근 방식을 따르는 딥 러닝 지향 알고리즘의 한 유형입니다. 신경망에서 우리는 항상 각 입력과 출력이 다른 모든 계층과 독립적이라고 가정합니다. 이러한 유형의 신경망은 하나의 작업을 차례로 완료하는 순차적 인 방식으로 수학적 계산을 수행하기 때문에 반복이라고합니다.
아래 다이어그램은 순환 신경망의 완전한 접근 방식과 작동 방식을 지정합니다.
위 그림에서 c1, c2, c3 및 x1은 o1의 각 출력을 전달하는 h1, h2 및 h3과 같은 일부 숨겨진 입력 값을 포함하는 입력으로 간주됩니다. 이제 반복 신경망의 도움으로 사인파를 생성하기 위해 PyTorch를 구현하는 데 중점을 둘 것입니다.
훈련 중에는 한 번에 하나의 데이터 포인트를 사용하여 모델에 대한 훈련 방식을 따릅니다. 입력 시퀀스 x는 20 개의 데이터 포인트로 구성되며 대상 시퀀스는 입력 시퀀스와 동일한 것으로 간주됩니다.
1 단계
아래 코드를 사용하여 순환 신경망을 구현하는 데 필요한 패키지를 가져옵니다.
import torch
from torch.autograd import Variable
import numpy as np
import pylab as pl
import torch.nn.init as init
2 단계
입력 레이어의 크기를 7로 설정하여 모델 하이퍼 매개 변수를 설정합니다. 대상 시퀀스를 생성하기위한 6 개의 컨텍스트 뉴런과 1 개의 입력 뉴런이 있습니다.
dtype = torch.FloatTensor
input_size, hidden_size, output_size = 7, 6, 1
epochs = 300
seq_length = 20
lr = 0.1
data_time_steps = np.linspace(2, 10, seq_length + 1)
data = np.sin(data_time_steps)
data.resize((seq_length + 1, 1))
x = Variable(torch.Tensor(data[:-1]).type(dtype), requires_grad=False)
y = Variable(torch.Tensor(data[1:]).type(dtype), requires_grad=False)
훈련 데이터를 생성합니다. 여기서 x는 입력 데이터 시퀀스이고 y는 필수 대상 시퀀스입니다.
3 단계
가중치는 평균이 0 인 정규 분포를 사용하여 순환 신경망에서 초기화됩니다. W1은 입력 변수의 수용을 나타내고 w2는 아래와 같이 생성되는 출력을 나타냅니다.
w1 = torch.FloatTensor(input_size,
hidden_size).type(dtype)
init.normal(w1, 0.0, 0.4)
w1 = Variable(w1, requires_grad = True)
w2 = torch.FloatTensor(hidden_size, output_size).type(dtype)
init.normal(w2, 0.0, 0.3)
w2 = Variable(w2, requires_grad = True)
4 단계
이제 신경망을 고유하게 정의하는 피드 포워드 함수를 만드는 것이 중요합니다.
def forward(input, context_state, w1, w2):
xh = torch.cat((input, context_state), 1)
context_state = torch.tanh(xh.mm(w1))
out = context_state.mm(w2)
return (out, context_state)
5 단계
다음 단계는 순환 신경망의 사인파 구현 훈련 절차를 시작하는 것입니다. 외부 루프는 각 루프를 반복하고 내부 루프는 시퀀스 요소를 반복합니다. 여기에서는 연속 변수의 예측에 도움이되는 평균 제곱 오차 (MSE)도 계산합니다.
for i in range(epochs):
total_loss = 0
context_state = Variable(torch.zeros((1, hidden_size)).type(dtype), requires_grad = True)
for j in range(x.size(0)):
input = x[j:(j+1)]
target = y[j:(j+1)]
(pred, context_state) = forward(input, context_state, w1, w2)
loss = (pred - target).pow(2).sum()/2
total_loss += loss
loss.backward()
w1.data -= lr * w1.grad.data
w2.data -= lr * w2.grad.data
w1.grad.data.zero_()
w2.grad.data.zero_()
context_state = Variable(context_state.data)
if i % 10 == 0:
print("Epoch: {} loss {}".format(i, total_loss.data[0]))
context_state = Variable(torch.zeros((1, hidden_size)).type(dtype), requires_grad = False)
predictions = []
for i in range(x.size(0)):
input = x[i:i+1]
(pred, context_state) = forward(input, context_state, w1, w2)
context_state = context_state
predictions.append(pred.data.numpy().ravel()[0])
6 단계
이제 필요한 방식으로 사인파를 플로팅 할 때입니다.
pl.scatter(data_time_steps[:-1], x.data.numpy(), s = 90, label = "Actual")
pl.scatter(data_time_steps[1:], predictions, label = "Predicted")
pl.legend()
pl.show()
산출
위 프로세스의 출력은 다음과 같습니다.
이 장에서는 torchvision.datasets그리고 그 다양한 유형. PyTorch에는 다음과 같은 데이터 세트 로더가 포함됩니다.
- MNIST
- COCO (캡션 및 감지)
데이터 세트는 아래에 주어진 두 가지 유형의 함수 대부분을 포함합니다.
Transform− 이미지를 받아 표준 항목의 수정 된 버전을 반환하는 함수. 이들은 변형과 함께 구성 될 수 있습니다.
Target_transform− 대상을 가져 와서 변환하는 함수. 예를 들어, 캡션 문자열을 받아 세계 인덱스의 텐서를 반환합니다.
MNIST
다음은 MNIST 데이터 세트의 샘플 코드입니다-
dset.MNIST(root, train = TRUE, transform = NONE,
target_transform = None, download = FALSE)
매개 변수는 다음과 같습니다-
root − 처리 된 데이터가 존재하는 데이터 세트의 루트 디렉토리.
train − True = 훈련 세트, False = 테스트 세트
download − True = 인터넷에서 데이터 세트를 다운로드하여 루트에 저장합니다.
머리
이를 위해서는 COCO API를 설치해야합니다. 다음 예제는 PyTorch를 사용하여 데이터 세트의 COCO 구현을 설명하는 데 사용됩니다-
import torchvision.dataset as dset
import torchvision.transforms as transforms
cap = dset.CocoCaptions(root = ‘ dir where images are’,
annFile = ’json annotation file’,
transform = transforms.ToTensor())
print(‘Number of samples: ‘, len(cap))
print(target)
달성 된 출력은 다음과 같습니다.
Number of samples: 82783
Image Size: (3L, 427L, 640L)
Convents는 처음부터 CNN 모델을 구축하는 것입니다. 네트워크 아키텍처에는 다음 단계의 조합이 포함됩니다.
- Conv2d
- MaxPool2d
- 정류 된 선형 단위
- View
- 선형 레이어
모델 훈련
모델 학습은 이미지 분류 문제와 동일한 프로세스입니다. 다음 코드 스 니펫은 제공된 데이터 세트에 대한 학습 모델의 절차를 완료합니다.
def fit(epoch,model,data_loader,phase
= 'training',volatile = False):
if phase == 'training':
model.train()
if phase == 'training':
model.train()
if phase == 'validation':
model.eval()
volatile=True
running_loss = 0.0
running_correct = 0
for batch_idx , (data,target) in enumerate(data_loader):
if is_cuda:
data,target = data.cuda(),target.cuda()
data , target = Variable(data,volatile),Variable(target)
if phase == 'training':
optimizer.zero_grad()
output = model(data)
loss = F.nll_loss(output,target)
running_loss + =
F.nll_loss(output,target,size_average =
False).data[0]
preds = output.data.max(dim = 1,keepdim = True)[1]
running_correct + =
preds.eq(target.data.view_as(preds)).cpu().sum()
if phase == 'training':
loss.backward()
optimizer.step()
loss = running_loss/len(data_loader.dataset)
accuracy = 100. * running_correct/len(data_loader.dataset)
print(f'{phase} loss is {loss:{5}.{2}} and {phase} accuracy is {running_correct}/{len(data_loader.dataset)}{accuracy:{return loss,accuracy}})
이 방법에는 학습 및 검증을위한 다양한 논리가 포함됩니다. 다른 모드를 사용하는 두 가지 주요 이유가 있습니다.
기차 모드에서 드롭 아웃은 유효성 검사 또는 테스트 단계에서 발생하지 않아야하는 값의 백분율을 제거합니다.
훈련 모드의 경우 기울기를 계산하고 모델의 매개 변수 값을 변경하지만 테스트 또는 검증 단계에서는 역 전파가 필요하지 않습니다.
이 장에서는 처음부터 수녀원을 만드는 데 중점을 둘 것입니다. 이것은 토치로 각각의 수녀원 또는 샘플 신경망을 만드는 것을 추론합니다.
1 단계
각 매개 변수를 사용하여 필요한 클래스를 만듭니다. 매개 변수에는 임의 값이있는 가중치가 포함됩니다.
class Neural_Network(nn.Module):
def __init__(self, ):
super(Neural_Network, self).__init__()
self.inputSize = 2
self.outputSize = 1
self.hiddenSize = 3
# weights
self.W1 = torch.randn(self.inputSize,
self.hiddenSize) # 3 X 2 tensor
self.W2 = torch.randn(self.hiddenSize, self.outputSize) # 3 X 1 tensor
2 단계
시그 모이 드 함수를 사용하여 함수의 피드 포워드 패턴을 만듭니다.
def forward(self, X):
self.z = torch.matmul(X, self.W1) # 3 X 3 ".dot"
does not broadcast in PyTorch
self.z2 = self.sigmoid(self.z) # activation function
self.z3 = torch.matmul(self.z2, self.W2)
o = self.sigmoid(self.z3) # final activation
function
return o
def sigmoid(self, s):
return 1 / (1 + torch.exp(-s))
def sigmoidPrime(self, s):
# derivative of sigmoid
return s * (1 - s)
def backward(self, X, y, o):
self.o_error = y - o # error in output
self.o_delta = self.o_error * self.sigmoidPrime(o) # derivative of sig to error
self.z2_error = torch.matmul(self.o_delta, torch.t(self.W2))
self.z2_delta = self.z2_error * self.sigmoidPrime(self.z2)
self.W1 + = torch.matmul(torch.t(X), self.z2_delta)
self.W2 + = torch.matmul(torch.t(self.z2), self.o_delta)
3 단계
아래에 언급 된대로 훈련 및 예측 모델을 만듭니다.
def train(self, X, y):
# forward + backward pass for training
o = self.forward(X)
self.backward(X, y, o)
def saveWeights(self, model):
# Implement PyTorch internal storage functions
torch.save(model, "NN")
# you can reload model with all the weights and so forth with:
# torch.load("NN")
def predict(self):
print ("Predicted data based on trained weights: ")
print ("Input (scaled): \n" + str(xPredicted))
print ("Output: \n" + str(self.forward(xPredicted)))
컨볼 루션 신경망에는 주요 기능이 포함됩니다. extraction. 다음 단계는 컨볼 루션 신경망의 특징 추출을 구현하는 데 사용됩니다.
1 단계
각 모델을 가져와 "PyTorch"로 기능 추출 모델을 만듭니다.
import torch
import torch.nn as nn
from torchvision import models
2 단계
필요할 때 호출 할 수있는 기능 추출기 클래스를 만듭니다.
class Feature_extractor(nn.module):
def forward(self, input):
self.feature = input.clone()
return input
new_net = nn.Sequential().cuda() # the new network
target_layers = [conv_1, conv_2, conv_4] # layers you want to extract`
i = 1
for layer in list(cnn):
if isinstance(layer,nn.Conv2d):
name = "conv_"+str(i)
art_net.add_module(name,layer)
if name in target_layers:
new_net.add_module("extractor_"+str(i),Feature_extractor())
i+=1
if isinstance(layer,nn.ReLU):
name = "relu_"+str(i)
new_net.add_module(name,layer)
if isinstance(layer,nn.MaxPool2d):
name = "pool_"+str(i)
new_net.add_module(name,layer)
new_net.forward(your_image)
print (new_net.extractor_3.feature)
이 장에서는 수도원의 도움을 받아 데이터 시각화 모델에 초점을 맞출 것입니다. 기존 신경망을 사용하여 시각화에 대한 완벽한 그림을 얻으려면 다음 단계가 필요합니다.
1 단계
기존 신경망의 시각화에 중요한 필수 모듈을 가져옵니다.
import os
import numpy as np
import pandas as pd
from scipy.misc import imread
from sklearn.metrics import accuracy_score
import keras
from keras.models import Sequential, Model
from keras.layers import Dense, Dropout, Flatten, Activation, Input
from keras.layers import Conv2D, MaxPooling2D
import torch
2 단계
훈련 및 테스트 데이터로 잠재적 인 임의성을 중지하려면 아래 코드에 지정된대로 각 데이터 세트를 호출하십시오.
seed = 128
rng = np.random.RandomState(seed)
data_dir = "../../datasets/MNIST"
train = pd.read_csv('../../datasets/MNIST/train.csv')
test = pd.read_csv('../../datasets/MNIST/Test_fCbTej3.csv')
img_name = rng.choice(train.filename)
filepath = os.path.join(data_dir, 'train', img_name)
img = imread(filepath, flatten=True)
3 단계
아래 코드를 사용하여 완벽한 방식으로 정의 된 훈련 및 테스트 데이터를 얻기 위해 필요한 이미지를 플롯합니다.
pylab.imshow(img, cmap ='gray')
pylab.axis('off')
pylab.show()
출력은 다음과 같이 표시됩니다.
이 장에서 우리는 대신 두 시퀀스에 걸쳐 단일 2D 컨볼 루션 신경망에 의존하는 대체 접근법을 제안합니다. 네트워크의 각 계층은 지금까지 생성 된 출력 시퀀스를 기반으로 소스 토큰을 다시 코딩합니다. 따라서주의와 유사한 속성은 네트워크 전체에 퍼져 있습니다.
여기서는 creating the sequential network with specific pooling from the values included in dataset. 이 프로세스는 "이미지 인식 모듈"에서도 가장 잘 적용됩니다.
다음 단계는 PyTorch를 사용하여 수녀원으로 시퀀스 처리 모델을 만드는 데 사용됩니다-
1 단계
수녀원을 사용하여 시퀀스 처리를 수행하기 위해 필요한 모듈을 가져옵니다.
import keras
from keras.datasets import mnist
from keras.models import Sequential
from keras.layers import Dense, Dropout, Flatten
from keras.layers import Conv2D, MaxPooling2D
import numpy as np
2 단계
아래 코드를 사용하여 각 순서로 패턴을 생성하는 데 필요한 작업을 수행하십시오-
batch_size = 128
num_classes = 10
epochs = 12
# input image dimensions
img_rows, img_cols = 28, 28
# the data, split between train and test sets
(x_train, y_train), (x_test, y_test) = mnist.load_data()
x_train = x_train.reshape(60000,28,28,1)
x_test = x_test.reshape(10000,28,28,1)
print('x_train shape:', x_train.shape)
print(x_train.shape[0], 'train samples')
print(x_test.shape[0], 'test samples')
y_train = keras.utils.to_categorical(y_train, num_classes)
y_test = keras.utils.to_categorical(y_test, num_classes)
3 단계
모델을 컴파일하고 아래와 같이 언급 된 기존 신경망 모델에 패턴을 맞 춥니 다.
model.compile(loss =
keras.losses.categorical_crossentropy,
optimizer = keras.optimizers.Adadelta(), metrics =
['accuracy'])
model.fit(x_train, y_train,
batch_size = batch_size, epochs = epochs,
verbose = 1, validation_data = (x_test, y_test))
score = model.evaluate(x_test, y_test, verbose = 0)
print('Test loss:', score[0])
print('Test accuracy:', score[1])
생성 된 출력은 다음과 같습니다.
이 장에서 우리는 유명한 단어 임베딩 모델 인 word2vec를 이해할 것입니다. Word2vec 모델은 관련 모델 그룹의 도움으로 단어 임베딩을 생성하는 데 사용됩니다. Word2vec 모델은 순수한 C 코드로 구현되며 그래디언트는 수동으로 계산됩니다.
PyTorch에서 word2vec 모델의 구현은 아래 단계에서 설명됩니다.
1 단계
아래에 언급 된대로 단어 임베딩으로 라이브러리를 구현하십시오.
import torch
from torch.autograd import Variable
import torch.nn as nn
import torch.nn.functional as F
2 단계
word2vec라는 클래스를 사용하여 단어 임베딩의 Skip Gram Model을 구현합니다. 그것은 포함합니다emb_size, emb_dimension, u_embedding, v_embedding 속성 유형.
class SkipGramModel(nn.Module):
def __init__(self, emb_size, emb_dimension):
super(SkipGramModel, self).__init__()
self.emb_size = emb_size
self.emb_dimension = emb_dimension
self.u_embeddings = nn.Embedding(emb_size, emb_dimension, sparse=True)
self.v_embeddings = nn.Embedding(emb_size, emb_dimension, sparse = True)
self.init_emb()
def init_emb(self):
initrange = 0.5 / self.emb_dimension
self.u_embeddings.weight.data.uniform_(-initrange, initrange)
self.v_embeddings.weight.data.uniform_(-0, 0)
def forward(self, pos_u, pos_v, neg_v):
emb_u = self.u_embeddings(pos_u)
emb_v = self.v_embeddings(pos_v)
score = torch.mul(emb_u, emb_v).squeeze()
score = torch.sum(score, dim = 1)
score = F.logsigmoid(score)
neg_emb_v = self.v_embeddings(neg_v)
neg_score = torch.bmm(neg_emb_v, emb_u.unsqueeze(2)).squeeze()
neg_score = F.logsigmoid(-1 * neg_score)
return -1 * (torch.sum(score)+torch.sum(neg_score))
def save_embedding(self, id2word, file_name, use_cuda):
if use_cuda:
embedding = self.u_embeddings.weight.cpu().data.numpy()
else:
embedding = self.u_embeddings.weight.data.numpy()
fout = open(file_name, 'w')
fout.write('%d %d\n' % (len(id2word), self.emb_dimension))
for wid, w in id2word.items():
e = embedding[wid]
e = ' '.join(map(lambda x: str(x), e))
fout.write('%s %s\n' % (w, e))
def test():
model = SkipGramModel(100, 100)
id2word = dict()
for i in range(100):
id2word[i] = str(i)
model.save_embedding(id2word)
3 단계
단어 임베딩 모델이 적절한 방식으로 표시되도록 기본 방법을 구현하십시오.
if __name__ == '__main__':
test()
심층 신경망에는 자연어의 과정을 이해하는 기계 학습의 돌파구를 가능하게하는 독점적 인 기능이 있습니다. 이러한 모델의 대부분은 언어를 단어 또는 문자의 평평한 시퀀스로 취급하고 반복 신경망 또는 RNN이라고하는 일종의 모델을 사용하는 것으로 관찰됩니다.
많은 연구자들은 언어가 계층 적 구문 트리와 관련하여 가장 잘 이해된다는 결론에 도달합니다. 이 유형은 특정 구조를 고려하는 재귀 신경망에 포함됩니다.
PyTorch에는 이러한 복잡한 자연어 처리 모델을 훨씬 쉽게 만드는 데 도움이되는 특정 기능이 있습니다. 컴퓨터 비전을 강력하게 지원하는 모든 종류의 딥 러닝을위한 완전한 기능을 갖춘 프레임 워크입니다.
재귀 신경망의 특징
재귀 신경망은 다른 그래프와 같은 구조로 동일한 가중치 세트를 적용하는 방식으로 생성됩니다.
노드는 토폴로지 순서로 순회됩니다.
이러한 유형의 네트워크는 자동 미분의 역방향 모드로 훈련됩니다.
자연어 처리에는 재귀 신경망의 특별한 경우가 포함됩니다.
이 재귀 신경 텐서 네트워크는 트리에 다양한 구성 기능 노드를 포함합니다.
재귀 신경망의 예는 다음과 같습니다.