From 6bfed4982d6cc0b52f09fd8d96b16566c8ba7b36 Mon Sep 17 00:00:00 2001 From: logic-finder <83723320+logic-finder@users.noreply.github.com> Date: Thu, 28 Oct 2021 23:10:08 +0900 Subject: translate the below document. (#2793) Using IIR filters --- .../api/web_audio_api/using_iir_filters/index.html | 94 +++++++++++----------- 1 file changed, 47 insertions(+), 47 deletions(-) (limited to 'files/ko') diff --git a/files/ko/web/api/web_audio_api/using_iir_filters/index.html b/files/ko/web/api/web_audio_api/using_iir_filters/index.html index 0c48b1096c..7db83230de 100644 --- a/files/ko/web/api/web_audio_api/using_iir_filters/index.html +++ b/files/ko/web/api/web_audio_api/using_iir_filters/index.html @@ -1,5 +1,5 @@ --- -title: Using IIR filters +title: IIR 필터 사용하기 slug: Web/API/Web_Audio_API/Using_IIR_filters tags: - API @@ -11,59 +11,59 @@ tags: ---
The IIRFilterNode
interface of the Web Audio API is an {{domxref("AudioNode")}} processor that implements a general infinite impulse response (IIR) filter; this type of filter can be used to implement tone control devices and graphic equalizers, and the filter response parameters can be specified, so that it can be tuned as needed. This article looks at how to implement one, and use it in a simple example.
Web Audio API의 IIRFilterNode
인터페이스는 일반적인 무한 임펄스 응답 (IIR) 필터를 구현하는 {{domxref("AudioNode")}} 프로세서입니다; 이 유형의 필터는 음색 제어 장치와 그래픽 이퀄라이저를 구현하는 데 사용될 수 있으며, 필터 응답 파라미터들은 필요하면 조율될 수 있도록 명시될 수 있습니다. 이 글은 어떻게 이것을 구현하는지, 그리고 간단한 예제로 어떻게 이것을 사용하는지를 살펴봅니다.
Our simple example for this guide provides a play/pause button that starts and pauses audio play, and a toggle that turns an IIR filter on and off, altering the tone of the sound. It also provides a canvas on which is drawn the frequency response of the audio, so you can see what effect the IIR filter has.
+이 가이드를 위한 간단한 예제는 오디오 재생을 시작하거나 멈추는 재생/정지 버튼과, 사운드의 음색을 변경하는 IIR 필터를 켜고 끄는 토글 버튼을 제공합니다. 이것은 또한 오디오의 주파수 응답이 그려진 캔버스를 제공하므로, 여러분은 IIR 필터가 어떤 이펙트를 가지고 있는지를 볼 수 있습니다.
- + -You can check out the full demo here on Codepen. Also see the source code on GitHub. It includes some different coefficient values for different lowpass frequencies — you can change the value of the filterNumber
constant to a value between 0 and 3 to check out the different available effects.
여러분은 Codepen에서 전체 데모를 확인할 수 있습니다. GitHub에서 소스 코드도 볼 수 있습니다. 이것은 각각 다른 로우패스 주파수들에 대한 몇 가지 다른 계수 값들을 포함합니다 — 여러분은 각각 다른 이용 가능한 이펙트들을 확인해보기 위해 filterNumber
상수의 값을 0에서 3사이의 값으로 변경할 수 있습니다.
IIR filters are supported well across modern browsers, although they have been implemented more recently than some of the more longstanding Web Audio API features, like Biquad filters.
+비록 IIR 필터가 Biquad 필터같은, 더욱 오랫동안에 걸친 Web Audio API 기능들 중 몇 가지보다 더욱 최근에 구현되긴 했지만, IIR 필터는 현대 브라우저들에서 잘 지원됩니다.
-The Web Audio API now comes with an {{domxref("IIRFilterNode")}} interface. But what is this and how does it differ from the {{domxref("BiquadFilterNode")}} we have already?
+Web Audio API는 이제 {{domxref("IIRFilterNode")}} 인터페이스를 가지고 있습니다. 하지만 이것은 무엇이고 어떻게 이것이 우리가 이미 가지고 있는 {{domxref("BiquadFilterNode")}}와 다를까요?
-An IIR filter is a infinite impulse response filter. It's one of two primary types of filters used in audio and digital signal processing. The other type is FIR — finite impulse response filter. There's a really good overview to IIF filters and FIR filters here.
+IIR 필터는 무한 임펄스 응답 필터입니다. 이것은 오디오와 디지털 신호 처리에서 사용되는 두 가지 주요한 유형의 필터 중 하나입니다. 다른 유형은 FIR — 유한 임펄스 응답 필터입니다. 여기 IIR 필터와 FIR 필터에 대한 정말 좋은 개요가 있습니다.
-A biquad filter is actually a specific type of infinite impulse response filter. It's a commonly-used type and we already have it as a node in the Web Audio API. If you choose this node the hard work is done for you. For instance, if you want to filter lower frequencies from your sound, you can set the type to highpass
and then set which frequency to filter from (or cut off). There's more information on how biquad filters work here.
biquad 필터는 실제로는 무한 임펄스 응답 필터의 특정한 유형입니다. 이것은 흔히 쓰이는 유형이고 우리는 이미 Web Audio API에 노드로 이것을 가지고 있습니다. 만약 여러분이 이 노드를 선택한다면 힘든 일들은 이미 여러분을 위해 완료되어 있습니다. 예를 들자면, 만약 여러분이 사운드에서 낮은 주파수들을 여과하기를 원한다면, 여러분은 type을 highpass
로 설정하고 어떤 주파수를 여과할지 (또는 잘라낼지) 설정할 수 있습니다. 여기 biquad 필터가 어떻게 작동하는지에 대한 더 많은 정보가 있습니다.
When you are using an {{domxref("IIRFilterNode")}} instead of a {{domxref("BiquadFilterNode")}} you are creating the filter yourself, rather than just choosing a pre-programmed type. So you can create a highpass filter, or a lowpass filter, or a more bespoke one. And this is where the IIR filter node is useful — you can create your own if none of the alaready available settings is right for what you want. As well as this, if your audio graph needed a highpass and a bandpass filter within it, you could just use one IIR filter node in place of the two biquad filter nodes you would otherwise need for this.
+여러분이 {{domxref("IIRFilterNode")}}를 {{domxref("BiquadFilterNode")}} 대신에 사용할 때 여러분은 미리 프로그램된 유형을 단지 선택하는 것 보다는 필터를 직접 만드는 것입니다. 그래서 여러분은 하이패스 필터, 또는 로우패스 필터, 또는 더욱 맞춤형의 필터를 만들 수 있습니다. 그리고 이것이 IIR 필터가 유용해지는 지점입니다 — 만약 이미 이용 가능한 세팅중 아무 것도 여러분이 원하는 것에 대해 적합하지 못하다면 여러분은 여러분만의 필터를 만들 수 있습니다. 이것 뿐만이 아니라, 만약 여러분의 오디오 그래프가 내부에 하이패스와 밴드패스 필터를 필요로 한다면, 여러분은 이것을 위해 필요할 두 개의 biquad 필터 노드 대신에 단지 하나의 IIR 필터 노드를 사용할 수 있습니다.
-With the IIRFIlter node it's up to you to set what feedforward
and feedback
values the filter needs — this determines the characteristics of the filter. The downside is that this involves some complex maths.
IIR 필터 노드와 함께 필터가 필요로 하는 어떤 feedforward
와 feedback
값을 설정할지는 여러분에게 달렸습니다 — 이것은 필터의 특징을 결정합니다. 불리한 면은 이것은 몇 가지 복잡한 수학을 수반한다는 것입니다.
If you are looking to learn more there's some information about the maths behind IIR filters here. This enters the realms of signal processing theory — don't worry if you look at it and feel like it's not for you.
+만약 여러분이 더 배우기를 원한다면 여기 몇 가지 IIR 필터 뒤의 수학들에 대한 정보가 있습니다. 이는 신호 처리 이론의 영역에 들어갑니다 — 보고 이것이 여러분을 위한 것이 아닌 것처럼 느껴지더라도 걱정하지는 마세요.
-If you want to play with the IIR filter node and need some values to help along the way, there's a table of already calculated values here; on pages 4 & 5 of the linked PDF the an values refer to the feedForward
values and the bn values refer to the feedback
. musicdsp.org is also a great resource if you want to read more about different filters and how they are implemented digitally.
만약 여러분이 IIR 필터 노드를 가지고 놀기를 원하고 그러기 위해 몇몇 값들이 필요하다면, 여기 이미 계산된 값들의 표가 있습니다; 링크된 PDF의 페이지 4 & 5에서 an값들은 feedForward
값을 나타내고 bn값들은 feedback
을 나타냅니다. 만약 여러분이 다른 필터들과 어떻게 그것들이 디지털적으로 구현되는지에 대해 더 읽기를 원한다면 musicdsp.org는 또한 훌륭한 자원입니다.
With that all in mind, let's take a look at the code to create an IIR filter with the Web Audio API.
+이것 모두를 염두에 둔 채로, Web Audio API로 IIR 필터를 만드는 코드를 살펴봅시다.
-When creating an IIR filter, we pass in the feedforward
and feedback
coefficients as options (coefficients is how we describe the values). Both of these parameters are arrays, neither of which can be larger than 20 items.
IIR 필터를 만들 때, 우리는 feedforward
와 feedback
계수를 옵션으로 (계수들은 우리가 값들을 표현하는 방법입니다) 전달합니다. 이 파라미터 둘 다는 배열이고, 둘 중 어느 것도 20개의 원소보다 클 수 없습니다.
When setting our coefficients, the feedforward
values can't all be set to zero, otherwise nothing would be sent to the filter. Something like this is acceptable:
계수를 설정할 때, feedforward
값들은 모두 0으로 설정될 수 없는데, 그렇지 않으면 아무 것도 필터로 전달되지 않을 것입니다. 이것과 같은 것은 가능합니다:
let feedForward = [0.00020298, 0.0004059599, 0.00020298];-
Our feedback
values cannot start with zero, otherwise on the first pass nothing would be sent back:
feedback
값들은 0으로 시작할 수 없는데, 그렇지 않으면 첫번째 전달에서 아무 것도 되돌아오지 않을 것입니다:
let feedBackward = [1.0126964558, -1.9991880801, 0.9873035442];
Note: These values are calculated based on the lowpass filter specified in the filter characteristics of the Web Audio API specification. As this filter node gains more popularity we should be able to collate more coefficient values.
+참고: 이 값들은 Web Audio API 명세의 필터 특징들에서 명시된 로우패스 필터에 기반하여 계산된 값들입니다. 이 필터 노드가 더욱 많은 인기를 얻고 있으므로 우리는 더 많은 계수 값들을 모을 수 있을 것입니다.
Let's create our context and our filter node:
+컨텍스트와 필터 노드를 만들어 봅시다:
const AudioContext = window.AudioContext || window.webkitAudioContext; const audioCtx = new AudioContext(); @@ -71,7 +71,7 @@ const audioCtx = new AudioContext(); const iirFilter = audioCtx.createIIRFilter(feedForward, feedBack);-
We need a sound source to play. We set this up using a custom function, playSoundNode()
, which creates a buffer source from an existing {{domxref("AudioBuffer")}}, attaches it to the default destination, starts it playing, and returns it:
우리는 재생할 음원이 필요합니다. 우리는 사용자 정의 함수인 playSoundNode()
를 사용하여 이것을 설정하는데, 이 함수는 존재하는 {{domxref("AudioBuffer")}}로부터 버퍼 소스를 만들고, 이것을 기본 목적지에 부착하고, 재생을 시작시키고, 이것을 반환합니다.
function playSourceNode(audioContext, audioBuffer) { const soundSource = audioContext.createBufferSource(); @@ -81,11 +81,11 @@ const iirFilter = audioCtx.createIIRFilter(feedForward, feedBack); return soundSource; }-
This function is called when the play button is pressed. The play button HTML looks like this:
+이 함수는 재생 버튼이 눌러졌을 때 호출됩니다. 재생 버튼 HTML은 다음같이 생겼습니다:
<button class="button-play" role="switch" data-playing="false" aria-pressed="false">Play</button>-
And the click
event listener starts like so:
그리고 click
이벤트 리스너는 다음과 같이 시작합니다:
playButton.addEventListener('click', function() { if (this.dataset.playing === 'false') { @@ -93,11 +93,11 @@ const iirFilter = audioCtx.createIIRFilter(feedForward, feedBack); ... }, false);-
The toggle that turns the IIR filter on and off is set up in the similar way. First, the HTML:
+IIR 필터를 켜고 끄는 토글 버튼은 비슷한 방식으로 설정됩니다. 우선, HTML은:
<button class="button-filter" role="switch" data-filteron="false" aria-pressed="false" aria-describedby="label" disabled></button>-
The filter button's click
handler then connects the IIRFilter
up to the graph, between the source and the detination:
필터 버튼의 click
핸들러는 그리고 나서 IIRFilter
를 그래프에 연결하는데, 이는 소스와 목적지 사이입니다:
filterButton.addEventListener('click', function() { if (this.dataset.filteron === 'false') { @@ -106,58 +106,58 @@ const iirFilter = audioCtx.createIIRFilter(feedForward, feedBack); ... }, false);-
We only have one method available on {{domxref("IIRFilterNode")}} instances, getFrequencyResponse()
, this allows us to see what is happening to the frequencies of the audio being passed into the filter.
우리는 {{domxref("IIRFilterNode")}} 인스턴스에서 이용 가능한 단 하나의 메서드 getFrequencyResponse()
만을 가지고 있는데, 이는 필터 내로 전달되고 있는 오디오의 주파수에 무슨 일이 일어나는지 볼 수 있게 해 줍니다.
Let's draw a frequency plot of the filter we've created with the data we get back from this method.
+우리가 만든 필터의 주파수 플롯을 이 메서드로부터 얻은 데이터로 그려 봅시다.
-We need to create three arrays. One of frequency values for which we want to receive the magnitude response and phase response for, and two empty arrays to receive the data. All three of these have to be of type float32array
and all be of the same size.
우리는 세 개의 배열을 만들 필요가 있습니다. 규모 응답과 상(phase) 응답을 받기를 원하는 주파수 값의 배열 하나, 그리고 데이터를 받기 위한 두 개의 빈 배열입니다. 이 세 개 모두 float32array
유형이여야만 하고 같은 크기여야 합니다.
// arrays for our frequency response +// 주파수 응답에 대한 배열들 const totalArrayItems = 30; let myFrequencyArray = new Float32Array(totalArrayItems); let magResponseOutput = new Float32Array(totalArrayItems); let phaseResponseOutput = new Float32Array(totalArrayItems);-Let's fill our first array with frequency values we want data to be returned on:
+첫번째 배열을 우리가 원하는 반환될 데이터인 주파수 값으로 채웁시다.
myFrequencyArray = myFrequencyArray.map(function(item, index) { return Math.pow(1.4, index); });-We could go for a linear approach, but it's far better when working with frequencies to take a log approach, so let's fill our array with frequency values that get larger further on in the array items.
+우리는 선형적인 접근을 택할 수도 있지만, 주파수를 가지고 작업할 때는 로그 접근을 취하는 것이 훨씬 나으므로, 배열 원소에서 더 커진 주파수 값들로 배열을 채웁시다.
-Now let's get our response data:
+이제 응답 데이터를 얻읍시다:
iirFilter.getFrequencyResponse(myFrequencyArray, magResponseOutput, phaseResponseOutput);-We can use this data to draw a filter frequency plot. We'll do so on a 2d canvas context.
+우리는 이 데이터를 필터 주파수 플롯을 그리기 위해 사용할 수 있습니다. 우리는 2d 캔버스 컨텍스트에서 그렇게 할 것입니다.
-// create a canvas element and append it to our dom +// 캔버스 요소를 만들고 dom에 추가합니다 const canvasContainer = document.querySelector('.filter-graph'); const canvasEl = document.createElement('canvas'); canvasContainer.appendChild(canvasEl); -// set 2d context and set dimesions +// 2d 컨텍스트를 설정하고 크기를 설정합니다 const canvasCtx = canvasEl.getContext('2d'); const width = canvasContainer.offsetWidth; const height = canvasContainer.offsetHeight; canvasEl.width = width; canvasEl.height = height; -// set background fill +// 배경을 채울 색상을 설정합니다 canvasCtx.fillStyle = 'white'; canvasCtx.fillRect(0, 0, width, height); -// set up some spacing based on size +// 크기에 맞춰 여백을 설정합니다 const spacing = width/16; const fontSize = Math.floor(spacing/1.5); -// draw our axis +// 축을 그립니다 canvasCtx.lineWidth = 2; canvasCtx.strokeStyle = 'grey'; @@ -167,7 +167,7 @@ canvasCtx.lineTo(spacing, height-spacing); canvasCtx.lineTo(width-spacing, height-spacing); canvasCtx.stroke(); -// axis is gain by frequency -> make labels +// 축은 gain(y축)과 주파수(x축)입니다 -> 라벨을 만듭니다 canvasCtx.font = fontSize+'px sans-serif'; canvasCtx.fillStyle = 'grey'; canvasCtx.fillText('1', spacing-fontSize, spacing+fontSize); @@ -176,7 +176,7 @@ canvasCtx.fillText('0', spacing-fontSize, height-spacing+fontSize); canvasCtx.fillText('Hz', width/2, height-spacing+fontSize); canvasCtx.fillText('20k', width-spacing, height-spacing+fontSize); -// loop over our magnitude response data and plot our filter +// 규모 응답 데이터를 순회하고 필터를 그립니다 canvasCtx.beginPath(); @@ -193,6 +193,6 @@ for(let i = 0; i < magResponseOutput.length; i++) { canvasCtx.stroke();-Summary
+요약
-That's it for our IIRFilter demo. This should have shown you how to use the basics, and helped you to understand what it's useful for and how it works.
+이것이 IIR 필터 데모의 전부입니다. 이것은 어떻게 기본을 사용하는지를 보여주고, 왜 이것이 유용한지와 어떻게 이것이 작동하는지를 이해하는 것을 도와주었을 것입니다.
-- cgit v1.2.3-54-g00ecf