2017-10-01 16:03:17 -0600 | received badge | ● Famous Question (source) |
2017-10-01 16:03:17 -0600 | received badge | ● Notable Question (source) |
2017-06-24 15:12:35 -0600 | received badge | ● Nice Answer (source) |
2017-01-14 05:02:04 -0600 | received badge | ● Notable Question (source) |
2016-03-08 00:48:33 -0600 | received badge | ● Popular Question (source) |
2016-03-07 06:47:00 -0600 | received badge | ● Popular Question (source) |
2015-08-08 03:21:43 -0600 | answered a question | Simplify result of this definite integral for an answer to this and related other questions see http://thingwy.blogspot.de/ |
2015-08-08 03:20:33 -0600 | received badge | ● Notable Question (source) |
2015-02-28 18:35:49 -0600 | received badge | ● Popular Question (source) |
2014-10-20 00:48:59 -0600 | received badge | ● Popular Question (source) |
2013-09-26 21:15:03 -0600 | answered a question | Fermi-Dirac integral of half order
A) unrelated to sage: as I already said in my previous post, I'd be careful making all-out statements. (Even more so based on 'quick' google seraches). So once again, to falsify your claims: [1] The Analytical Evaluation of the Half-Order Fermi-Dirac Integrals Jerry A. Selvaggi, and Jerry P. Selvaggi The Open Mathematics Journal, 2012, 5, 1-7 [2] Solutions to the Fermi-Dirac Integrals in Semiconductor Physics Using Polylogarithms M. Ulrich, W. Seng, P. Barnes Journal of Computational Electronics 1: 431434, 2002 and several other papers. You should also realize, that there is a difference between scientific papers, like the preceding, which have undergone peer review, and some unpublished and unrefereed 'notes', which pop up on the internet - like the one you point to @ nanohub.org From the preceeding, I guess it is quite clear, where or to whom to apply vocabulary like 'egregious'. Moreover, it is Ref. [2] which tells you that things work down even to y>-1. Just pls. read the papers before posting. B) related to sage: MM is not '..programmed to recognize Fermi-Dirac integrals and respond accordingly..'. Basically it uses eqn. (5) of Ref. [2], which is a paper free to be read with results free to be used by anyone - also outside of academia. Obviously MM has simply cared to include this result into its code - while sage has not. As simple as that.
C) related to this forum I like this forum because it tends to be free of such statements. Pls. keep it that way. |
2013-09-26 06:42:15 -0600 | answered a question | Sage Cloud - parallel processing - cluster online public I'd be the last to put the brake on your sage enthusiasm ... and I can't answer your question on SAGE cloud usage ... so, admittedly my answer is kind of unrelated to this forum ... but if you are really up to writing scientifically competitive numerical Monte Carlo production code including - as your question suggests - parallelism, i.e. most likely code that makes use of MPI, then, to my humble understanding you may want to reconsider, if a CAS like sage is really what you want to use for that - before you get stuck. Surely you can try doing your best at using essentially the C(P)ython subset of sage including libs like mpi4py. But even then - and I have lots of examples for that - it is very very likely, that your MC code will perform poorly, to say the least, as compared to any straightforward C++ implementation. |
2013-09-24 22:24:18 -0600 | answered a question | Problem with quad from SciPy There are two comments in order here: A) as you state yourself, the integrands of your expression, e.g. contains lots of symbolic varibles: B) having said that, and not knowing what your actual problem is, I however presume that the preceeding is not what you actually want, and that rather you want to set up some kind of linear equation (eq1 ?) with symbolic variables and numerically evaluated 'constants'. If that is so, I would disect the numerical integration of each of those constant off from the symbolic part of the code. |
2013-09-20 05:05:43 -0600 | commented answer | is it a sparse matrix or dense matrix? @whomeveritmayconcern: I'd dare to disagree with the notion that a matrix is not sparse or dense by itself. I'd rather go with the majority of mathematical definitions on that, which can also be found publicly, e.g. http://en.wikipedia.org/wiki/Sparse_matrix, or http://www.phy.ornl.gov/csep/la/node14.html, or many others. Also, the 'difference' between sparse and dense matrices ist not how you store them ... I believe matrices exist even without computer RAM ;-) . Rather, once a matrix has been identified to be sparse, then you may want to consider storing it into various existing sparse matrix formats and may want to use various sparse matrix algorithms ... yet, even if you would stay away from doing so, the matrix would still remain sparse by itself. |
2013-09-20 04:21:44 -0600 | answered a question | is it a sparse matrix or dense matrix? For a matrix $M$ of rank $N\times N$, the number of non-zero elements should scale $\sim N$ or, at most, $\sim N \log(N)$ for $M$ to be sparse, otherwise most sparse matrix algorithms are of rather little help. (You can surely refine this statement for $N\times M$ matrices with $N\neq M$ ...) In turn, I would not call 'your' matrix sparse. |
2013-09-06 22:53:21 -0600 | answered a question | Fermi-Dirac integral of half order First, when asking questions, it might speed up a potential answer if you would care to give enough detail about your problem ... so, I only guess that this is what you want $$F(y,\mu) = \int_0^\infty \frac{x^{y}}{e^{x+\mu}+1} dx$$ Second, I'd be very careful about www-ing statements like
since, to my recollection $F(y,\mu)$ is just another way of writing the polylog for all $y>-1$, i.e down to those values of $y$ where the singularity of the integrand remains harmless. Therefore, at least I do not understand your claim, since in 1D the DOS in a semiconductor is $\propto x^{-1/2}$ (which you also did not specify that in your question). So it can be done analytically ... Third, if still you really want to do this numerically in sage ... just look here http://www.sagemath.org/doc/reference/calculus/sage/gsl/integration.html and e.g. do this Finally, and only to my very humble understanding: sage is a chain of existing tools, i.e. it is kind of as strong as it's weakest link. Since in plain sage things like Maxima are the link for many of those calculations which 90%-99% of non-mathematician might call 'symbolic', plain sage frequently is of little help if compared to MM or Maple once you come to such 'symbolic' problems. Applied to your case this means: so, nothing ... or if you try special values again, not too helpful. Maybe there are 'tricks' to get further but I don't know. If however you use MM then, out of the box: so MM 'knows' that your integral can be done analytically and provides the answer, and which is the numerical value we got previously. In conclusion: To answer if that implies you should better be using MM, there are more powerful experts around here. |
2013-09-05 09:42:10 -0600 | answered a question | A very nonlinear system of three equations If you just want to have a numerical solution to a small set of (nonlinear) equations, why not simply 'fsolve' them? The 'abs()' is there to provide at least some additional constraining on a,b,c I don't know if this is elegant - but it is straightforward. |
2013-09-04 10:06:49 -0600 | asked a question | Simplify result of this definite integral It is well known that for $n\in\mathbb{N}$ and $n>0$ (an maybe even for more than these restrictions): $$I_n = \int_0^\infty\frac{x^n}{e^x-1}dx = \zeta(n+1)n!$$ which, analytically can be shown easily by expanding $1/(1-e^{-x})$ into a geometric series, which leads to trivial integrals, and by using $\zeta(n+1)=\sum_{l=1}^\infty l^{-(n+1)}$. So, eg.: $$I_1 = \pi^2/6$$ $$I_2 = 2\zeta(3)$$ a.s.o... Now, if I try even the simplest case with sage, I get this 'nifty' little results Is there any trick to simplify this down to the final result, or is this about as far as I can get with sage alone? PS.: it is probably needless to say that (once again ... :( ...) |
2013-08-20 06:52:06 -0600 | received badge | ● Student (source) |
2013-08-19 08:31:38 -0600 | asked a question | arithmetic with matrices of formal functions If I have two plain formal functions, like it seems I can always get more 'involved' formal functions, like the following h(k,q), by symbolic operations My naive hope was, that this would straightforwardly apply also to matrix construction from formal functions, like so So, B(k,q) does not substitute the variables. After some attempts, it seems that this is a valid way to construct a callable symbolic matrix from formal functions My 1st question is, if there is not a 'less cryptic' way to construct B from u and v? My 2nd question concerns doing matrix arithmetic with B. If I try to do something similar to that for the plain formal function arithmetic for h(k,q) with my formal matrix function B it 'does not work'. Eg.: I.e., again, upon matrix multiplication, the object B(k,q)*B(q,q) seems to not substitute the arguments into the formal functions anymore. However, if I do Then But it seems awkward if one would have to do matrix arithmetic like that. So, how does one do proper matrix operations with matrices made from formal functions? |
2013-08-18 01:09:01 -0600 | commented answer | vector division? Ok., this makes (some) sense. Still, would you mind educating me on if this is just syntactic candy, or rather something absolutely standard that I should find in my high school linear algebra textbooks. |
2013-08-17 22:18:06 -0600 | asked a question | vector division? given a vector in sage then why is this a meaningful operation To my (utterly humble) understanding, I always thought, that if vector multiplication '*' is defined via the scalar product - as it seems to be in sage then, division cannot be defined meaningfully? [Just as a sideremark along that line: I have no problem with numpy's element wise array-arithmetic In my layman's world, this type of division makes perfect sense. (Moreover I'm curious why sage seems to not adopt this pythonic way of array arithmetic)] |
2013-08-17 09:19:34 -0600 | commented answer | How to return a list from callable symbolic expression (Maybe) that helps. Let me ask one for clarification. If I get you right, kind of your point is, that callable symbolic expression should allow for meaningful usage with symbolic operations like multiplication, addition a.s.o. But while a scalar product, as f*f may make sense (even though I wasn't even looking for that) the division f(x)/f(x) is also a symbolic operation, which does not make sense for me in case of vectors - although sage simply return f(x)/f(x) = 1 with my definition (1) |
2013-08-17 07:54:52 -0600 | commented answer | How to return a list from callable symbolic expression Can you provide me with an example of what you mean by 'unsafe' or 'not meaningful' if the callable symbolic expression would actually return what I have asked for, namely a list? |
2013-08-17 06:51:14 -0600 | asked a question | How to return a list from callable symbolic expression I was (wrongfully) expecting the return type of all of the following function calls to be the same, namely a list. Why does the callable symbolic expression (1) return a vector, and how to rewrite (1) such that it does return a list? |
2012-12-02 00:49:47 -0600 | received badge | ● Editor (source) |
2012-12-02 00:46:07 -0600 | answered a question | Solve contains wrong solution I would not agree with you that these solutions are 'wrong'. They are just presented in a very user unfriendly way. The 1st one, i.e.: definitely is a solution - it just specifies a range of measure zero, since so, it is not 'wrong' as you state - it is just 'totally useless' ;) The other solution is also perfectly ok since so, the solution you want is which I think is ok ..... however I would definetely agree with you that from a well known competitor is far more user friendly |
2012-12-01 11:37:19 -0600 | asked a question | non-commutative algebra with formal functions I'd like to look at the following: the set of formal functions with 2 variables f(x,y) and the real numbers a,b,c..., including an addition and a non-commutative multiplication, such that things like are possible (and vice versa), and with the multiplication of the functions being non-commutative, however with the multiplication of the functions by the real scalars still commutative. Can I construct something like that with sage? |
2012-12-01 10:45:50 -0600 | commented answer | equating formal functions Yes, I was expecting f(x)==f(x) to automatically simplify to True. (Mathematica will actually do so.) The bool()-typing workaround you suggest is kind of ok for me, yet, as I read your answer, it seems really strange that x-x==0 does not result in True but rather in 0==0 ... and moreover, if you type 0==0 at the sage prompt you will obviously get True ... |
2012-12-01 06:04:56 -0600 | asked a question | equating formal functions Why does the following not result in 'True'? or, speaking differently, can I define formal functions such that the preceding will result in 'True'? |
2012-11-29 03:43:08 -0600 | received badge | ● Teacher (source) |
2012-11-28 23:23:46 -0600 | answered a question | Why simplify does not simplify this expression ?
anyway, I guess what you want is |
2012-11-28 06:37:06 -0600 | commented answer | Why does this not integrate ehem, guys, for a newbs 1st-in-a-life-time three-liner typed into sage this is a little over my head. If this nobrainer integral results in a bug already, is your point that I should use integrate() only in conjunction with simplify_full()? Or is this a 'rare' case? Or am I doing something wrong? |
2012-11-28 02:06:22 -0600 | asked a question | Why does this not integrate why is this integral performed: i.e. I get: while this is not |