가우스 조던으로 짠 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;
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2700368 | if에 관해서 질문이요... | Orange | 2025-07-04 |
2700339 | 이거 결과값이 왜이런건지.. (4) | 그댸와나 | 2025-07-04 |
2700313 | 파일 읽어서 저장하는데 빈파일일 경우 문재가 발생하네요.. (2) | 크나 | 2025-07-03 |
2700287 | 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) | 아련나래 | 2025-07-03 |
2700264 | 문자와 숫자 동시에 입력??? | 글고운 | 2025-07-03 |
2700236 | txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) | 미국녀 | 2025-07-03 |
2700211 | 전위 연산자 (2) | 어른처럼 | 2025-07-02 |
2700183 | C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; | 피스케스 | 2025-07-02 |
2700150 | 꼭좀 도와주세요ㅠㅠㅠ | 호습다 | 2025-07-02 |
2700095 | 연산문제...질문... | 오빤테앵겨 | 2025-07-01 |
2700070 | while문 , 3의배수 출력하는 프로그램좀 짜주세욤. | 횃불 | 2025-07-01 |
2700041 | 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? | 헛장사 | 2025-07-01 |
2700012 | 배열// (1) | 전갈자리 | 2025-07-01 |
2699895 | 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) | 선아 | 2025-06-30 |
2699842 | 질문을 너무 많이 하네여.....죄송.... (2) | 해님꽃 | 2025-06-29 |
2699816 | 오류 질문입니다.. (1) | 해비치 | 2025-06-29 |
2699763 | 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) | 미라 | 2025-06-28 |
2699555 | c언어 다항식을 입력을 했는데 왜 출력이 안될까요? | 피스케스 | 2025-06-27 |
2699528 | C언어 포인터연산 질문입니다. (3) | 안녕나야 | 2025-06-26 |
2699476 | 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) | 클라우드 | 2025-06-26 |