-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcomplex.c
53 lines (45 loc) · 1.77 KB
/
complex.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* complex.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: ysingh <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/11/30 21:36:17 by ysingh #+# #+# */
/* Updated: 2022/12/12 15:02:53 by ysingh ### ########.fr */
/* */
/* ************************************************************************** */
#include "fractol.h"
t_complex *ft_create_complex(double real, double imagine)
{
t_complex *data;
data = (t_complex *)malloc(sizeof(t_complex));
if (!data)
return (NULL);
data->real = real;
data->imagine = imagine;
return (data);
}
void ft_complex_addnum(t_complex *n1, t_complex *n2)
{
double result_real;
double result_imagine;
result_real = (n1->real) + (n2->real);
result_imagine = (n1->imagine) + (n2->imagine);
n1->real = result_real;
n1->imagine = result_imagine;
}
void ft_complex_mul(t_complex *n1, t_complex *n2)
{
double result_real;
double result_imagine;
result_real = (n1->real * n2->real) - (n1->imagine * n2->imagine);
result_imagine = (n1->real * n2->imagine) + (n1->real * n2->imagine);
n1->real = result_real;
n1->imagine = result_imagine;
}
float ft_complex_module(t_complex *complex)
{
return ((complex->real * complex->real)
+ (complex->imagine * complex->imagine));
}