Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.soft-sys.math.mathematica > #16714

Re: Problems with Solve

From danl@wolfram.com
Newsgroups comp.soft-sys.math.mathematica
Subject Re: Problems with Solve
Date 2014-04-01 07:03 +0000
Message-ID <lhdobp$of$1@smc.vnet.net> (permalink)
References <lgj2cs$lcg$1@smc.vnet.net>
Organization Time-Warner Telecom

Show all headers | View raw


On Friday, March 21, 2014 11:09:00 PM UTC-5, Samuel Mark Young wrote:
> Hello everyone,
>
> I'm trying to use the solutions of Solve from solving a cubic equation - however, it keeps returning complex answers when there are real solutions. For example:
>
>
>
> Solve[z + 5 (z^2 - 1) + 1 z^3 == 1, z]
>
>
>
> This equation has 3 real solutions. However, the answers returned when I ask mathematica for a decimal answer are complex (which I need to do later on when an integration needs solving numerically):
>
> {{z -> 0.925423 + 0. I}, {z -> -4.47735 +
>
>     2.22045*10^-16 I}, {z -> -1.44807 - 4.44089*10^-16 I}}
>
>
>
> I'm guessing this is to do with the finite precision that is used in the calculations as the imaginary components are very small, but am unsure how to deal with them and they shouldn't be there. Any suggestions?
>
>
>
>
>
> The second problem I am having is that I need to solve for s in a function B[s] == 10^-5, where B is some (complicated) function of s.
>
>
>
> The form of the function depends on s - and this is handled by If[] commands in the function B. For example, the s dependance might be:
>
>
>
> B[s]:=If[s<0.5,Erfc[-x],Erfc[-x]+Erfc[y]-Erfc[z]]
>
>
>
> B[s] is a smooth function of s.
>
>
>
> The problem seems to arise because, before it has found a solution for s, it can't decide which form of the function to use - and so just returns an error message (I've tried using Solve, NSolve, and FindRoot with different methods). However, since I'm only looking for a numerical solution it is easily possible to solve this manually using trial and improvement - which seems to be something that Mathematica should be able to do? But I can't figure out how.
>
>
>
> Please feel free to contact me directly at sy81@sussex.ac.uk with advice.  Thank you in advance for any help!
>
>
>
> Regards,
>
> Sam

For item (1) you might wish to do it via Solve[..., Cubics->False]. The result you are getting is correct but it will indeed numericize with those small phantom imaginary parts; that's a result of what's called truncation error.

For item (2) I would have recommended exactly what Ray Koopman already posted.

Daniel Lichtblau
Wolfram Research

Back to comp.soft-sys.math.mathematica | Previous | NextPrevious in thread | Find similar


Thread

Problems with Solve Samuel Mark Young <sy81@sussex.ac.uk> - 2014-03-22 04:09 +0000
  Re: Problems with Solve totarefugium <mtaktikos@t-online.de> - 2014-03-23 09:01 +0000
  Re: Problems with Solve totarefugium <mtaktikos@t-online.de> - 2014-03-23 08:59 +0000
  Re: Problems with Solve danl@wolfram.com - 2014-04-01 07:03 +0000

csiph-web