Question

Je sais que c'est une question assez épaisse, mais j'essaie d'effectuer des comparaisons entre F # et C # et j'ai emprunté un script F # auprès de http://www.clear-lines.com/blog/post/nearest-neighbor-classification-part-2.aspx Et j'essaie de retirer l'opération équivalente d'un programme C # dans le but de tester l'opération et la syntaxe. Cette partie est dans un script plus large que je convertit en un programme F # qui effectue une analyse K-means des données données.

Voici la partie F #:

let elections =
    let file = @"C:\Users\Deines\Documents\Election2008.txt"
    let fileAsLines =
        File.ReadAllLines(file)
            |> Array.map (fun line -> line.Split(','))
    let dataset =
        fileAsLines
        |> Array.map (fun line ->
            [| Convert.ToDouble(line.[1]);
               Convert.ToDouble(line.[2]);
               Convert.ToDouble(line.[3]) |])
    let labels = fileAsLines |> Array.map (fun line -> line.[4])
    dataset, labels 

Voici un échantillon des données (Election2008.txt):

AL,32.7990,-86.8073,4447100,REP 
AK,61.3850,-152.2683,626932,REP 
AZ,33.7712,-111.3877,5130632,REP 
AR,34.9513,-92.3809,2673400,REP 
CA,36.1700,-119.7462,33871648,DEM 
CO,39.0646,-105.3272,4301261,DEM 
CT,41.5834,-72.7622,3405565,DEM 
DE,39.3498,-75.5148,783600,DEM 
DC,38.8964,-77.0262,572059,DEM 
FL,27.8333,-81.7170,15982378,DEM 
Était-ce utile?

La solution

Vous pouvez effectuer la même opération de base en C # via:

Tuple<double[][], string[]> GetElections()
{
    var file = @"C:\Users\Deines\Documents\Election2008.txt";
    var fileAsLines = File.ReadLines(file).Select(line => line.Split(','));
    var dataset = fileAsLines.Select(line => new[] 
                                             { 
                                                 Convert.ToDouble(line[1]),
                                                 Convert.ToDouble(line[2]),
                                                 Convert.ToDouble(line[3])
                                             }).ToArray();
    var labels = fileAsLines.Select(line => line[4]).ToArray();
    return Tuple.Create(dataset, labels);
}

Cela étant dit, les développeurs C # écriraient rarement ceci de cette manière. Il serait plus probable que vous fassiez un type personnalisé pour contenir les résultats (avec des valeurs de nom +) et de le lire de cette façon, c'est-à-dire:

class ElectionResult
{
     public ElecationResult(string label, double x, double y, int amount)
     {
         this.Label = label;
         this.Point = new Point(x,y);
         this.Amount = amount;
     }
     string Label { get; private set; }
     Point Location { get; private set; }
     int Amount { get; private set; }
}

IList<ElectionResult> GetElectionResults()
{
    var file = @"C:\Users\Deines\Documents\Election2008.txt";
    var fileAsLines = File.ReadLines(file).Select(line => line.Split(','));

    return fileAsLines.Select(line => new ElectionResult(line[4],
                                                 Convert.ToDouble(line[1]),
                                                 Convert.ToDouble(line[2]),
                                                 Convert.ToInt32(line[3]))
                      .ToList();
}

Cela rend beaucoup plus utilisable pour un développeur C # typique, car il n'y a pas de correspondance de modèle pour extraire les tableaux du résultat du tuple.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top