28 lines
1 KiB
Go
28 lines
1 KiB
Go
|
// Copyright 2020 The Go Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
package strconv
|
||
|
|
||
|
// FormatComplex converts the complex number c to a string of the
|
||
|
// form (a+bi) where a and b are the real and imaginary parts,
|
||
|
// formatted according to the format fmt and precision prec.
|
||
|
//
|
||
|
// The format fmt and precision prec have the same meaning as in FormatFloat.
|
||
|
// It rounds the result assuming that the original was obtained from a complex
|
||
|
// value of bitSize bits, which must be 64 for complex64 and 128 for complex128.
|
||
|
func FormatComplex(c complex128, fmt byte, prec, bitSize int) string {
|
||
|
if bitSize != 64 && bitSize != 128 {
|
||
|
panic("invalid bitSize")
|
||
|
}
|
||
|
bitSize >>= 1 // complex64 uses float32 internally
|
||
|
|
||
|
// Check if imaginary part has a sign. If not, add one.
|
||
|
im := FormatFloat(imag(c), fmt, prec, bitSize)
|
||
|
if im[0] != '+' && im[0] != '-' {
|
||
|
im = "+" + im
|
||
|
}
|
||
|
|
||
|
return "(" + FormatFloat(real(c), fmt, prec, bitSize) + im + "i)"
|
||
|
}
|