home *** CD-ROM | disk | FTP | other *** search
/ PC Open 13 / pcopen13.iso / Zip / SM34A.ZIP / LIBRARY / INTE.LIB < prev    next >
Encoding:
Text File  |  1993-04-20  |  2.6 KB  |  71 lines

  1. #    inte(y,x) integrates y with respect to x (indefinite integral)
  2. #    inte(y, x,xmin,xmax) integrates y with respect to x from xmin to xmax)
  3. #    (definite integral).
  4.  
  5. inte(sign(x_), x_) := x*sign(x)
  6. inte(abs(x_), x_) := x*abs(x)/2
  7. inte(ln(x_), x_) := x*ln(x)-x
  8. inte(e^x_/x_, x_) := ei(x)
  9.  
  10. inte(sin(x_), x_) := -cos(x)
  11. inte(cos(x_), x_) := sin(x)
  12. inte(tan(x_), x_) := ln(sec(x)*sign(sec(x)))
  13. inte(cot(x_), x_) := ln(sin(x)*sign(sin(x)))
  14. inte(sec(x_), x_) := ln((sec(x)+tan(x))*sign(sec(x)+tan(x)))
  15. inte(csc(x_), x_) := ln((csc(x)-cot(x))*sign(csc(x)-cot(x)))
  16.  
  17. inte(asin(x_), x_) := x*asin(x)+1/sqrt(1-x^2)
  18. inte(acos(x_), x_) := x*acos(x)-1/sqrt(1-x^2)
  19. # inte(atan(x_), x_) := x*atan(x)-ln((1+x^2))/2
  20.  
  21. #inte(sinh(x_), x_) := cosh(x)
  22. #inte(cosh(x_), x_) := sinh(x)
  23. #inte(tanh(x_), x_) := ln(cosh(x))
  24. #inte(coth(x_), x_) := ln(sinh(x)*sign(sinh(x)))
  25. #inte(sech(x_), x_) := asin(tanh(x))
  26. #inte(csch(x_), x_) := ln(tanh(x/2)*sign(tanh(x/2)))
  27.  
  28. inte(sin(x_)^2, x_) := x/2-sin(2*x)/4
  29. inte(cos(x_)^2, x_) := x/2+sin(2*x)/4
  30. inte(tan(x_)^2, x_) := tan(x)-x
  31. inte(cot(x_)^2, x_) := -cot(x)-x
  32. inte(sec(x_)^2, x_) := tan(x)
  33. inte(csc(x_)^2, x_) := -cot(x)
  34.  
  35. inte(sin(x_)/x_, x_) := si(x)
  36. inte(cos(x_)/x_, x_) := ci(x)
  37.  
  38. inte(sin(x_)*exp(x_), x_) := (sin(x)-cos(x))*exp(x)/2
  39. inte(cos(x_)*exp(x_), x_) := (sin(x)+cos(x))*exp(x)/2
  40.  
  41. inte(1/sqrt(1+x_)/x_, x_) := ln((sqrt(1+x)-1)/(sqrt(1+x)+1))
  42. inte(sqrt(1+x_)/x_, x_) := 2*sqrt(1+x)+ln((sqrt(1+x)-1)/(sqrt(1+x)+1))
  43.  
  44. #inte(1/sqrt(1+x_^2), x_) := asinh(x)
  45. #inte(1/sqrt(1-x_^2), x_) := asin(x)
  46. #inte(1/sqrt(x_^2-1), x_) := acosh(x)
  47. #inte(1/sqrt(1+x_^2)/x_, x_) := -acsch(x)
  48. #inte(1/sqrt(1-x_^2)/x_, x_) :=  -asech(x)
  49. #inte(1/sqrt(x_^2-1)/x_, x_) := asec(x)
  50.  
  51. #inte(sqrt(1+x_^2), x_) := x*sqrt(1+x^2)/2+asinh(x)/2
  52. #inte(sqrt(1-x_^2), x_) := x*sqrt(1-x^2)/2+asin(x)/2
  53. #inte(sqrt(x_^2-1), x_) := x*sqrt(x^2-1)/2-acosh(x)/2
  54. # inte(x_^2*sqrt(1+x_^2), x_) := x*(1+x^2)^1.5/4-sqrt(1+x^2)/8-(1/8)*asinh(x)
  55. #inte(sqrt(1+x_^2)/x_, x_) := sqrt(1+x^2)-2*acsch(x)
  56.  
  57. inte(a_/b_, x_) := if(d(b,x)==a, ln(|b|))
  58.  
  59. inte(e^(-a*x_^2), x_) := sqrt(pi)/2*erf(sqrt(a)*x)/sqrt(a)
  60.  
  61.  
  62. inte(y_,x_,a1_,b1_) := if(a1 <= 0 and b1 >= 0 and subs(y,x=0) == inf, inf)
  63. inte(y_,x_,a2_,b2_) := if(a2 <= 0 and b2 >= 0 and subs(y,x=0) == -inf, -inf)
  64. inte(y_,x_,a3_,b3_) := if(a3 >= 0 and b3 <= 0 and subs(y,x=0) == inf, -inf)
  65. inte(y_,x_,a4_,b4_) := if(a4 >= 0 and b4 <= 0 and subs(y,x=0) == -inf, inf)
  66. inte(y_,x_,a_,b_) := block(integ:=inte(y,x),
  67.      subs(integ,x=b)-subs(integ,x=a), local(integ))
  68.  
  69. inte(y_,x_,a_,b_,c_) := block(inte:=inte(y,x),
  70.      subs(inte,x=c)-subs(inte,x=b+zero)+subs(inte,x=b-zero)-subs(inte,x=a))
  71.