mirror of
				https://github.com/gonum/gonum.git
				synced 2025-10-27 01:00:26 +08:00 
			
		
		
		
	Moved unit types to different files
This commit is contained in:
		
							
								
								
									
										59
									
								
								dimless.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								dimless.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| package unit | ||||
|  | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"math" | ||||
| ) | ||||
|  | ||||
| // Dimless represents a dimensionless constant | ||||
| type Dimless float64 | ||||
|  | ||||
| const ( | ||||
| 	One Dimless = 1.0 | ||||
| ) | ||||
|  | ||||
| // Unit converts the Dimless to a unit | ||||
| func (d Dimless) Unit() *Unit { | ||||
| 	return New(float64(d), Dimensions{}) | ||||
| } | ||||
|  | ||||
| // Dimless allows Dimless to implement a Dimlesser interface | ||||
| func (d Dimless) Dimless() Dimless { | ||||
| 	return d | ||||
| } | ||||
|  | ||||
| // From converts the unit to a dimless. Returns an error if there | ||||
| // is a mismatch in dimension | ||||
| func (d *Dimless) From(u *Unit) error { | ||||
| 	if !DimensionsMatch(u, One) { | ||||
| 		(*d) = Dimless(math.NaN()) | ||||
| 		return errors.New("Dimension mismatch") | ||||
| 	} | ||||
| 	(*d) = Dimless(u.Unit().Value()) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (d Dimless) Format(fs fmt.State, c rune) { | ||||
| 	switch c { | ||||
| 	case 'v': | ||||
| 		if fs.Flag('#') { | ||||
| 			fmt.Fprintf(fs, "%T(%v)", d, float64(d)) | ||||
| 			return | ||||
| 		} | ||||
| 		fallthrough | ||||
| 	case 'e', 'E', 'f', 'F', 'g', 'G': | ||||
| 		p, pOk := fs.Precision() | ||||
| 		if !pOk { | ||||
| 			p = -1 | ||||
| 		} | ||||
| 		w, wOk := fs.Width() | ||||
| 		if !wOk { | ||||
| 			w = -1 | ||||
| 		} | ||||
| 		fmt.Fprintf(fs, "%*.*"+string(c), w, p, float64(d)) | ||||
| 	default: | ||||
| 		fmt.Fprintf(fs, "%%!%c(%T=%g)", c, d, float64(d)) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										61
									
								
								length.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								length.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | ||||
| package unit | ||||
|  | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"math" | ||||
| ) | ||||
|  | ||||
| // Length represents a length in meters | ||||
| type Length float64 | ||||
|  | ||||
| const ( | ||||
| 	Meter      Length = 1.0 | ||||
| 	Centimeter Length = 0.01 | ||||
| ) | ||||
|  | ||||
| // Unit converts the Length to a unit | ||||
| func (l Length) Unit() *Unit { | ||||
| 	return New(float64(l), Dimensions{MassDim: 1}) | ||||
| } | ||||
|  | ||||
| // Length allows length to implement a Lengther interface | ||||
| func (l Length) Length() Length { | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| // From converts a uniter to a length. Returns an error if there | ||||
| // is a mismatch in dimension | ||||
| func (l *Length) From(u Uniter) error { | ||||
| 	if !DimensionsMatch(u, Meter) { | ||||
| 		(*l) = Length(math.NaN()) | ||||
| 		return errors.New("Dimension mismatch") | ||||
| 	} | ||||
| 	(*l) = Length(u.Unit().Value()) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (l Length) Format(fs fmt.State, c rune) { | ||||
| 	switch c { | ||||
| 	case 'v': | ||||
| 		if fs.Flag('#') { | ||||
| 			fmt.Fprintf(fs, "%T(%v)", l, float64(l)) | ||||
| 			return | ||||
| 		} | ||||
| 		fallthrough | ||||
| 	case 'e', 'E', 'f', 'F', 'g', 'G': | ||||
| 		p, pOk := fs.Precision() | ||||
| 		if !pOk { | ||||
| 			p = -1 | ||||
| 		} | ||||
| 		w, wOk := fs.Width() | ||||
| 		if !wOk { | ||||
| 			w = -1 | ||||
| 		} | ||||
| 		fmt.Fprintf(fs, "%*.*"+string(c), w, p, float64(l)) | ||||
| 		fmt.Fprint(fs, " m") | ||||
| 	default: | ||||
| 		fmt.Fprintf(fs, "%%!%c(%T=%g m)", c, l, float64(l)) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										70
									
								
								mass.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								mass.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| package unit | ||||
|  | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"math" | ||||
| ) | ||||
|  | ||||
| // Represents a mass in kilograms | ||||
| type Mass float64 | ||||
|  | ||||
| const ( | ||||
| 	Yottagram Mass = 1e12 | ||||
| 	Zettagram Mass = 1e18 | ||||
| 	Exagram   Mass = 1e15 | ||||
| 	Petagram  Mass = 1e12 | ||||
| 	Teragram  Mass = 1e9 | ||||
| 	Gigagram  Mass = 1e6 | ||||
| 	Megagram  Mass = 1e3 | ||||
| 	Kilogram  Mass = 1.0 | ||||
| 	Gram      Mass = 1e-3 | ||||
| 	Milligram Mass = 1e-6 | ||||
| 	Microgram Mass = 1e-9 | ||||
| ) | ||||
|  | ||||
| // Mass converts the Mass to a unit | ||||
| func (m Mass) Unit() *Unit { | ||||
| 	return New(float64(m), Dimensions{MassDim: 1}) | ||||
| } | ||||
|  | ||||
| // Mass allows Mass to implement a Masser interface | ||||
| func (m Mass) Mass() Mass { | ||||
| 	return m | ||||
| } | ||||
|  | ||||
| // From converts the unit to a mass. Returns an error if there | ||||
| // is a mismatch in dimension | ||||
| func (m *Mass) From(u Uniter) error { | ||||
| 	if !DimensionsMatch(u, Kilogram) { | ||||
| 		(*m) = Mass(math.NaN()) | ||||
| 		return errors.New("Dimension mismatch") | ||||
| 	} | ||||
| 	(*m) = Mass(u.Unit().Value()) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (m Mass) Format(fs fmt.State, c rune) { | ||||
| 	switch c { | ||||
| 	case 'v': | ||||
| 		if fs.Flag('#') { | ||||
| 			fmt.Fprintf(fs, "%T(%v)", m, float64(m)) | ||||
| 			return | ||||
| 		} | ||||
| 		fallthrough | ||||
| 	case 'e', 'E', 'f', 'F', 'g', 'G': | ||||
| 		p, pOk := fs.Precision() | ||||
| 		if !pOk { | ||||
| 			p = -1 | ||||
| 		} | ||||
| 		w, wOk := fs.Width() | ||||
| 		if !wOk { | ||||
| 			w = -1 | ||||
| 		} | ||||
| 		fmt.Fprintf(fs, "%*.*"+string(c), w, p, float64(m)) | ||||
| 		fmt.Fprint(fs, " kg") | ||||
| 	default: | ||||
| 		fmt.Fprintf(fs, "%%!%c(%T=%g kg)", c, m, float64(m)) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 btracey
					btracey