Я пытаюсь заставить работать базовую модель тензорного потока в моем приложении, но сталкиваюсь со следующей ошибкой:
клиент. js? 06a0: 84 Ошибка: аргумент 'x 'переданный в' slice2d 'должен иметь число c тензор, но получил тензор строки в vn (tf-core.esm. js? 45ef: 17) в gn (tf-core.esm. js? 45ef: 17) в slice2d_ (tf-core.esm. js? 45ef: 17) в slice2d (tf-core.esm. js? 45ef: 17) в eval (tf-layer.esm. js? 271e) : 17) в eval (tf-core.esm. js? 45ef: 17) в t.scopedRun (tf-core.esm. js? 45ef: 17) в t.tidy (tf-core.esm. js 45ef: 17) в Ze (tf-core.esm. js? 45ef: 17) в sliceAlongFirstAxis (tf-layer.esm. js? 271e: 17) vue__WEBPACK_IMPORTED_MODULE_22 __. Default.config.errorHand client. js? 06a0: 84 globalHandleError @ vue .runtime.esm. js? 2b0e: 1870 handleError @ vue .runtime.esm. js? 2b0e: 1839 invokeWithErrorHandling @ vue .runtime .esm. js? 2b0e: 1862 invoker @ vue .runtime.esm. js? 2b0e: 2179 original._wrapper @ vue .runtime.esm. js? 2b0e: 6917
Я пробовал parseInt, но, похоже, это не имеет значения. Код ниже:
<template>
<div>
<div class="train-controls">
<h2 class="section col-sm-1">Training Data (x,y) pairs</h2>
<div class="field-label">X</div><div class="field-label">Y</div>
<div v-for="(item, index) in xValues" v-bind:key="index">
<div>
<div class="col-sm-1">
<input class="field field-x" v-model="xValues[index]" type="number">
<input class="field field-y" v-model="yValues[index]" type="number">
</div>
</div>
</div>
<button class="button-add-example button--green" v-on:click="addItem">+</button>
<button class="button-train button--green" v-on:click="train">Train</button>
</div>
<div class="predict-controls">
<h2 class="section col-sm-1">Predicting</h2>
<input class="field element" v-model="valueToPredict" type="number" placeholder="Enter an integer number"><br>
<div class="element">{{predictedValue}}</div>
<button class="element button--green" v-on:click="predict" :disabled="!trained">Predict</button>
</div>
</div>
</template>
<script>
import * as tf from '@tensorflow/tfjs';
export default {
data() {
return {
trained: false,
xValues: [1,2,3,4],
yValues: [1,3,5,7],
predictedValue:'Click on train!',
valueToPredict:''
}
},
methods: {
addItem() {
this.xValues.push(0);
this.yValues.push(0);
},
train() {
// Define a model for linear regression.
const model = this.model = tf.sequential();
model.add(tf.layers.dense({units: 1, inputShape: [1]}));
// Prepare the model for training: Specify the loss and the optimizer.
model.compile({loss: 'meanSquaredError', optimizer: 'sgd'});
const xs = tf.tensor2d(this.xValues, [this.xValues.length, 1]);
const ys = tf.tensor2d(this.yValues, [this.yValues.length, 1]);
// Train the model using the data.
model.fit(xs, ys, {epochs: 50}).then(() => {
this.trained = true;
this.predictedValue = 'Ready for making predictions';
});
},
predict() {
// Use the model to do inference on a data point the model hasn't seen before:
this.predictedValue = this.model.predict(tf.tensor2d([this.valueToPredict], [1, 1])).get(0, 0);
}
}
}
</script>
<style>
.field, .field-label {
height: 30px;
padding: 0px 15px;
float: left;
width: 50%;
}
.field {
border-radius: 0px 5px 5px 0px;
border: 1px solid #eee;
margin-bottom: 15px;
height: 40px;
}
.col-sm-1:after {
content: "";
display: table;
clear: both;
}
.section, .field-label {
text-align: left;
font-family: "Quicksand", "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; /* 1 */
font-weight: 100;
}
.field-label {
font-weight: 700;
}
.button-add-example {
width: 100%;
margin-bottom: 10px;
}
.button-train {
width: 100%;
}
.predict-controls {
padding-top: 30px;
padding-bottom: 30px;
}
.predict-controls .element {
width: 50%;
display: block;
}
button {
margin-top: 10px;
font-family: "Quicksand", "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; /* 1 */
font-weight: 700;
}
</style>