AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Komplexe Zahlen: Potenzen

Ein Thema von Green · begonnen am 31. Jan 2008 · letzter Beitrag vom 1. Feb 2008
Antwort Antwort
Green

Registriert seit: 11. Jun 2006
156 Beiträge
 
#1

Komplexe Zahlen: Potenzen

  Alt 31. Jan 2008, 16:56
So. Ich habe ein Programm geschrieben (oder bin eher dabei) in dem viel mit komplexen zahlen gerechnet wird.
Jetzt ist folgendes Problem: ich möchte eine bestimmte zahl (kopmplex) hoch eine andere nehmen.

Also praktisch A(Ar, Ai)^B(Br, Bi).

Die variablen Ar, Ai, Br, Bi liegen als doubles vor.

Was machen? hab mir viel durchelgesen (gegooglet, wikipedia etc.) und ganz viele tole formeln zum protenzieren von Complexen Zahlen gefunden, aber irgendwie bin ich aus dem Zeug nicht schlauer geworden..

was jetzt?

lG Green
  Mit Zitat antworten Zitat
jbaertle

Registriert seit: 2. Mär 2007
Ort: München
20 Beiträge
 
Delphi 7 Professional
 
#2

Re: Komplexe Zahlen: Potenzen

  Alt 31. Jan 2008, 18:02
Hallo Green,

also falls Du Dein Problem der Potenz komplexer Zahlen selber programmieren musst/möchtest, bringt Dich mein Hinweis vielleicht weiter (um etwas rechnen/programmieren kommst Du leider nicht rum).

Erste Zahl: A = R*e^(i*f)
Zweite Zahl: B = (C+i*D)

Dann gilt für E = A^B = R^B * (e^(i*f))^B = R^B * e^(i*f*B)

Der Term mit der Exponentialfunktion ist kein Problem, einfach ausmultiplizieren und den Term e^(i...) in den cos. bzw. sin-Teil trennen.
Der Term R^B = R^C * R^(i*D) macht mit R^(i*D) noch etwas Aufwand, aber es gilt: R^(i*D) = (e^(ln(R)))^(i*D) = e^(ln(R)*i*D) = e^(i*D*ln(R)) = cos (D*ln(R)) + i*sin ...

Hoffe, das hilft Dir.
Ach ja, ich wüsste jetzt nicht, wo ich eine solche Potenz brauchen kann, aber Mathe ist ja auch einfach so schön...

Schönen Abend noch, Jani.
  Mit Zitat antworten Zitat
Benutzerbild von Kroko1999
Kroko1999

Registriert seit: 21. Apr 2005
Ort: Spremberg
455 Beiträge
 
Turbo Delphi für Win32
 
#3

Re: Komplexe Zahlen: Potenzen

  Alt 31. Jan 2008, 18:40
Hier steht doch die gleiche Formel, wo ist dein Problem
Da sprach der Stumme zum Blinden: "Du wirst sehen ..."
oder
Wer lesen kann, ist klar im Vorteil!
  Mit Zitat antworten Zitat
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#4

Re: Komplexe Zahlen: Potenzen

  Alt 31. Jan 2008, 21:57
Was für ein Programm schreibst du denn, in dem komplexe Zahlen potenziert werden müssen?
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.685 Beiträge
 
Delphi 2007 Enterprise
 
#5

Re: Komplexe Zahlen: Potenzen

  Alt 1. Feb 2008, 02:39
Das ganze lässt sich ein wenig aufdröseln. Der Ansatz lautet im Reellen wie im Komplexen: a^b = exp(b*ln(a))

Du brauchst also nur noch die komplexen Varianten der Exponentialfunktion und des natürlichen Logarithmus, und kannst dann sehr elegant 2 komplexe Argumente miteinander Potenzieren.

Exp(C):
Delphi-Quellcode:
function expC(const C : TComplex) : TComplex;
var
  sn, cs : extended;
  t : double;
begin
  sincos(C.i, sn, cs);
  t := exp(C.r);
  result.r := t * cs;
  result.i := t * sn;
end;
Ln(C):
Delphi-Quellcode:
function lnC(const C : TComplex) : TComplex;
begin
  result.r := ln(sqrt(sqr(C.r)+sqr(C.i)));
  result.i := argC(C).r;
end;
Wobei du hier noch argC() brauchst:
Delphi-Quellcode:
function argC(const C : TComplex): double;
var
  temp : double;
begin
  result := 0;
  temp := 0;
  if (C.r = 0) and (C.i = 0) then Exit;

  if C.i <> 0 then
  begin
    result := pi / 2 * Sign(C.i);
    Exit;
  end
  else
  begin
    if C.r > 0 then
    begin
      result := 0;
      Exit;
    end
    else
    begin
      result := pi;
      Exit;
    end;
  end;

  if C.r <> 0 then
    temp := ArcTan(Abs(C.i / C.r));

  if C.r > 0 then
  begin
    if C.i > 0 then
    begin
      result := temp;
      Exit;
    end
    else
    begin
      result := -temp;
      Exit;
    end;
  end
  else
  begin
    if C.i > 0 then
    begin
      result := pi - temp;
      Exit;
    end
    else
    begin
      result := temp - pi;
      Exit;
    end;
  end;
end;
Schaut erstmal wild aus, funktioniert aber auch.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:45 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz