Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-05-2011, 11:07   #1
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
[Python] Esercizio di programmazione funzionale

Buon giorno,
ieri sera mentre armeggiavo su internet ho dato uno sguardo alla
programmazione funzionale.
Così da bravo nerd stamattina di buon ora mi sono messo a fare qualche
esercizio in python. Perché in python? Perché lo conosco già,
haskell era da zero ma probabilmente lo imparerò presto.

Comunque:
Ho un dubbio sul seguente codice scritto da me:
Codice:
from math import *

def mac(sig,coef):
    '''Moltiplica e accumula i valori del segnale coi coefficienti'''
    return reduce(lambda x,y: x+y,map(lambda x,y:x*y,sig,coef))

def buf_ins(buf,sig):
    '''inserimento circolare nel buffer'''
    for value in sig:
        buf.insert(0,value)
        buf.pop()
        yield buf

def convolve(sig,fil):
    '''1,2,3... Convoluzione! XD'''
    buf = [0 for i in range(len(fil))]
    #e forse si riesce pure ad eliminare il for...
    for b in buf_ins(buf,sig):
        yield mac(b,fil)
Questo codice funziona. Ho fatto tutte le prove, ho anche graficato i risultati della convoluzione con octave... tutto ok.
Il punto è che volevo eliminare il for nel metodo convolve usando map():
Codice:
map(mac,map(buf_ins,buf,sig),fil)
Però questo non funziona.
Dove sbaglio?
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2011, 17:57   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Forse perché convolve è un generatore, visto che utilizza yield?

Comunque se posti qualche riga per testare quel codice è meglio, così si può fare qualche prova.

P.S. Se t'interessa la velocità, al posto della lista tradizionale puoi usare la deque, che consente inserimento e rimozione in testa o coda in tempo costante, mentre le operazioni in testa nelle liste sono estremamente costose (lineari).
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2011, 23:54   #3
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
uhmhm...
In realtà al momento la velocità non mi interessa granché ma terrò presente deque e la sostituirò.
Io ho anche provato togliere yeld e a dire "ok, restituisco una lista".
Comincio però a pensare che il problema sia che non ho capito come funziona map.
map(buf_ins,buf,sig) mi ridà una lista di generatori, io invece pensavo mi desse una lista di numeri...
Probabilmente è quello il problema.
boh?... non lo so, domattina ci riprovo e posto eventuali soluzioni e il test.
Buona notte
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2011, 07:17   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Ho capito. Il problema è buf_ins, che non è una normale funzione, ma un generatore.

map restituisce una lista, ma i cui elementi derivano dall'applicazione di buf_ins ai valori delle due liste che vengono passati come i due parametri che prevede.

Poiché buf_ins è un generatore, è questo che verrà restituito da map per ogni singolo elemento.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2011, 15:33   #5
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Ho capito. Il problema è buf_ins, che non è una normale funzione, ma un generatore.

map restituisce una lista, ma i cui elementi derivano dall'applicazione di buf_ins ai valori delle due liste che vengono passati come i due parametri che prevede.

Poiché buf_ins è un generatore, è questo che verrà restituito da map per ogni singolo elemento.
Sono arrivato alla tua stessa conclusione e ho fatto la prova stampando il risultato di buf_ins... Va bene così per ora, mi tengo la versione funzionante. L'importante è aver capito dove stava l'inghippo
In ogni caso penso di studiare Haskell appena ho tempo, mi ha troppo preso questa cosa della programmazione funzionale!
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2011, 16:00   #6
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Francamente non faccio uso di map e reduce. Preferisco le list comprehension o le generator expression, oltre al modulo functools.

Comunque per la programmazione funzionale in Python c'è un ottimo tutorial nel sito ufficiale.

P.S. Di Haskell non mi piace proprio la sintassi.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
SpaceX realizzerà uno smartphone ...
Fire TV Omni QLED, Serie 2 e Serie 4: le...
Con l'Event Horizon Telescope si sta stu...
Milano Cortina 2026, dietro le quinte de...
IA e automazione: le armi per industrial...
SpaceX sta per rimuovere il braccio di a...
Sony a ISE 2026: display, soluzioni imme...
Sony punta sull'IA: brevettati i podcast...
Logitech G Astro A50, le cuffie gaming d...
Lenovo a ISE 2026: smart collaboration, ...
GeForce RTX 5000 SUPER cancellate e RTX ...
Substack conferma violazione: esposti da...
L'IA costa caro. Oracle punta a raccogli...
OpenAI lancia Frontier: il cervello cent...
Questo robot aspirapolvere lava sempre c...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 05:29.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v