Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-10-2009, 00:34   #1
nikaldo
Junior Member
 
Iscritto dal: Feb 2009
Messaggi: 3
[C++] Errore di compilazione

In internet ho trovato questo codice sorgente in C++ per la ricerca di numeri primi , ma provandolo sul compilatore C++ 6 della Microsoft
mi segnala un errore di cui non riesco a trovare la soluzione, sperando che qualcuno possa aiutarmi ringrazio in anticipo.

_>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

#include <iostream>
#include <cmath>
using namespace std;

void numeri_primi(int max)
{
int k=(int)(max/trunc(log(max))); /* usa la stima di Gauss sul numero dei numeri primi, valido per max che entra in una variabile */
int i, j , pasI=2;
int *dp=new int[k];
int *m=new int[k];
int massimo=1,prova;

dp[0]=5;
m[0]=25;

if (max >=2){
cout<<2<<endl;
}
if (max >=3){
cout<<3<<endl;
}
if (max >=5){
cout<<5<<endl;
}

for(i=7; i<max ;i+=(pasI=6-pasI)) // evita i multipli di 3
{
/* cerca i divisori tra i primi già trovati fino a sqrt(i) */
for(prova = dp[j=0]; (i%m[j]) && prova*prova < i; prova=dp[++j])
{
if(i>m[j])
m[j]+= 2*prova;
}
if(i!=m[j])
{
cout<<i<<endl;
dp[massimo]=i;
m[massimo++]=i*i;
}
}

delete dp;
delete m;
}

int main(void)
{
int i;

cout<<"Introdurre il numero Max : "<<endl;
cin>>i;
numeri_primi(i);
}


____________________________________________________________________________________________________________________________

Compiling...
Numeriprimi.cpp
c:\n_prime\numeriprimi.cpp(7) : error C2065: 'trunc' : undeclared identifier
c:\n_prime\numeriprimi.cpp(53) : warning C4508: 'main' : function should return a value; 'void' return type assumed
Error executing cl.exe.

N_prime.exe - 1 error(s), 1 warning(s)
nikaldo è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 01:44   #2
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
mai sentito parlare della funzione trunc O_O
Cercando su google ho visto che dovrebbe comportarsi come la funzione floor. Prova a sostituire trunc con floor e la cosa dovrebbe funzionare
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 14:16   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
trunc non esiste perché il troncamento si fa semplicemente convertendo da floating point ad intero.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 00:12   #4
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
Quote:
Originariamente inviato da cionci Guarda i messaggi
trunc non esiste perché il troncamento si fa semplicemente convertendo da floating point ad intero.
ah quindi non è equivalente a floor? Allora avevo capito male
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 08:27   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Torav Guarda i messaggi
ah quindi non è equivalente a floor? Allora avevo capito male
E' equivalente solo per i floating point positivi

flloor(-0.1) ritorna -1, (int)-0.1 ritorna 0
flloor(-2.1) ritorna -3, (int)-2.1 ritorna -2
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 09:18   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Una precisazione: su cpu intel il cast da float ad int è critico per le prestazioni in quanto viene svuotata completamente la pipeline della fpu e viene modificata la modalità di funzionamento della stessa (da arrotondamento a troncamento) per eseguire l'operazione e viceversa per poter eseguire tutte le operazioni seguenti.
Il C99 fornisce le funzioni lrint,lrintf ecc che evitano questo problema.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 13:10   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Comunque lrint non fa la stessa cosa della conversione ad intero. Fa l'arrotondamento.
Codice:
int main()
{
   printf("%ld\n", lrint(-0.9));
   printf("%ld\n", lrint(-0.1));      
   printf("%d\n", (int)-0.9);      
}
L'output sarà:
-1
0
0

Questa cosa del cambio di modalità dell'unità floating point sinceramente non la sapevo. Ora provo a tradurre in codice assembly
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 13:25   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Per la conversione in asm x64 viene usata questa istruzione: http://www.sesp.cse.clrc.ac.uk/html/...32_hh/vc67.htm
Quindi per i compilatori a 64 bit non ci sono problemi.

In effetti in asm x86 si vede l'istruzione fldcw che svuota la pipeline.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2009, 00:11   #9
nikaldo
Junior Member
 
Iscritto dal: Feb 2009
Messaggi: 3
C++ Errore di esecuzione

Vi ringrazio per l'aiuto , sostituendo a " trunc " l'istruzione "int" il programma funziona perfettamente; mi resta solo la curiosità del perchè sia stata utilizzato questo tipo di istruzione in C++ pechè a quanto ho potuto appurare è invece tipica del linguaggio Visual J++.
nikaldo è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2009, 08:21   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Non ne ho idea...probabilmente è stato utilizzato qualche compilatore che ha nella libreria math questa istruzione non standard.
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Il nuovo MacBook Neo ha una memoria SSD ...
Xbox Project Helix, le prime specifiche ...
Annunci pubblicitari sulla TV quando cam...
Prezzi aumentati del 50% durante la nott...
Sconti studiati per singolo utente: Sony...
Addio alla Kia Niro EV, il crossover sar...
Apple crede nel suo iPhone Fold: la prod...
Fortnite, un nuovo listino per i pacchet...
Ecco i nuovi Sonos Play ed Era 100 SL: d...
Razer svela il futuro del gaming potenzi...
Tre robot Narwal in offerta: pulizia aut...
Gracenote denuncia OpenAI: ChatGPT addes...
Microsoft AI Tour Milano: dall'efficienz...
Asus ExpertBook Ultra: Intel Core Ultra ...
Intel presenta i processori desktop Core...
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: 03:26.


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