본문으로 이동
주 메뉴
주 메뉴
사이드바로 이동
숨기기
둘러보기
대문
최근 바뀜
임의의 문서로
미디어위키 도움말
특수 문서 목록
학교의 모든 지식. SMwiki
검색
검색
보이기
로그인
개인 도구
로그인
로그아웃한 편집자를 위한 문서
더 알아보기
기여
토론
파이썬:푸리에 분석
편집하기 (부분)
문서
토론
한국어
읽기
편집
원본 편집
역사 보기
도구
도구
사이드바로 이동
숨기기
동작
읽기
편집
원본 편집
역사 보기
일반
여기를 가리키는 문서
가리키는 글의 최근 바뀜
파일 올리기
문서 정보
보이기
사이드바로 이동
숨기기
경고:
로그인하지 않았습니다. 편집을 하면 IP 주소가 공개되게 됩니다.
로그인
하거나
계정을 생성하면
편집자가 사용자 이름으로 기록되고, 다른 장점도 있습니다.
스팸 방지 검사입니다. 이것을 입력하지
마세요
!
= 고속 푸리에 분석 = 다음과 같이 x와 y, 간격 데이터를 적절히 정리해주면 된다.<syntaxhighlight lang="python3"> # 데이터 처리. x_vals = df[x].values # x 컬럼(시간 또는 인덱스) signal_data = df[y].values # 선택된 y 컬럼의 데이터 (numpy 배열) try: T = float(T) # 숫자만 받아들일 수 있다. except: # 입력값이 없는 경우. # 자동으로 간격 계산 (균등하다고 가정) x_diff = np.diff(x_vals) if np.allclose(x_diff, x_diff[0]): # 거의 동일한 간격이면 T = x_diff[0] else: T = np.mean(x_diff) N = len(signal_data) # 데이터 포인트 개수 # 푸리에 변환 계산 fft_result = np.fft.fft(signal_data) freqs = np.fft.fftfreq(N, d=T) fft_freqs = freqs[:N // 2] fft_magnitude = np.abs(fft_result[:N // 2]) # plotly 그래프를 위해 데이터프레임 생성 fft_df = pd.DataFrame({'Frequency_Index': fft_freqs, 'Magnitude': fft_magnitude}) # 'Frequency_Index'로 이름 변경 # 그래프 생성 (plotly line plot) plot_title = f'{y} 컬럼 푸리에 변환 결과 (샘플링 주기: {T:.4f})' if T > 0 else f'{y} 컬럼 푸리에 변환 결과' fig = px.line(fft_df, x='Frequency_Index', y='Magnitude', title=plot_title, labels={'Frequency_Index': 'Frequency (Relative or Index)', 'Magnitude': 'Magnitude'}) # 그래프 레이아웃 조정 (선택 사항) fig.update_layout(xaxis_title="주파수 (상대값 또는 인덱스)", yaxis_title="크기 (Magnitude)") # 그래프를 HTML div로 변환 plot_div = plot(fig, output_type='div') context['plot_div'] = plot_div </syntaxhighlight>
요약:
학교의 모든 지식. SMwiki에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 라이선스로 배포된다는 점을 유의해 주세요(자세한 내용에 대해서는
학교의 모든 지식. SMwiki:저작권
문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요.
또한, 직접 작성했거나 퍼블릭 도메인과 같은 자유 문서에서 가져왔다는 것을 보증해야 합니다.
저작권이 있는 내용을 허가 없이 저장하지 마세요!
취소
편집 도움말
(새 창에서 열림)
검색
검색
파이썬:푸리에 분석
편집하기 (부분)
새 주제