summaryrefslogtreecommitdiffstatshomepage
path: root/py
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2015-02-02 12:52:14 +0000
committerDamien George <damien.p.george@gmail.com>2015-02-02 12:52:14 +0000
commitf49782f0058b0c7bdf21471a9265117089439124 (patch)
tree876590d937067ff4aab6ee348000abe3c8327d2c /py
parent471b2a8906182616dee2f5be1bf6348b0ff56337 (diff)
downloadmicropython-f49782f0058b0c7bdf21471a9265117089439124.tar.gz
micropython-f49782f0058b0c7bdf21471a9265117089439124.zip
py: Fix cmath.log10; fix printing of complex number with negative imag.
Diffstat (limited to 'py')
-rw-r--r--py/modcmath.c2
-rw-r--r--py/objcomplex.c10
2 files changed, 9 insertions, 3 deletions
diff --git a/py/modcmath.c b/py/modcmath.c
index 59fa76ee68..46a33d3a89 100644
--- a/py/modcmath.c
+++ b/py/modcmath.c
@@ -97,7 +97,7 @@ STATIC MP_DEFINE_CONST_FUN_OBJ_1(mp_cmath_log_obj, mp_cmath_log);
STATIC mp_obj_t mp_cmath_log10(mp_obj_t z_obj) {
mp_float_t real, imag;
mp_obj_get_complex(z_obj, &real, &imag);
- return mp_obj_new_complex(0.5 * MICROPY_FLOAT_C_FUN(log10)(real*real + imag*imag), MICROPY_FLOAT_C_FUN(atan2)(imag, real));
+ return mp_obj_new_complex(0.5 * MICROPY_FLOAT_C_FUN(log10)(real*real + imag*imag), 0.4342944819032518 * MICROPY_FLOAT_C_FUN(atan2)(imag, real));
}
STATIC MP_DEFINE_CONST_FUN_OBJ_1(mp_cmath_log10_obj, mp_cmath_log10);
diff --git a/py/objcomplex.c b/py/objcomplex.c
index 027292a17a..6a403f6269 100644
--- a/py/objcomplex.c
+++ b/py/objcomplex.c
@@ -58,7 +58,10 @@ STATIC void complex_print(void (*print)(void *env, const char *fmt, ...), void *
print(env, "%sj", buf);
} else {
mp_format_float(o->real, buf, sizeof(buf), 'g', 7, '\0');
- print(env, "(%s+", buf);
+ print(env, "(%s", buf);
+ if (o->imag >= 0) {
+ print(env, "+");
+ }
mp_format_float(o->imag, buf, sizeof(buf), 'g', 7, '\0');
print(env, "%sj)", buf);
}
@@ -69,7 +72,10 @@ STATIC void complex_print(void (*print)(void *env, const char *fmt, ...), void *
print(env, "%sj", buf);
} else {
sprintf(buf, "%.16g", (double)o->real);
- print(env, "(%s+", buf);
+ print(env, "(%s", buf);
+ if (o->imag >= 0) {
+ print(env, "+");
+ }
sprintf(buf, "%.16g", (double)o->imag);
print(env, "%sj)", buf);
}