Komplex számok a programozásban

Innen: HamWiki
A lap korábbi változatát látod, amilyen HG2ECZ (vitalap | közreműködések) 2014. november 30., 19:19-kor történt szerkesztése után volt. (→‎C)
Ugrás a navigációhoz Ugrás a kereséshez

Láttuk, hogy a komplex számok RLC körök váltakozóáramú viselkedésének leírásánál fontos szerephez jutnak. Jelen szócikk azt vizsgálja, mely programnyelveken hogyan lehet komplex számokkal számításokat csinálni.

C

Nyelvi szinten a c99 szabványtól támogatva van.

<source lang="C">

  1. include <stdio.h>
  2. include <complex.h>

void kiir(const char *s, float complex a) {

   printf("%s: %f + %fj\n", s, creal(a), cimag(a) );

}

int main() {

   float complex a, b;
   a = 5 + 3i; // de akár 5 + 3j vagy 5 + 3*I alakban is megadható.
   b = 3 + 2i;
   // creal(a), cimag(a) - lásd kiír függvényben.
   kiir("a: ", a);
   kiir("b: ", b);
   // vektorhossz; cabs: double, cabsf: float, cabsl: long double
   printf("cabs(a): %f\n", cabs(a) );
   // fázis; carg: double, cargf: float, cargl: long double
   printf("carg(a): %f\n", carg(a) ); // radiánban
   kiir("a+b: ", a + b);
   kiir("a*b: ", a * b);
   kiir("a/b: ", a / b);
   return 0;

} </source>

Ha régebbi, például ansi C-t vagy C90 szabványt ismerő fordító esetén a nyelvi támogatás hiányában például az alábbi komplex számokat kezelő függvényekkel tudunk számolni:

<source lang="c">

  1. include <math.h>

typedef struct _complex {

   float real;
   float imag;

} Complex;

Complex cadd(Complex a, Complex b) {

   Complex res;
   res.real = a.real + b.real;
   res.imag = a.imag + b.imag;
   return res;

}

Complex cmul(Complex a, Complex b) {

   Complex res;
   res.real = a.real * b.real - a.imag * b.imag;
   res.imag = a.real * b.imag + b.real * a.imag;
   return res;

}

// (a.real + a.imag) / (b.real + b.imag) // ---> szorozzuk a nevező konjugáltjával, azaz (b.real - b.imag) értékkel Complex cdiv(Complex a, Complex b) {

   Complex res, tmp;
   tmp.real = a.real * b.real + a.imag * b.imag; // keresztszorzatok kiesnek
   res.real = (a.real * b.real + a.imag * b.imag)/tmp.real;
   res.imag = (a.imag * b.real - a.real * b.imag)/tmp.real;
   return res;

}

float magnitude(Complex a) {

   return sqrt(a.real*a.real + a.imag * a.imag);

}

float phase(Complex a) {

   return atan2(a.imag, a.real);

} </source>

C#

apt-get install libmono-system-numerics4.0-cil
mcs -r:System.Numerics complex_teszt.cs

<source lang="csharp"> using System; using System.Numerics;

public class Example {

  public static void Main() {
     Complex a = new Complex(5, 3);
     Complex b = new Complex(3, 2);
     Complex r;
     Console.WriteLine(a.ToString());
     Console.WriteLine(b.ToString());
     Console.WriteLine(a.Real);
     Console.WriteLine(a.Imaginary);
     Console.WriteLine(Complex.Abs(a));
     Console.WriteLine(a.Magnitude); // Abs másképpen
     Console.WriteLine(a.Phase);
     r = a + b;
     Console.WriteLine(r.ToString());
     r = a * b;
     Console.WriteLine(r.ToString());
     r = a / b;
     Console.WriteLine(r.ToString());
  }

} </source>

Java

Nyelvi elemként nem ismeri a komplex számokat, azonban számtalan LIB letölthető hozzá a komplex számokkal való számoláshoz.

Javascript

Nyelvi elemként nem támogatja, azonban a komplex számokat kezelő függvénygyűjtemény itt található rá: http://mathjs.org/

Példa: http://mathjs.org/examples/complex_numbers.js.html

Octave

Az Octave egy matematikai program, jól szkriptelhető, egyszerű a nyelvezete. Műszaki számításokra kifejezetten alkalmas. Amennyiben ;-vel zárjuk a sort, akkor annak a sornak az eredménye nem kerül ki a képernyőre.

A komplex számok nyelvi szinten vannak támogatva.


<source lang="octave">

  1. !/usr/bin/octave

a = 5 + 3i b = 3 + 2i

disp "a: Real, imag:" re = real(a) im = imag(a)

disp "a: magnit, phase:" magnit = abs(a) phase = arg(a)

disp "a+b, a*b, a/b:" plusz = a+b szor = a*b per = a/b </source>

PHP

Alapból nincs támogatva, azonban a feltelepíthető a Complex csomag (jelenleg béta). Sajnos ezzel sem olyan kényelmes a komplex számokkal való számolás. Szerencsés lenne itt is nyelvi elemként beintegrálni.

pear install Math_Complex
# illetve ha nem települ fel, akkor:
pear install Math_Complex channel://pear.php.net/Math_Complex-0.8.6

Példa: https://github.com/pear/Math_Complex/blob/master/docs/examples/using_complexop.php

Próbáim során a ComplexOp problémás volt, így a Complex lett csak behívva, amiben még nincs összeadás, szorzás, osztás.

<source lang="php"> <?php require_once 'Math/Complex.php';

$a = new Math_Complex(5, 3); // a = 5 + 3j $b = new Math_Complex(3, 2); // b = 3 + 2j

echo "a: ", $a->toString(), "\n"; echo "b: ", $b->toString(), "\n";

echo "real(a): ", $a->getReal(), "\n"; echo "imag(a): ", $a->getIm(), "\n";

echo "magnit: ", $a->abs(), "\n"; echo "phase: ", $a->angle(), "\n";


// alábbi nekem a ComplexOp modul hibájával elszállt require_once 'Math/ComplexOp.php';

$r = Math_ComplexOp::add($a. $b); echo "a+b: ", $r->toString(), "\n";

$r = Math_ComplexOp::mult($a. $b); echo "a*b: ", $r->toString(), "\n";

$r = Math_ComplexOp::div($a. $b); echo "a/b: ", $r->toString(), "\n"; ?> </source>


Python

A komplex számok nyelvi szinten támogatva vannak.

<source lang="python">

  1. !/usr/bin/python

import cmath

a = 5 + 3j b = 3 + 2j

print "real(a): ", a.real print "imag(a): ", a.imag

print "a:", a print "b:", b

print "abs:", abs(a) print "phase:", cmath.phase(a) print "polar:", cmath.polar(a)

print "a+b:", a+b print "a*b:", a*b print "a/b:", a/b </source>

Ruby

A Ruby szintén nyelvi szinten támogatja a komplex számokkal való műveleteket.

<source lang="ruby">

  1. !/usr/bin/ruby

a = 5 + 3i b = 3 + 2i

print a.real print a.imag

print a print b

print a.abs() print a.phase() print a.polar()

print a+b print a*b print a/b </source>