가우스 조던으로 짠 31차 역행렬
희나리
고조파의 웨이브폼 데이터를 집어넣어 차수별 고조파의 크기를 나타내도록 만들었습니다.
역행렬만드는게 젤 어려웠는데 가우스 조던으로 해결했네여.
#include stdio.h
#include math.h
#define M_PI 3.14
#define n (31)
double sqr_X[n][n] = {0}; // S_n 입력
double mat[n][2*n] = {0}; // S_n에 정방행렬 붙인 형태
double inv_mat[n][n] = {0}; // S_n의 역행렬
double table1 [n][1] = {0}; //차수별 고조파의 크기 입력 A_n
double table3 [n][1] = {0}; // 차수별 고조파의 크기 출력V_t
double table5 [n][1] = {0}; // A_n result
int main (void)
{
int n;
int i , j, k;
double mul_cont, div_cont;
double fGet;
for ( i = 0 ; i n ; i++ )
{
for ( j = 0 ; j n ; j++ )
{
fGet = sinl (((double)i+1) * (2 * M_PI) * (((double)j+1) / 32));
sqr_X[i][j] = fGet;
}
}
printf(\n 입력한 행렬 S_n = \n);
for ( i = 0 ; i n ; i++ )
{
;
for ( j = 0 ; j n ; j++ )
{
printf(%3.2lf\t, sqr_X[i][j]);
}
printf(\n);
}
printf(\n);
for (i=0;i n;i++)
{
for (j=0;j n;j++)
{
mat[i][j] = sqr_X[i][j];
}
for (j=n;jn*2;j++)
{
mat[i][j] = 0;
if (i+n == j)
mat[i][j]=1;
}
}
for (j=0;j n;j++)
{
div_cont = mat[j][j];
for (k = 0;k n*2; k++)
{
mat[j][k] = mat[j][k] / div_cont;
}
if (j != 0)
{
for (i=0;i j;i++)
{
mul_cont = mat[i][j];
for (k=0;k n*2;k++)
{
mat[i][k] = mat[i][k] - mat[j][k] * mul_cont;
}
}
}
if (j != n-1 )
{
for (i=j+1;i n;i++)
{
mul_cont = mat[i][j];
for (k=0;k n*2;k++)
&nbsr / {
mat[i][k] = mat[i][k] - mat[j][k] * mul_cont;
}
}
}
}
for (i=0;i n;i++)
{
for (j=n;j n*2;j++)
{
inv_mat[i][j-n] = mat[i][j];
}
}
printf(\n 입력한 행렬 S_n의 역행렬 = \n);
for (i =0 ; i n; i++)
{
for (j=0 ; j n; j++)
{
printf(%8.2lf\t , inv_mat[i][j]);
}
printf(\n);
}
printf(\n---------------------------------------------------------------\n);
printf(각 차수별 고조파의 크기를 넣으세여 \n ); /* A_n 값 입력 */
printf(\n);
for( j = 0 ; j n ; j++)
{
for( k = 0 ; k 1 ; k++)
{
printf(%d 차 고조파의 크기 : ,j+1);
scanf(%lf, &table1[j][k]);
}
}
printf(\n);
printf(\n);
printf(**********************\n);
printf( V_t \n);
printf(**********************\n);
for( i = 0 ; i n ; i++)
{
for( j= 0 ; j n ; j++)
{
for( k = 0 ; k 1 ; k++)
{
table3[i][k] += sqr_X[i][j] * table1[j][k];
}
}
}
for( i = 0 ; i n; i++)
{
for( k= 0 ; k 1 ; k++)
{
printf(V_t_%d : %lf \n,i+1, table3[i][k], \n );
}
}
printf(\n);
printf(**********************\n);
printf( A_t result \n);
printf(**********************\n);
for( i = 0 ; i n ; i++)
{
for( j= 0 ; j n ; j++)
{
for( k=0 ; k 1 ; k++)
{
table5[i][k] += inv_mat[i][j] * table3[j][k];
}
}
}
for( i = 0 ; i n; i++)
{
for( k= 0 ; k 1 ; k++)
{
printf(A_t_%d : %lf \n,i+1, table5[i][k], \n );
}
}
return 0;
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |
2693727 | scanf 오류 문제!! (2) | 큰나래 | 2025-05-04 |
2693704 | 구조체 주소록 문제인데 도와주세요 (2) | 도1도캣 | 2025-05-04 |
2693676 | 열혈강의 c언어 질문입니다 | 하양이 | 2025-05-04 |
2693647 | 12.620000 을요 12.620 으로 어떻게 표현해요? (2) | 파도 | 2025-05-04 |
2693619 | 타이틀 코드.. | 단순드립 | 2025-05-03 |
2693591 | 컴파일 에러에서 질문드립니다 (3) | 게자리 | 2025-05-03 |
2693463 | 동적할당 이용시 fwrite사용을 어떻게 해야하나요..? (10) | 일본어못해요 | 2025-05-02 |
2693387 | 배열문제입니다 수정오류캡쳐했습니다 (6) | 연하얀 | 2025-05-01 |
2693356 | text 입출력 내림차순 질문입니다 ㅠ | 빛글 | 2025-05-01 |
2693328 | C언어를이용해서 .txt파일 외에 다른 확장자 파일 삭제가 가능한지.. (2) | 대나무 | 2025-05-01 |