single
Datatyper
Stryg for at vise menuen
Tilgængelige datatyper i TensorFlow
TensorFlow understøtter et væld af datatyper for at imødekomme forskellige typer data og operationer. Nogle af de mest anvendte typer er:
-
tf.float16,tf.float32,tf.float64: disse er flydende tal, hvor cifrene efter punktummet har betydning. Tallet i navnet (som16itf.float16) angiver antal bits der bruges.tf.float32anvendes ofte, da det giver en god balance mellem præcision og beregningshastighed; -
tf.int8,tf.int16,tf.int32,tf.int64: disse er heltalstyper, tal uden decimalpunktum. De kan være både positive og negative; -
tf.uint8,tf.uint16,tf.uint32,tf.uint64: 'u' står her for 'unsigned', hvilket betyder, at disse heltal altid er ikke-negative; -
tf.bool: repræsenterer booleske værdier (TrueellerFalse); -
tf.string: til tekstdata.
For heltalstyper betyder et større tal i navnet blot et bredere værdiinterval, det kan gemme. Men for flydende taltyper indikerer et højere tal i navnet også større beregningsnøjagtighed.
Der findes flere datatyper i TensorFlow, men for begyndere er det vigtigt først at blive fortrolig med disse primære typer. For en komplet liste over datatyper understøttet af TensorFlow, se venligst denne specifikke side i TensorFlow-dokumentationen.
Indstilling af datatype ved oprettelse af et tensor
Når du initialiserer et tensor, kan du angive dets type ved at bruge argumentet dtype:
123456789101112import tensorflow as tf # Creating a tensor of type `float16` tensor_float = tf.constant([1.2, 2.3, 3.4], dtype=tf.float16) # Creating a tensor of type `int64` tensor_int = tf.constant([1, 2, 3], dtype=tf.int64) # Display tensors print(tensor_float) print('-' * 50) print(tensor_int)
Mange tensor-oprettelsesfunktioner anvender denne tilgang. Det gælder for metoder som tf.Variable(), tf.zeros(), tf.ones(), tf.random.normal(), tf.random.uniform() og endda tf.convert_to_tensor().
Konvertering mellem datatyper
Men hvad nu hvis den funktion, du bruger, ikke tillader direkte angivelse af datatype? Eller måske har du allerede en tensor af en bestemt type og skal ændre den. I disse tilfælde skal du transformere tensorer fra én datatype til en anden. Dette er især relevant, da visse neurale netværksoperationer eller lag ofte kræver input af en bestemt type, primært flydende tal.
Du kan bruge tf.cast() til dette:
123456789101112import tensorflow as tf # Create a tensor tensor_float = tf.constant([-1.2, 2.3, 3.8]) # Convert our `tensor_float` from `float32` to `int32` tensor_int_converted = tf.cast(tensor_float, dtype=tf.int32) # Display a tensor print(tensor_float) print('-' * 50) print(tensor_int_converted)
Bemærk, at når du konverterer fra en flydende type til en heltalstype, vil TensorFlow udføre en floor-operation, hvilket betyder, at decimaldelen fjernes. Så 3.8 bliver til 3, og -1.2 bliver til -1.
Vær forsigtig, når du ændrer datatyper, især når du skifter til en type med lavere præcision. Du kan miste information under processen.
Swipe to start coding
Din opgave er at oprette en tensor af en bestemt datatype og derefter konvertere den til en anden datatype.
- Opret en tensor med navnet
initial_tensormed formen(3, 3)og normalt fordelte værdier. Sørg for, at denne tensor har en datatype med 64-bit flydende tal. - Transformér
initial_tensortil en tensor kaldetconverted_tensormed en datatype af 16-bit flydende tal.
Løsning
Tak for dine kommentarer!
single
Spørg AI
Spørg AI
Spørg om hvad som helst eller prøv et af de foreslåede spørgsmål for at starte vores chat